SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理

Nacos 注册中心

(图片部分引自黑马程序员SpringCloud讲义)

认识和安装Nacos

1.Windows安装

开发阶段采用单机安装即可。

1.1 下载安装包

在Nacos的GitHub页面,提供有下载链接,可以下载编译好的Nacos服务端或者源代码:

GitHub主页:https://github.com/alibaba/nacos

GitHub的Release下载页:https://github.com/alibaba/nacos/releases

如图:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第1张图片

本课程采用1.4.1.版本的Nacos,课前资料已经准备了安装包:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第2张图片

windows版本使用nacos-server-1.4.1.zip包即可。

1.2 解压

将这个包解压到任意非中文目录下,如图:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第3张图片

目录说明:

  • bin:启动脚本
  • conf:配置文件

1.3 端口配置

Nacos的默认端口是8848,如果你电脑上的其它进程占用了8848端口,请先尝试关闭该进程。

如果无法关闭占用8848端口的进程,也可以进入nacos的conf目录,修改配置文件中的端口:
SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第4张图片

修改其中的内容:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第5张图片

1.4 启动

启动非常简单,进入bin目录,结构如下:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第6张图片

然后执行命令即可:

  • windows命令:

    startup.cmd -m standalone
    

执行后的效果如图:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第7张图片

1.5 访问

在浏览器输入地址:http://127.0.0.1:8848/nacos即可:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第8张图片

默认的账号和密码都是nacos,进入后:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第9张图片

2.Linux安装

Linux或者Mac安装方式与Windows类似。

2.1 安装JDK

Nacos依赖于JDK运行,索引Linux上也需要安装JDK才行。

上传jdk安装包:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第10张图片

上传到某个目录,例如:/usr/local/

然后解压缩:

tar -xvf jdk-8u144-linux-x64.tar.gz

然后重命名为java

配置环境变量:

export JAVA_HOME=/usr/local/java
export PATH=$PATH:$JAVA_HOME/bin

设置环境变量:

source /etc/profile

2.2 上传安装包

如图:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第11张图片

也可以直接使用课前资料中的tar.gz:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第12张图片

上传到Linux服务器的某个目录,例如/usr/local/src目录下:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第13张图片

2.3 解压

命令解压缩安装包:

tar -xvf nacos-server-1.4.1.tar.gz

然后删除安装包:

rm -rf nacos-server-1.4.1.tar.gz

目录中最终样式:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第14张图片

目录内部:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第15张图片

2.4 端口配置

与windows中类似

2.5 启动

在nacos/bin目录中,输入命令启动Nacos:

sh startup.sh -m standalone

3.Nacos的依赖

父工程:

<dependency>
    <groupId>com.alibaba.cloudgroupId>
    <artifactId>spring-cloud-alibaba-dependenciesartifactId>
    <version>2.2.5.RELEASEversion>
    <type>pomtype>
    <scope>importscope>
dependency>

客户端:


<dependency>
    <groupId>com.alibaba.cloudgroupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discoveryartifactId>
dependency>

Nacos快速入门

修改 user-serviceorder-service 中的 application.yml 文件,注释eureka地址(nacos和eureka都是用以注册服务,但是eureka性能更强大一些),添加nacos地址:

spring:
  cloud:
    nacos:
      server-addr: localhost:8848 #配置nacos端口

#eureka:
#  client:
#    service-url:
#      defaultZone: http://127.0.0.1:10086/eureka/

启动我们的 user-serviceorder-service

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第16张图片

Nacos服务分级存储模型

Nacos服务分级存储模型

  • 一级是服务,例如userservice
  • 二级是集群,例如杭州或上海
  • 三级是实例,例如杭州机房的某台部署了userservice的服务器

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第17张图片

服务调用尽可能选择本地集群的服务,跨集群调用延迟较高。本地集群不可访问时,再去访问其它集群

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第18张图片

修改application.yml,添加如下内容:

spring:
    cloud:
        nacos:
          server-addr: localhost:8848 #配置nacos端口
          discovery:
            cluster-name: SH  # 配置集群名称,也就是机房位置,例如:HZ,杭州

在Nacos控制台可以看到集群变化:
SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第19张图片

order-serviceapplication.yml 文件中

spring:
    cloud:
        nacos:
          server-addr: localhost:8848 #配置nacos端口
          discovery:
            cluster-name: SH  # 配置集群名称,也就是机房位置,例如:HZ,杭州

并且重新设计负载均衡。注意,要注释掉前面使用的Ribbon负载均衡

@Configuration
public class IRuleConfig {

    /** ribbon 负载均衡
     * 对所有order-service调用的微服务做负载均衡
     * */
//    @Bean
//    public IRule randomRule(){
//        return new RandomRule();
//    }

}
# 可以针对某个微服务做负载均衡
userservice:
  ribbon:
#    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 负载均衡规则
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则

总结来说:

  • NacosRule负载均衡策略优先选择同集群服务实例列表
  • 本地集群找不到提供者,才去其它集群寻找,并且会报警告
  • 确定了可用实例列表后,再采用随机负载均衡挑选实例

Nacos 负责均衡设置

实际部署中会出现这样的场景:服务器设备性能有差异,部分实例所在机器性能较好,另一些较差,我们希望性能好的机器承担更多的用户请。求Nacos提供了权重配置来控制访问频率,权重越大则访问频率越高。通过Nacos来设置权重,首先选中实例后面的编辑按钮

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第20张图片

将权重设置为0.1,测试可以发现8081被访问到的频率大大降低。权重设置为0则完全不会被访问
SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第21张图片

Nacos环境隔离

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第22张图片

在Nacos控制台可以创建namespace,用来隔离不同环境

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第23张图片

保存后会在控制台看到这个命名空间的id

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第24张图片

order-serviceapplication.yml 中添加 namespace 域,将命名空间ID填入

spring:
    cloud:
        nacos:
          server-addr: localhost:8848 #配置nacos端口
          discovery:
            cluster-name: SH  # 配置集群名称,也就是机房位置,例如:HZ,杭州
            namespace: 492a7d5d-237b-46a1-a99a-fa8e98e4b0f9 # 命名空间,填ID

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第25张图片

此时访问order-service,因为namespace不同,会导致找不到userservice,控制台会报错:

在这里插入图片描述

总结来说,Nacos环境隔离每个namespace都有唯一id服务,设置namespace时要写id而不是名称,不同namespace下的服务互相不可见

Nacos 和 Eureka 的对比

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第26张图片

服务注册到Nacos时,可以选择注册为临时或非临时实例,通过下面的配置来设置:

spring:
	cloud:
		nacos:
			discovery:
				ephemeral: false # 设置为非临时实例

临时实例宕机时,会从nacos的服务列表中剔除,而非临时实例则不会

Nacos与eureka的共同点

  • 都支持服务注册和服务
  • 拉取都支持服务提供者心跳方式做健康检测

Nacos与Eureka的区别

  • Nacos支持服务端主动检测提供者状态:临时实例采用心跳模式,非临时实例采用主动检测模式
  • 临时实例心跳不正常会被剔除,非临时实例则不会被剔除
  • Nacos支持服务列表变更的消息推送模式,服务列表更新更及时
  • Nacos集群默认采用AP方式,当集群中存在非临时实例时,采用CP模式;Eureka采用AP方式

Nacos配置管理

统一配置

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第27张图片

在Nacos中添加配置信息:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第28张图片

在弹出表单中填写配置信息:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第29张图片

配置获取的步骤如下:

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第30张图片

引入Nacos的配置管理客户端依赖:


<dependency>
    <groupId>com.alibaba.cloudgroupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-configartifactId>
dependency>

在userservice中的resource目录添加一个bootstrap.yml文件,这个文件是引导文件,优先级高于application.yml:

spring:
  application:
    name: userservice   #微服务名称
  profiles:
    active: dev #开发环境
  cloud:
    nacos:
      server-addr: localhost:8848 #配置nacos端口
      discovery:
        cluster-name: HZ  # 配置集群名称,也就是机房位置,例如:HZ,杭州
      config:
        file-extension: yaml  #后缀名

我们在user-service中将pattern.dateformat这个属性注入到UserController中做测试:

// 注入nacos中的配置属性
@Value("${pattern.dateformat}")
private String dateformat;
// 编写controller,通过日期格式化器来格式化现在时间并返回
@GetMapping("/now")
public String now(){
    return LocalDateTime.now().format(
        DateTimeFormatter.ofPattern(dateformat, Locale.CHINA)
    );
}

在地址栏中输入:http://localhost:8081/user/now ,得到结果

2022-08-01 22:27:16

总结来说:将配置交给Nacos管理的步骤:

  1. 在Nacos中添加配置文件
  2. 在微服务中引入nacos的config依赖
  3. 在微服务中添加bootstrap.yml,配置nacos地址、当前环境、服务名称、文件后缀名。这些决定了程序启动时去nacos读取哪个文件

热更新配置

Nacos中的配置文件变更后,热更新有两种办法,微服务无需重启就可以感知。

第一种:使用@RefreshScope

在@Value注入的变量所在类上添加注解@RefreshScope

第二种:使用@ConfigurationProperties注解

填写配置文件

@Component
@Data
@ConfigurationProperties(prefix = "pattern")
public class PatternProperties {
    private String dateformat;
}

在controller层中修改dataformat

@Autowired
private PatternProperties patternProperties;

// 注入nacos中的配置属性
//    @Value("${pattern.dateformat}")
//    private String dateformat;
// 编写controller,通过日期格式化器来格式化现在时间并返回
@GetMapping("/now")
public String now(){
    return LocalDateTime.now().format(
        DateTimeFormatter.ofPattern(patternProperties.getDateformat(), Locale.CHINA)
    );
}

注意:

  • 不是所有的配置都适合放到配置中心,维护起来比较麻烦
  • 建议将一些关键参数,需要运行时调整的参数放到nacos配置中心,一般都是自定义配置

多环境配置共享

微服务启动时会从nacos读取多个配置文件:

  • [spring.application.name]-[spring.profiles.active].yaml,例如:userservice-dev.yaml
  • [spring.application.name].yaml,例如:userservice.yaml

无论profile如何变化,[spring.application.name].yaml这个文件一定会加载,因此多环境共享配置可以写入这个文

SpringCloud 微服务应用篇 | (3)Nacos 注册中心和配置管理_第31张图片

多种配置的优先级:服务名-profile.yaml >服务名称.yaml > 本地配置

不同微服务之间可以共享配置文件,通过下面的两种方式来指定:

方式一:

spring:
  application:
    name: userservice   #微服务名称
  profiles:
    active: dev #开发环境
  cloud:
    nacos:
      server-addr: localhost:8848 #配置nacos端口
      config:
        file-extension: yaml  #后缀名
        shared-configs: # 多微服务间共享的配置列表
          - dataId: common.yaml # 要共享的配置文件id

方式二:

spring:
  application:
    name: userservice   #微服务名称
  profiles:
    active: dev #开发环境
  cloud:
    nacos:
      server-addr: localhost:8848 #配置nacos端口
      config:
        file-extension: yaml  #后缀名
        extends-configs: # 多微服务间共享的配置列表
          - dataId: extend.yaml # 要共享的配置文件id

优先级:环境配置 >服务名.yaml > extension-config > extension-configs > shared-configs > 本地配置

共享搭建Nacos集群

集群搭建步骤:

①搭建MySQL集群并初始化数据库表

官方推荐的最佳实践是使用带有主从的高可用数据库集群,首先新建一个数据库,命名为nacos,而后导入下面的SQL:

CREATE TABLE `config_info` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  `data_id` varchar(255) NOT NULL COMMENT 'data_id',
  `group_id` varchar(255) DEFAULT NULL,
  `content` longtext NOT NULL COMMENT 'content',
  `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
  `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
  `src_user` text COMMENT 'source user',
  `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',
  `app_name` varchar(128) DEFAULT NULL,
  `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',
  `c_desc` varchar(256) DEFAULT NULL,
  `c_use` varchar(64) DEFAULT NULL,
  `effect` varchar(64) DEFAULT NULL,
  `type` varchar(64) DEFAULT NULL,
  `c_schema` text,
  PRIMARY KEY (`id`),
  UNIQUE KEY `uk_configinfo_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info';

/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = config_info_aggr   */
/******************************************/
CREATE TABLE `config_info_aggr` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  `data_id` varchar(255) NOT NULL COMMENT 'data_id',
  `group_id` varchar(255) NOT NULL COMMENT 'group_id',
  `datum_id` varchar(255) NOT NULL COMMENT 'datum_id',
  `content` longtext NOT NULL COMMENT '内容',
  `gmt_modified` datetime NOT NULL COMMENT '修改时间',
  `app_name` varchar(128) DEFAULT NULL,
  `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',
  PRIMARY KEY (`id`),
  UNIQUE KEY `uk_configinfoaggr_datagrouptenantdatum` (`data_id`,`group_id`,`tenant_id`,`datum_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='增加租户字段';


/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = config_info_beta   */
/******************************************/
CREATE TABLE `config_info_beta` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  `data_id` varchar(255) NOT NULL COMMENT 'data_id',
  `group_id` varchar(128) NOT NULL COMMENT 'group_id',
  `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
  `content` longtext NOT NULL COMMENT 'content',
  `beta_ips` varchar(1024) DEFAULT NULL COMMENT 'betaIps',
  `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
  `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
  `src_user` text COMMENT 'source user',
  `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',
  `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',
  PRIMARY KEY (`id`),
  UNIQUE KEY `uk_configinfobeta_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info_beta';

/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = config_info_tag   */
/******************************************/
CREATE TABLE `config_info_tag` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  `data_id` varchar(255) NOT NULL COMMENT 'data_id',
  `group_id` varchar(128) NOT NULL COMMENT 'group_id',
  `tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id',
  `tag_id` varchar(128) NOT NULL COMMENT 'tag_id',
  `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
  `content` longtext NOT NULL COMMENT 'content',
  `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
  `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
  `src_user` text COMMENT 'source user',
  `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',
  PRIMARY KEY (`id`),
  UNIQUE KEY `uk_configinfotag_datagrouptenanttag` (`data_id`,`group_id`,`tenant_id`,`tag_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info_tag';

/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = config_tags_relation   */
/******************************************/
CREATE TABLE `config_tags_relation` (
  `id` bigint(20) NOT NULL COMMENT 'id',
  `tag_name` varchar(128) NOT NULL COMMENT 'tag_name',
  `tag_type` varchar(64) DEFAULT NULL COMMENT 'tag_type',
  `data_id` varchar(255) NOT NULL COMMENT 'data_id',
  `group_id` varchar(128) NOT NULL COMMENT 'group_id',
  `tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id',
  `nid` bigint(20) NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`nid`),
  UNIQUE KEY `uk_configtagrelation_configidtag` (`id`,`tag_name`,`tag_type`),
  KEY `idx_tenant_id` (`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_tag_relation';

/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = group_capacity   */
/******************************************/
CREATE TABLE `group_capacity` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  `group_id` varchar(128) NOT NULL DEFAULT '' COMMENT 'Group ID,空字符表示整个集群',
  `quota` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表示使用默认值',
  `usage` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '使用量',
  `max_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值',
  `max_aggr_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '聚合子配置最大个数,,0表示使用默认值',
  `max_aggr_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值',
  `max_history_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最大变更历史数量',
  `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
  PRIMARY KEY (`id`),
  UNIQUE KEY `uk_group_id` (`group_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='集群、各Group容量信息表';

/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = his_config_info   */
/******************************************/
CREATE TABLE `his_config_info` (
  `id` bigint(64) unsigned NOT NULL,
  `nid` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
  `data_id` varchar(255) NOT NULL,
  `group_id` varchar(128) NOT NULL,
  `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
  `content` longtext NOT NULL,
  `md5` varchar(32) DEFAULT NULL,
  `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `src_user` text,
  `src_ip` varchar(50) DEFAULT NULL,
  `op_type` char(10) DEFAULT NULL,
  `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',
  PRIMARY KEY (`nid`),
  KEY `idx_gmt_create` (`gmt_create`),
  KEY `idx_gmt_modified` (`gmt_modified`),
  KEY `idx_did` (`data_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='多租户改造';


/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = tenant_capacity   */
/******************************************/
CREATE TABLE `tenant_capacity` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  `tenant_id` varchar(128) NOT NULL DEFAULT '' COMMENT 'Tenant ID',
  `quota` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表示使用默认值',
  `usage` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '使用量',
  `max_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值',
  `max_aggr_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '聚合子配置最大个数',
  `max_aggr_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值',
  `max_history_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最大变更历史数量',
  `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
  PRIMARY KEY (`id`),
  UNIQUE KEY `uk_tenant_id` (`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='租户容量信息表';


CREATE TABLE `tenant_info` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  `kp` varchar(128) NOT NULL COMMENT 'kp',
  `tenant_id` varchar(128) default '' COMMENT 'tenant_id',
  `tenant_name` varchar(128) default '' COMMENT 'tenant_name',
  `tenant_desc` varchar(256) DEFAULT NULL COMMENT 'tenant_desc',
  `create_source` varchar(32) DEFAULT NULL COMMENT 'create_source',
  `gmt_create` bigint(20) NOT NULL COMMENT '创建时间',
  `gmt_modified` bigint(20) NOT NULL COMMENT '修改时间',
  PRIMARY KEY (`id`),
  UNIQUE KEY `uk_tenant_info_kptenantid` (`kp`,`tenant_id`),
  KEY `idx_tenant_id` (`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='tenant_info';

CREATE TABLE `users` (
	`username` varchar(50) NOT NULL PRIMARY KEY,
	`password` varchar(500) NOT NULL,
	`enabled` boolean NOT NULL
);

CREATE TABLE `roles` (
	`username` varchar(50) NOT NULL,
	`role` varchar(50) NOT NULL,
	UNIQUE INDEX `idx_user_role` (`username` ASC, `role` ASC) USING BTREE
);

CREATE TABLE `permissions` (
    `role` varchar(50) NOT NULL,
    `resource` varchar(255) NOT NULL,
    `action` varchar(8) NOT NULL,
    UNIQUE INDEX `uk_role_permission` (`role`,`resource`,`action`) USING BTREE
);

INSERT INTO users (username, password, enabled) VALUES ('nacos', '$2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu', TRUE);

INSERT INTO roles (username, role) VALUES ('nacos', 'ROLE_ADMIN');

②下载解压nacos

下载不赘述

解压:进入nacos的conf目录,修改配置文件cluster.conf.example,重命名为cluster.conf,然后添加内容:

127.0.0.1:8845
127.0.0.1.8846
127.0.0.1.8847

③修改集群配置(节点信息)、数据库配置

然后修改application.properties文件,添加数据库配置

# 使用mysql集群
spring.datasource.platform=mysql
# 使用mysql的数量
db.num=1

db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user.0=root
db.password.0=root

④分别启动多个nacos节点

将nacos文件夹复制三份,分别命名为:nacos1、nacos2、nacos3、

然后分别修改三个文件夹中的application.properties,

nacos1:

server.port=8845

nacos2:

server.port=8846

nacos3:

server.port=8847

然后分别启动三个nacos节点:

startup.cmd

⑤nginx反向代理

解压到任意非中文目录下,修改conf/nginx.conf文件,配置如下:

upstream nacos-cluster {
    server 127.0.0.1:8845;
	server 127.0.0.1:8846;
	server 127.0.0.1:8847;
}

server {
    listen       80;
    server_name  localhost;

    location /nacos {
        proxy_pass http://nacos-cluster;
    }
}

而后在浏览器访问:http://localhost/nacos即可。代码中application.yml文件配置如下:

spring:
  cloud:
    nacos:
      server-addr: localhost:80 # Nacos地址

实际部署时,需要给做反向代理的nginx服务器设置一个域名,这样后续如果有服务器迁移nacos的客户端也无需更改配置.

Nacos的各个节点应该部署到多个不同服务器,做好容灾和隔离

你可能感兴趣的:(——,SpringCloud,——,spring,cloud,java,spring,nacos)