【分布式注册中心】NACOS_2.3.0部署与实战

部署

一 准备

1 依赖:MYSQL

2 创建数据库

复制代码
CREATE database if NOT EXISTS `nacos` default character set utf8mb4 collate utf8mb4_unicode_ci;

3 导入初始化SQL

https://raw.githubusercontent.com/alibaba/nacos/develop/distribution/conf/mysql-schema.sqlhttps://raw.githubusercontent.com/alibaba/nacos/develop/distribution/conf/mysql-schema.sql

4 执行创建NACOS管理员账号SQL(初始账号密码:nacos/nacos)

复制代码
INSERT INTO users (username, password, enabled) VALUES ('nacos', '$2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu', TRUE);
INSERT INTO roles (username, role) VALUES ('nacos', 'ROLE_ADMIN');

5 执行创建MYSQL操作员SQL

复制代码
CREATE USER 'nacos'@'%' IDENTIFIED BY 'nacos';
GRANT ALL PRIVILEGES ON nacos.* TO 'nacos'@'%';
FLUSH PRIVILEGES;

二 DOCKER部署

复制代码
sudo docker run -d \
-p 8848:8848 \
-p 9848:9848 \
-e PREFER_HOST_MODE=hostname \
-e MODE=standalone \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=mysql \
-e MYSQL_SERVICE_DB_NAME=nacos \
-e MYSQL_SERVICE_PORT=3306 \
-e MYSQL_SERVICE_USER=nacos \
-e MYSQL_SERVICE_PASSWORD=nacos \
-e "MYSQL_SERVICE_DB_PARAM=characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true" \
-e NACOS_AUTH_ENABLE=true \
-e NACOS_AUTH_IDENTITY_KEY=nacos \
-e NACOS_AUTH_IDENTITY_VALUE=nacos \
-e NACOS_AUTH_TOKEN=SecretKey012345678901234567890123456789012345678901234567890123456789 \
-v /Users/wuzijing/Documents/middle/nacos/log:/home/nacos/logs \
--name nacos \
--privileged=true \
--restart=always \
nacos/nacos-server:v2.3.0

代码

一 JAVA配置

1 YAML

复制代码
server:
  port: 8904
spring:
  application:
    name: report
  cloud:
    nacos:
      config:
        server-addr: ip:8848
        group: DEFAULT_GROUP
        username: nacos
        password: nacos
  config:
    import[0]: optional:nacos:/${spring.application.name}.yaml

2 POM

复制代码
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
  <version>2023.0.1.2</version>
  <exclusions>
    <exclusion>
      <groupId>com.alibaba.nacos</groupId>
      <artifactId>nacos-client</artifactId>
    </exclusion>
  </exclusions>
</dependency>
<dependency>
  <groupId>com.alibaba.nacos</groupId>
  <artifactId>nacos-spring-context</artifactId>
  <version>2.1.0-RC</version>
  <exclusions>
    <exclusion>
      <groupId>com.alibaba.nacos</groupId>
      <artifactId>nacos-client</artifactId>
    </exclusion>
  </exclusions>
</dependency>
<dependency>
  <groupId>com.alibaba.nacos</groupId>
  <artifactId>nacos-client</artifactId>
  <version>2.3.0</version>
</dependency>
<dependency>
  <groupId>io.netty</groupId>
  <artifactId>netty-resolver-dns-native-macos</artifactId>
  <classifier>osx-aarch_64</classifier>
</dependency>

3 启动类注解

复制代码
import com.alibaba.nacos.spring.context.annotation.EnableNacos;
import com.alibaba.nacos.api.annotation.NacosProperties;

@EnableNacos(
    globalProperties = @NacosProperties(
        serverAddr = "${spring.cloud.nacos.config.server-addr}",
        username = "${spring.cloud.nacos.config.username}",
        password = "${spring.cloud.nacos.config.password}"
    )
)
相关推荐
二月夜4 小时前
剖析Java正则表达式回溯问题
java·正则表达式
xuhaoyu_cpp_java5 小时前
项目学习(三)分页查询
java·经验分享·笔记·学习
程序员二叉5 小时前
【Java】集合面试全套精讲|HashMap/ArrayList高频考点完整版
java·面试·哈希算法
cfm_29145 小时前
JVM GC垃圾回收初步了解
java·开发语言·jvm
心之伊始6 小时前
LangChain4j RAG 实战:Java 后端如何把本地文档接入 Embedding 检索链路
java·架构·源码分析·csdn
许彰午6 小时前
17_synchronized关键字深度解析
java·开发语言
闪电悠米7 小时前
黑马点评-Redis 消息队列-03_stream_consumer_group
开发语言·数据库·redis·分布式·缓存·junit·lua
Xzh04237 小时前
AI Agent 学习路线(Java 后端方向)
java·人工智能·学习
艾利克斯冰8 小时前
Java 设计模式-行为型模式(更新中)
java·开发语言·设计模式
倒霉蛋小马8 小时前
Java新特性:record关键字
java·开发语言