当前位置:   article > 正文

微服务demo(二)nacos服务注册与集中配置

微服务demo(二)nacos服务注册与集中配置

环境:nacos1.3.0

一、服务注册

1、pom:

移步spring官网https://spring.io,查看集成Nacos所需依赖

找到对应版本点击进入查看集成说明

然后再里面找到集成配置样例,这里只截一张,其他集成内容继续向下找

我的:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5. <modelVersion>4.0.0</modelVersion>
  6. <groupId>com.demo.nacos</groupId>
  7. <artifactId>nacos-service</artifactId>
  8. <version>1.0-SNAPSHOT</version>
  9. <!-- springBoot -->
  10. <parent>
  11. <groupId>org.springframework.boot</groupId>
  12. <artifactId>spring-boot-starter-parent</artifactId>
  13. <version>2.0.4.RELEASE</version>
  14. </parent>
  15. <properties>
  16. <java.version>1.8</java.version>
  17. <maven.compiler.plugin.version>3.7.0</maven.compiler.plugin.version>
  18. <maven.source.plugin>3.0.1</maven.source.plugin>
  19. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  20. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  21. </properties>
  22. <dependencies>
  23. <dependency>
  24. <groupId>org.springframework.boot</groupId>
  25. <artifactId>spring-boot-starter</artifactId>
  26. </dependency>
  27. <!--nocas必须在web环境下-->
  28. <dependency>
  29. <groupId>org.springframework.boot</groupId>
  30. <artifactId>spring-boot-starter-web</artifactId>
  31. </dependency>
  32. <!-- SpringCloud -->
  33. <dependency>
  34. <groupId>org.springframework.cloud</groupId>
  35. <artifactId>spring-cloud-dependencies</artifactId>
  36. <version>Finchley.RELEASE</version>
  37. </dependency>
  38. <!-- SpringCloud Alibaba -->
  39. <dependency>
  40. <groupId>com.alibaba.cloud</groupId>
  41. <artifactId>spring-cloud-alibaba-dependencies</artifactId>
  42. <version>2.1.0.RELEASE</version>
  43. </dependency>
  44. <!--服务注册-->
  45. <dependency>
  46. <groupId>org.springframework.cloud</groupId>
  47. <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
  48. <version>0.2.2.RELEASE</version>
  49. </dependency>
  50. <!-- nacos 注册中心客户端 -->
  51. <!-- <dependency>-->
  52. <!-- <groupId>com.alibaba.cloud</groupId>-->
  53. <!-- <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>-->
  54. <!-- <version>2.1.0.RELEASE</version>-->
  55. <!-- </dependency>-->
  56. </dependencies>
  57. <build>
  58. <finalName>my-service</finalName>
  59. <plugins>
  60. <plugin>
  61. <groupId>org.springframework.boot</groupId>
  62. <artifactId>spring-boot-maven-plugin</artifactId>
  63. </plugin>
  64. </plugins>
  65. </build>
  66. </project>

我这里注册到nacos使用 com.alibaba.cloud会报错读取不到bootstrap,使用org.springframework.cloud就可以,暂未解决。

2、配置文件
(1)bootstrap:

bootstrap是springcloud衍生来的,推荐使用bootstrap。一般来说,是把application内容放到nacos配置中心配置,本地只用bootstrap连接到nacos而不用application配置。bootstrap优先于application执行。如果把nacos的配置放到application中去连接,那么远程nacos上的配置可能就读取不到了。

  1. spring:
  2. application:
  3. name: my-service
  4. cloud:
  5. compatibility-verifier:
  6. enabled: false
  7. nacos:
  8. #服务注册
  9. discovery:
  10. server-addr: xx.xx.xxx:8848
  11. server:
  12. port: 8899
  13. servlet:
  14. context-path: /myProvider
(2)application:

有认为,nacos配置中心配置内容必须写在bootstrap.yml文件中,如果写入application-*.yml或者application.yml中均不生效。其实使用application.properties也可以完成配置。我的:

  1. spring.cloud.nacos.discovery.server-addr=xx.xx.xxx:8848
  2. server.port=8877
  3. server.servlet.context-path=/myProvider
  4. spring.application.name=my-service
3、启动类
  1. import com.alibaba.nacos.api.config.annotation.NacosConfigurationProperties;
  2. import org.springframework.boot.SpringApplication;
  3. import org.springframework.boot.autoconfigure.SpringBootApplication;
  4. import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
  5. @SpringBootApplication
  6. @EnableDiscoveryClient
  7. public class NacosServierStart {
  8. public static void main(String args[]){
  9. SpringApplication.run(NacosServierStart.class,args);
  10. }
  11. }
5、测试

启动

查看nacos也成功的注册了:

二、集中配置

获取集中配置第一步需要注册到nacos,所以建立在上面的基础上:

1、参数说明
1.1、dataId:

相当于nacos集中配置的文件名。在 Nacos Spring Cloud 中,DataId 的完整格式如下:

${prefix}-${spring.profiles.active}.${file-extension} 

(1)prefix: 默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。
(2)spring.profiles.active: 即为当前环境对应的 profile, 注意:当 spring.profiles.active 为空时,对应的连接符 - 也将不存在, dataId 的拼接格式变成 p r e f i x . {prefix}.prefix.{file-extension}。如:

  1. my-service-dev.properties
  2. my-service-prod.properties

(3)file-exetension: 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。如my-service.properties。

1.2、Group:

组相当于一个特定场景,组默认是DEFAULT_GROUP,如果使用默认的则不需要在项目中指定。

1.3、namespace(tenat):

相当于 第一层 互相隔离 每个命名空间下面有自己的组。命名空间默认是 public 可以添加 dev prod test 。

1.4、配置格式:

没用,只是增加一点颜色,方便编辑

2、集成方法与demo
(1)pom:

加上macos-config依赖

  1. <!--集中配置-->
  2. <dependency>
  3. <groupId>com.alibaba.cloud</groupId>
  4. <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
  5. <version>2.1.0.RELEASE</version>
  6. </dependency>

如我完整的pom:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5. <modelVersion>4.0.0</modelVersion>
  6. <groupId>com.demo.nacos</groupId>
  7. <artifactId>nacos-service</artifactId>
  8. <version>1.0-SNAPSHOT</version>
  9. <!-- springBoot -->
  10. <parent>
  11. <groupId>org.springframework.boot</groupId>
  12. <artifactId>spring-boot-starter-parent</artifactId>
  13. <version>2.0.4.RELEASE</version>
  14. </parent>
  15. <properties>
  16. <java.version>1.8</java.version>
  17. <maven.compiler.plugin.version>3.7.0</maven.compiler.plugin.version>
  18. <maven.source.plugin>3.0.1</maven.source.plugin>
  19. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  20. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  21. </properties>
  22. <dependencies>
  23. <dependency>
  24. <groupId>org.springframework.boot</groupId>
  25. <artifactId>spring-boot-starter</artifactId>
  26. </dependency>
  27. <!--nocas必须在web环境下-->
  28. <dependency>
  29. <groupId>org.springframework.boot</groupId>
  30. <artifactId>spring-boot-starter-web</artifactId>
  31. </dependency>
  32. <!-- SpringCloud -->
  33. <dependency>
  34. <groupId>org.springframework.cloud</groupId>
  35. <artifactId>spring-cloud-dependencies</artifactId>
  36. <version>Finchley.RELEASE</version>
  37. </dependency>
  38. <!-- SpringCloud Alibaba -->
  39. <dependency>
  40. <groupId>com.alibaba.cloud</groupId>
  41. <artifactId>spring-cloud-alibaba-dependencies</artifactId>
  42. <version>2.1.0.RELEASE</version>
  43. </dependency>
  44. <!--服务注册-->
  45. <dependency>
  46. <groupId>org.springframework.cloud</groupId>
  47. <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
  48. <version>0.2.2.RELEASE</version>
  49. </dependency>
  50. <!-- nacos 注册中心客户端 -->
  51. <!-- <dependency>-->
  52. <!-- <groupId>com.alibaba.cloud</groupId>-->
  53. <!-- <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>-->
  54. <!-- <version>2.1.0.RELEASE</version>-->
  55. <!-- </dependency>-->
  56. <!--集中配置-->
  57. <dependency>
  58. <groupId>com.alibaba.cloud</groupId>
  59. <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
  60. <version>2.1.0.RELEASE</version>
  61. </dependency>
  62. </dependencies>
  63. <build>
  64. <finalName>my-service</finalName>
  65. <plugins>
  66. <plugin>
  67. <groupId>org.springframework.boot</groupId>
  68. <artifactId>spring-boot-maven-plugin</artifactId>
  69. </plugin>
  70. </plugins>
  71. </build>
  72. </project>
(2)配置文件

bootstrap加上config配置连接,

  1. spring:
  2. application:
  3. name: my-service
  4. cloud:
  5. compatibility-verifier:
  6. enabled: false
  7. nacos:
  8. #服务注册
  9. discovery:
  10. server-addr: xx.xx.xxx:8848
  11. #配置中心
  12. config:
  13. server-addr: xx.xx.xxx:8848

如我完整的: 

  1. spring:
  2. application:
  3. name: my-service
  4. cloud:
  5. compatibility-verifier:
  6. enabled: false
  7. nacos:
  8. #服务注册
  9. discovery:
  10. server-addr: xx.xx.xxx:8848
  11. #配置中心
  12. config:
  13. server-addr: xx.xx.xxx:8848
  14. server:
  15. port: 8877
  16. servlet:
  17. context-path: /myProvider
(3)启动类 

    无需改动

(4)业务代码:
  1. import com.alibaba.nacos.api.config.annotation.NacosValue;
  2. import org.springframework.beans.factory.annotation.Value;
  3. import org.springframework.cloud.context.config.annotation.RefreshScope;
  4. import org.springframework.web.bind.annotation.GetMapping;
  5. import org.springframework.web.bind.annotation.RequestBody;
  6. import org.springframework.web.bind.annotation.RequestMapping;
  7. import org.springframework.web.bind.annotation.RestController;
  8. import javax.servlet.http.HttpServletRequest;
  9. @RestController
  10. @RequestMapping("/test")
  11. //刷新配置
  12. @RefreshScope
  13. public class TestController {
  14. @Value("${user.text}")
  15. private String userText;
  16. @GetMapping("/getUserName")
  17. public String getTemp(HttpServletRequest request) throws InterruptedException {
  18. return userText;
  19. }
  20. }
3、测试

启动:

3.1、简单获取集中配置

(1)访问 http://localhost:8877/myProvider/test/getUserName

(2)修改nacos上的配置

再次刷新浏览器可以看到获取到最新的配置了

3.2、指定组

同步修改bootstrap配置文件并重启代码:

再次刷新浏览器

 

3.3、指定环境

集中配置划分为dev、test、prod。新增几个配置

如dev的内容为

同步修改bootstrap配置文件并重启代码:

再次刷新浏览器:

3.4、本地配置覆盖远程

如我本地新增

此时获取的仍然是远程的

如果希望本地配置覆盖远程,需要在bootstrap配置文件中开启配置:

4、远程配置管理

一般只将固定的配置放在本地boostrap,其他配置都放到远程nacos集中配置上。如现在只将nacos的连接和获取集中配置放在本地,其他如端口号、数据库连接等信息放在集中配置上。

(1)pom添加依赖:

  1. <!--mybatis-->
  2. <dependency>
  3. <groupId>org.mybatis.spring.boot</groupId>
  4. <artifactId>mybatis-spring-boot-starter</artifactId>
  5. <version>1.3.2</version>
  6. </dependency>
  7. <dependency>
  8. <groupId>mysql</groupId>
  9. <artifactId>mysql-connector-java</artifactId>
  10. <version>8.0.13</version>
  11. </dependency>

(2)启动类

  1. @SpringBootApplication
  2. @EnableDiscoveryClient
  3. @MapperScan("com.demo.nacos.provider.mapper")
  4. public class ProviderApplication {
  5. public static void main(String[] args) {
  6. SpringApplication.run(ProviderApplication.class, args);
  7. }
  8. }

(3)业务代码:

  1. @Autowired
  2. private UserDao userDao;
  3. @RequestMapping("/getAllUsers")
  4. public List<UserDTO> getAllUsers(){
  5. return userDao.getAllUsers();
  6. }
  1. <select id="getAllUsers" resultType="com.demo.nacos.common.dto.UserDTO">
  2. SELECT
  3. `NAME` userName,
  4. ACCOUNT userAccount
  5. FROM
  6. t_user_new
  7. </select>

(4)nacos集中配置:

  1. server.port=1111
  2. #server.servlet.context-path=/myProvider
  3. user.text = wtyy分组下 prod生产环境 的值
  4. #mybatis
  5. spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
  6. #spring.datasource.url=jdbc:mysql://localhost:3306/demo?useUnicode=true&characterEncoding=utf-8&useSSL=false
  7. spring.datasource.username=root
  8. #spring.datasource.password=wtyy
  9. spring.datasource.url=jdbc:mysql://xxx.xx.xxx:3306/demo?useUnicode=true&characterEncoding=utf-8&useSSL=false&allowMultiQueries=true
  10. spring.datasource.password=xxxxxx
  11. #mybatis
  12. mybatis.mapper-locations=classpath*:mapper/*Mapper.xml

(5)本地配置

  1. spring:
  2. application:
  3. name: my-service
  4. cloud:
  5. compatibility-verifier:
  6. enabled: false
  7. nacos:
  8. #服务注册
  9. discovery:
  10. server-addr: xxx.xx.xxx:8848
  11. #配置中心
  12. config:
  13. server-addr: xxx.xx.xxx:8848
  14. group: wtyy
  15. profiles:
  16. active: prod
  17. server:
  18. servlet:
  19. context-path: /myProvider

(6)测试:

启动后访问接口

这时把bootstrap改为dev环境,因为集中配置dev文件没有配置数据库信息,所以启动报错:

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/336585
推荐阅读
相关标签
  

闽ICP备14008679号