Spring Cloud alibaba: nacos服务注册中心,配置中心
服务注册中心
1.项目父工程添加springcloudalibaba依赖
<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>
2.将想要暴露的服务对应的pom文件中添加如下依赖
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
3.工程相应yml文件配置
spring:application:name: content-api # 服务名称cloud:nacos:server-addr: 192.168.101.65:8848discovery:namespace: dev402 # 命名空间 要和nacos的相对应group: xuecheng-plus-project # 分组
配置完毕后启动content服务,nacos中观察。
配置中心
需要配置的服务中要引入nacos的config依赖
<!--nacos配置中心需要加入的依赖--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId></dependency>
Data Id 的组成(三部分)
第一部分:application.yaml中配置的应用名,即spring.application.name的值
第二部分:环境名,通过spring.profiles.active指定
第三部分:配置文件 的后缀,目前nacos支持properties、yaml等格式类型。
上面所说的三部分都是要在本地的yaml配置文件中配置的,正因为配置了这三部分服务启动的时候可以从nacos中获取到这个服务的配置的信息,即先去找content-api-dev.yaml这个配置文件。具体配置的优先级后面会说。
spring:application:name: content-servicecloud:nacos:server-addr: 192.168.101.65:8848discovery:namespace: dev402group: xuecheng-plus-projectconfig:namespace: dev402group: xuecheng-plus-projectfile-extension: yamlrefresh-enabled: true#profiles默认为devprofiles:active: dev
配置成功后可以看到控制台中打印NacosRestTemplate.java通过Post方式与nacos服务端交互读取配置信息。
下面直接把完整的配置发出来自己,看一下。我全注释一下,简单东西简单说
server:servlet:context-path: /content # 服务请求时映射url前缀port: 6304 #端口号
#微服务配置
spring:application:name: content-api # 服务名Data Id 第一部分cloud:nacos:server-addr: 192.168.101.65:8848 # nacos地址,请确保服务可以正常访问discovery: #服务注册的相关配置信息 namespace: dev402 # 在nacos页面中创建的命名空间group: xuecheng-plus-project # 服务所属分组config: #配置文件相关信息namespace: dev402 # 命名空间group: xuecheng-plus-project # 服务所属分组file-extension: yaml # 程序应该使用 YAML 格式的文件作为配置文件refresh-enabled: trueextension-configs: # 直接引入其他配置文件需要配置extension-configs- data-id: content-service-${spring.profiles.active}.yamlgroup: xuecheng-plus-projectrefresh: trueshared-configs: # 公共配置用这个shared-configs:- data-id: swagger-${spring.profiles.active}.yamlgroup: xuecheng-plus-commonrefresh: true- data-id: logging-${spring.profiles.active}.yamlgroup: xuecheng-plus-commonrefresh: true
# 直接引用content-service-dev.yaml的数据库配置 但是理论上api层面不应包含数据库相关配置,引用也不行
# datasource:
# driver-class-name: com.mysql.cj.jdbc.Driver
# url: jdbc:mysql://192.168.101.65:3306/gogs?serverTimezone=UTC&userUnicode=true&useSSL=false&
# username: root
# password: mysql#profiles默认为dev 环境名的Data Id 第二部分profiles:active: dev
配置优先级
项目启动首先加载bootstrap.yml,拿到nacos的请求地址与id获取到远程的nacos配置
其次加载本地的application.yml配置,并与nacos拉取到的配置合并
最后进行spring容器的创建、bean的加载......
配置文件的有限级:
项目应用名配置文件(data ID) > 扩展配置文件(extension-configs) > 共享配置文件(shared-configs) > 本地配置文件(其他application.yml)。
配置本地优先
需求:有时候我们在测试程序时直接在本地加一个配置进行测试。
正常在idea的服务配置换个端口就可以但是由于受优先级影响,他会优先去nacos中查找相关服务配置,也就是说我们启动服务就会报错端口被占用。
解决办法:
#配置本地优先
spring:cloud:config:override-none: true
导入配置
如果我们已经有了配置文件的zip包可以直接在nacos中进行配置的导入。