【SpringCloud Alibaba】Nacos注册中心、配置中心、mysql持久化、集群配置

🔰 学习视频 🔰

尚硅谷SpringCloud框架开发教程(SpringCloudAlibaba微服务分布式架构丨Spring Cloud)

集数:96—110


🔰 项目地址 🔰

https://gitee.com/zqcliudaliuda/cloud2021


一、简介

官网:

🔶 Nacos名字由来

Naming和Configuration的前两个字母,s为service。

🔶 是什么

一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
Nacos: Dynamic Naming and Configuration Service,就是注册中心+配置中心的组合。

Nacos = Eureka + Config + Bus

🔶 能干吗

替代Eureka做服务注册中心,替代Config做服务配置中心。

二、Nacos安装运行

2.1 下载

https://github.com/alibaba/nacos/releases
在这里插入图片描述
跟着视频的版本学。

nacos-server-1.1.4.tar.gz 也可以下载,后面集群配置将要用。

2.2 解压运行

解压文件,并打开\nacos-server-1.1.4\nacos\bin目录,双击startup.cmd运行服务。

启动成功后访问:http://localhost:8848/nacos

账号密码均为:nacos

在这里插入图片描述

三、注册中心演示

官方文档

3.1 创建生产者工程

🔶 新建maven项目:cloudalibaba-provider-payment9001

🔶 POM

父POM

<!--统一管理jar包版本-->
<properties>
	...
	<spring.cloud.alibaba.version>2.1.0.RELEASE</spring.cloud.alibaba.version>
	...
</properties>

<!--Spring cloud alibaba 2.1.0.RELEASE-->
<!--子模块继承后,提供作用:锁定版本+子module不用groupId和version-->
<dependencyManagement>
  <dependencies>
  	...
	<dependency>
	  <groupId>com.alibaba.cloud</groupId>
	  <artifactId>spring-cloud-alibaba-dependencies</artifactId>
	  <version>${spring.cloud.alibaba.version}</version>
	  <type>pom</type>
	  <scope>import</scope>
	</dependency>
	...
   </dependencies>
</dependencyManagement>

子POM

<dependencies>
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <scope>runtime</scope>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

🔶 application.yml

server:
  port: 9001
spring:
  application:
    name: nacos-payment-provider
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
management:
  endpoints:
    web:
      exposure:
        include: "*"

🔶 主启动类

@SpringBootApplication
@EnableDiscoveryClient
public class PaymentMain9001 {
    public static void main(String[] args) {
        SpringApplication.run(PaymentMain9001.class, args);
    }
}

🔶 业务类

@RestController
public class PaymentController {

    @Value("${server.port}")
    private String serverPort;

    @GetMapping(value = "/payment/nacos/{id}")
    public String getPayment(@PathVariable("id") Integer id) {
        return "nacos registry, serverPort" + serverPort + "\t id" + id;
    }
}

🔶 测试

首先启动nacos server,确保能够打开控制台。再启动cloudalibaba-provider-payment9001微服务。

可以在服务列表中查看到刚刚启动的微服务。
在这里插入图片描述
访问:http://localhost:9001/payment/nacos/1

nacos registry, serverPort9001 id1

🔶 参照9001新建9002

搭建完成后启动,可在nacos控制中心看到2个实例。
在这里插入图片描述

3.2 创建消费者工程

🔶 新建maven项目:cloudalibaba-consumer-nacos-order83

🔶 POM

<dependencies>
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <scope>runtime</scope>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

🔶 application.yml

server:
  port: 83
spring:
  application:
    name: nacos-order-consumer
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

# 消费者将去访问微服务名称(注册成功进nacos的微服务提供者)
server-url:
  nacos-user-service: http://nacos-payment-provider

🔶 主启动类

@SpringBootApplication
@EnableDiscoveryClient
public class OrderNacosMain83 {
    public static void main(String[] args) {
        SpringApplication.run(OrderNacosMain83.class, args);
    }
}

🔶 配置类

@Configuration
public class ApplicationContextConfig {
    @Bean
    @LoadBalanced
    public RestTemplate getRestTemplate() {
        return new RestTemplate();
    }
}

🔶 业务类

@RestController
@Slf4j
public class OrderNacosController {
    @Resource
    private RestTemplate restTemplate;

    @Value("${server-url.nacos-user-service}")
    private String serverURL;

    @GetMapping("/consumer/payment/nacos/{id}")
    public String paymentInfo(@PathVariable("id") Long id) {
        return restTemplate.getForObject(serverURL + "/payment/nacos/" + id, String.class);
    }
}

🔶 测试

nacos控制台,可以看到两个微服务,分别为2和1。
在这里插入图片描述
访问:http://localhost:83/consumer/payment/nacos/1

获得结果(轮询负载):

nacos registry, serverPort9002 id1
或
nacos registry, serverPort9001 id1

四、配置中心演示

4.1 基础配置

4.1.1 新建项目

🔶 新建maven项目cloudalibaba-config-nacos-client3377

🔶 POM

<dependencies>
	<dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
    </dependency>
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <scope>runtime</scope>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

🔶 YML

Nacos同springcloud-config一样,在项目初始化时,要保证先从配置中心进行配置拉取,拉取配置之后,才能保证项目的正常启动。springboot中配置文件的加载是存在优先级顺序的, bootstrap优先级高于application

bootstrap.yml

server:
  port: 3377

spring:
  application:
    name: nacos-config-client
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
      config:
        server-addr: localhost:8848
        file-extension: yaml # 指定yaml格式的配置


# 格式:${prefix}-${spring.profiles.active}.${file-extension}
# 名称:nacos-config-client-dev.yaml

application.yml

spring:
  profiles:
    active: dev # 表示开发环境

🔶 主启动类

@EnableDiscoveryClient
@SpringBootApplication
public class NacosConfigClientMain3377 {
    public static void main(String[] args) {
        SpringApplication.run(NacosConfigClientMain3377.class, args);
    }
}

🔶 业务类

@RestController
@RefreshScope  // 支持Nacos的动态刷新功能
public class ConfigClientController {
    @Value("${config.info}")
    private String configInfo;
    
    @GetMapping("/config/info")
    public String getConfigInfo() {
        return configInfo;
    }
}

4.1.2 配置

【文档】在Nacos Spring Cloud中,dataId的完整格式如下:

${prefix}-${spring.profiles.active}.${file-extension}
  • prefix 默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。
  • spring.profiles.active 即为当前环境对应的 profile,详情可以参考 Spring Boot文档。 注意:当 spring.profiles.active 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成 ${prefix}.${file-extension}
  • file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。目前只支持 properties 和 yaml 类型。

所以说上面bootstrap.yml对应的配置名如下:

# 格式:${prefix}-${spring.profiles.active}.${file-extension}
# 名称:nacos-config-client-dev.yaml

🔶 添加配置
在这里插入图片描述
🔶 配置
在这里插入图片描述

4.1.3 测试

启动cloudalibaba-config-nacos-client3377

访问:http://localhost:3377/config/info

config info for dev, from nacos config center. Verson 1

修改配置,把配置修改成Verson 2

访问:http://localhost:3377/config/info

config info for dev, from nacos config center. Verson 2

可以实现动态刷新。

4.2 分类配置

4.2.1 实际问题

🔶 问题1

实际开发中,通常一个系统会准备:dev开发环境test测试环境prod生产环境。如何保证指定环境启动时服务能正确读取到Nacos上相应环境的配置文件呢? I

🔶 问题2

一个大型分布式微服务系统会有很多微服务子项目,每个微服务项目又都会有相应的开发环境、测试环境、预发环境、正式环境…那怎么对这些微服务配置进行管理呢?

4.2.2 设计思想

类似Java里面的package名和类名,最外层的namespace是可以用于区分部署环境的,GroupDatalD逻辑上区分两个目标对象。

在这里插入图片描述
默认情况:

Namespace=public
Group=DEFAULT_GROUP
Cluster=DEFAULT
  • Nacos默认的命名空间是public,Namespace主要用来实现隔离。比坊说我们现在有三个环境:开发、测试、产环境,我们就可以创建三个Namespace,不同的Namespace之间是隔离的。

  • Group默认是DEFAULT_ GROUP,Group可以把不同的微服务划分到同一个分组里面去

  • Service就是微服务;一个Service可以包含多 个Cluster (集群),Nacos默认Cluster是DEFAULT,Cluster是对指定微服务的一个虚拟划分。比方说为了容灾,将Service微服务分别部署在了杭州机房和广州机房,这时就可以给杭州机房的Service微服务起一个集群名称 (HZ),给广州机房的Service微服务起一个集群名称(GZ), 还可以尽量让同一个机房的微服务互相调用,以提升性能。

  • Instance就是微服务的实例。

4.2.3 DataID

指定application.yml下的spring.profile.active和配置文件的DatalD来使不同环境下读取不同的配置。

在配置一个nacos-config-client-test.yaml
在这里插入图片描述
现在有两个配置:
在这里插入图片描述
修改application.yml

spring:
  profiles:
    # active: dev # 表示开发环境
    active: test # 表示测试环境

此时读取的文件将从nacos-config-client-dev.yaml变为nacos-config-client-test.yaml

4.2.4 Group

默认:Group=DEFAULT_GROUP

新建两个Data Id相同,但Group不同的配置。
在这里插入图片描述
bootstrap.ymlapplication.yml的配置如下:
在这里插入图片描述

4.2.5 Namespcae

新建两个命名空间:
在这里插入图片描述
切换命名空间,可以在不同的命名空间中创建配置
请添加图片描述

可以根据命名空间的id选择命名空间,然后在命名空间下找到对应的GroupData Id
在这里插入图片描述

五、Nacos集群和持久化配置

Nacos支持3种部署模式

  • 单机模式-用于测试和单机试用。
  • 集群模式-用于生产环境,确保高可用。
  • 多集群模式-用于多数据中心场景。

5.1 说明

https://nacos.io/zh-cn/docs/cluster-mode-quick-start.html

集群部署架构图
在这里插入图片描述
nginx虚拟映射ip

默认Nacos使用嵌入式数据库实现数据的存储。所以,如果启动多个默认配置下的Nacos节点,数据存储是存在一致性问题的。为了解决这个问题,Nacos采用 了集中式存储的方式来支持集群化部署,目前只支持MySQL的存储。

5.2 单机模式支持mysql

Nacos默认自带的嵌入式数据库derby,derby到mysql的切换配置步骤如下:

🔶 步骤1:创建数据库

CREATE DATABASE nacos_config;
USE nacos_config;

🔶 步骤2:执行sql脚本

nacos-server-1.1.4\nacos\conf目录下找到sql脚本,并执行,此时数据库中将有这些表格。
在这里插入图片描述
🔶 步骤3:修改conf/application.properties文件

增加支持mysql数据源配置(目前只支持mysql),添加mysql数据源的url、用户名和密码。

spring.datasource.platform=mysql

db.num=1
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123456

🔶 步骤4:测试

此时启动nacos,进入控制台,发现里面的记录是空的,因为以前的记录在derby内。

随便新增一条配置后,查看数据库表config_info

在这里插入图片描述

5.3 Linux下集群配置

🔶 需求

CentOS:之前在虚拟机内安装好了CentOS7,后面直接运行即可。

1个Nginx
3个nacos注册中心
1个mysql

5.3.1 Nacos安装

🔶 下载nacos

https://github.com/alibaba/nacos/releases
在这里插入图片描述
下载到linux系统的/opt目录下。

🔶 Nacos解压安装

解压

tar -zxvf nacos-server-1.1.4.tar.gz

将解压后的nacos文件夹复制到mynacos目录下

cp -r nacos /mynacos/

进入nacos的bin目录

cd /mynacos/bin

5.3.2 mysql配置

🔶 CentOS7安装MySQL

参考的安装教程:CentOS7安装MySQL(完整版)

Zqc123456!

🔶 启动mysql,创建数据库

mysql> create database nacos_config;
mysql> show database;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| nacos_config       |
| performance_schema |
| sys                |
+--------------------+

🔶 创建数据库表格

使用/mynacos/conf/nacos-mysql.sql创建数据库表格

use nacos_config;
source /mynacos/conf/nacos-mysql.sql
mysql> show tables;
+------------------------+
| Tables_in_nacos_config |
+------------------------+
| config_info            |
| config_info_aggr       |
| config_info_beta       |
| config_info_tag        |
| config_tags_relation   |
| group_capacity         |
| his_config_info        |
| roles                  |
| tenant_capacity        |
| tenant_info            |
| users                  |
+------------------------+

5.3.3 application配置

进入到/mynacos/conf目录下。

备份application.properties

cp application.properties application.properties.bk

修改application.properties

vim application.properties

增添一下字段,配置数据库(上面介绍过的单机模式支持mysql

# mysql
spring.datasource.platform=mysql

db.num=1
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=Zqc123456!

5.3.4 cluster配置

梳理出3台nacos机器的不同端口号

进入到/mynacos/conf目录下,复制出cluster.conf

cp cluster.conf.example cluster.conf

内容为:

192.168.150.101:3333
192.168.150.101:4444
192.168.150.101:5555

注意:ip地址要填写本机的ip地址(正常的话应该是3台不同的服务器,这里就以一台为例)

5.3.5 编写启动脚本

编辑nacos的启动脚本startup.sh,使它能够接受不同的启动端口。

进入到/mynacos/bin目录下,备份startup.sh

cp startup.sh startup.sh.bk

添加一个-p选项,可以选择启动的端口。(:set nu显示行数)
在这里插入图片描述
启动完成后可以打印当前启动的端口号。
在这里插入图片描述

执行方式变为:

./startup.sh -p 3333

5.3.6 nginx配置

🔶 CentOS安装nginx

CentOS安装Nginx

🔶 备份配置文件

进入nginx/conf目录下

cd /usr/local/nginx/conf

备份nginx.conf

cp nginx.conf nginx.conf.bk

🔶 修改配置文件

vim nginx.conf

修改以下内容
在这里插入图片描述
🔶 按照指定启动

cd /usr/local/nginx/sbin
./nginx -c /usr/local/nginx/conf/nginx.conf

检查是否启动成功

ps -ef |grep nginx

在这里插入图片描述

🔶 开启1111端口

开放1111端口

firewall-cmd --add-service=http --permanent
sudo firewall-cmd --add-port=1111/tcp --permanent

重启防火墙

firewall-cmd --reload

5.3.7 启动nacos

进入到/mynacos/bin目录

cd /mynacos/bin

启动3个服务

./startup.sh -p 3333
./startup.sh -p 4444
./startup.sh -p 5555

java报错的话,可以试试这个教程。
https://blog.csdn.net/gexiaoyizhimei/article/details/95374890

检查是否启动成功

[root@localhost1 bin]# ps -ef|grep nacos|grep -v grep | wc -l
3

结果为3,启动成。

5.3.7 访问nacos

访问:http://192.168.150.101:1111/nacos/#/login

成功~

六、微服务注册

将微服务注册进nacos集群,拿cloudalibaba-provider-payment9002为例。

修改application.yaml
在这里插入图片描述
运行cloudalibaba-provider-payment9002

可以在nacos控制台上查看到。

在这里插入图片描述
注册成功。

访问的结构如下:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

望天边星宿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值