• SpringCloud Alibaba【二】nacos


    nacos初步使用

    Nacos 是阿里巴巴推出来的一个新开源项目,这是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
    简单来说,nacos可以用来管理一个springcloud项目中各个模块与组件。安装运行nacos后可以在专门的页面上看到注册进nacos的各个模块的信息。
    以上是个人理解,如有不对,可在评论区纠正。

    nacos安装与配置

    GitHub下载地址
    在这里插入图片描述
    在这里插入图片描述
    在此目录下进入cmd
    输入命令:startup.cmd -m standalone
    在这里插入图片描述
    访问控制台中的地址,用户名密码都是nacos
    在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述
    如果这里访问页面的IP地址与本机地址不同,说明nacos使用了虚拟网卡。如果想要ip地址为本机ip,需要在网络适配器中禁用虚拟卡
    在这里插入图片描述

    创建命名空间

    在这里插入图片描述
    创建成功后系统会生成一个唯一的id,这个id写在生产者与消费者的yml文件中(下文已写出)。这样nacos会将项目中的服务注册到指定的命名空间中,避免多个项目混淆。

    nacos使用与配置

    创建新项目作为父项目

    创建新项目后,删除src文件夹,只保留pom.xml
    在这里插入图片描述
    pom.xml

    
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0modelVersion>
    
        <groupId>com.hzxgroupId>
        <artifactId>testmaven32springcloudartifactId>
        <version>1.0-SNAPSHOTversion>
    
        <parent>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-parentartifactId>
            <version>2.3.2.RELEASEversion>
        parent>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-starterartifactId>
            dependency>
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-starter-testartifactId>
            dependency>
            
            <dependency>
                <groupId>com.alibaba.cloudgroupId>
                <artifactId>spring-cloud-alibaba-dependenciesartifactId>
                <version>2.2.6.RELEASEversion>
                <type>pomtype>
                <scope>importscope>
            dependency>
        dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.bootgroupId>
                    <artifactId>spring-boot-maven-pluginartifactId>
                plugin>
            plugins>
        build>
    project>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44

    我的springboot版本是2.3.2,对应的springcloud-alibaba版本是2.2.6。需要注意springboot和springcloud alibaba版本要相对应。

    创建nacos服务端项目

    名字是:nacos-provider-project
    在这里插入图片描述

    pom.xml

    
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <parent>
            <artifactId>testmaven32springcloudartifactId>
            <groupId>com.hzxgroupId>
            <version>1.0-SNAPSHOTversion>
        parent>
        <modelVersion>4.0.0modelVersion>
    
        <artifactId>nacos-provider-projectartifactId>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-starter-webartifactId>
                <version>2.3.2.RELEASEversion>
            dependency>
    		
            <dependency>
                <groupId>com.alibaba.cloudgroupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-discoveryartifactId>
                <version>2.2.7.RELEASEversion>
            dependency>
            
            <dependency>
                <groupId>com.alibaba.cloudgroupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-configartifactId>
                <version>2.2.7.RELEASEversion>
            dependency>
        dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.bootgroupId>
                    <artifactId>spring-boot-maven-pluginartifactId>
                    <configuration>
                        <excludes>
                            <exclude>
                                <groupId>org.projectlombokgroupId>
                                <artifactId>lombokartifactId>
                            exclude>
                        excludes>
                    configuration>
                plugin>
            plugins>
        build>
    
    project>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51

    application.yml

    server:
      port: 8081
    spring:
      cloud:
        nacos:
          discovery:
            server-addr: http://192.168.220.1:8848
            namespace: 8302a253-b30a-4a13-bdeb-0caf566317b9
      application:
        name: nacos-provider
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    启动类

    @SpringBootApplication
    @EnableDiscoveryClient
    public class StartNacosProvider{
        public static void main(String[] args) throws Exception {
            SpringApplication.run(StartNacosProvider.class, args);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    创建nacos客户端项目

    名字是:nacos-consumer-project

    pom.xml

    与服务端的pom.xml依赖一致

    
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <parent>
            <artifactId>testmaven32springcloudartifactId>
            <groupId>com.hzxgroupId>
            <version>1.0-SNAPSHOTversion>
        parent>
        <modelVersion>4.0.0modelVersion>
    
        <artifactId>nacos-consumer-projectartifactId>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-starter-webartifactId>
                <version>2.3.2.RELEASEversion>
            dependency>
    
            <dependency>
                <groupId>com.alibaba.cloudgroupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-discoveryartifactId>
                <version>2.2.7.RELEASEversion>
            dependency>
            <dependency>
                <groupId>com.alibaba.cloudgroupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-configartifactId>
                <version>2.2.7.RELEASEversion>
            dependency>
        dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.bootgroupId>
                    <artifactId>spring-boot-maven-pluginartifactId>
                    <configuration>
                        <excludes>
                            <exclude>
                                <groupId>org.projectlombokgroupId>
                                <artifactId>lombokartifactId>
                            exclude>
                        excludes>
                    configuration>
                plugin>
            plugins>
        build>
    project>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49

    application.yml

    server:
      port: 8091
    spring:
      cloud:
        nacos:
          discovery:
            server-addr: http://192.168.220.1:8848
            namespace: 8302a253-b30a-4a13-bdeb-0caf566317b9
      application:
        name: nacos-consumer
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    启动类

    @SpringBootApplication
    @EnableDiscoveryClient
    public class StartNacosConsumer {
        public static void main(String[] args) throws Exception {
            SpringApplication.run(StartNacosConsumer.class, args);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    启动测试

    先启动服务端再启动客户端
    在这里插入图片描述
    在这里插入图片描述
    在nacos网站可以看到服务已经注册进nacos中
    在这里插入图片描述
    如果nacos服务端部署在远程,并且出现启动失败的情况
    在这里插入图片描述
    在这里插入图片描述
    此时需要bootstrap.properties配置文件,将application.yml中关于nacos的配置写入bootstrap.properties。

    spring.application.name=nacos-consumer
    spring.cloud.nacos.discovery.server-addr=http://192.168.0.248:8848
    spring.cloud.nacos.discovery.namespace=42d5d19a-8564-4da2-8b97-7e4eac1c53a3
    spring.cloud.nacos.config.server-addr=http://192.168.0.248:8848
    
    • 1
    • 2
    • 3
    • 4

    但是为什么把配置内容写在application.yml文件就不行,我就不知道了。


    nacos配置负载均衡

    改造生产者nacos-provider-project

    controller层

    @RestController
    public class ProviderController {
        
        @Value("${server.port}")
        private String port;
    
        @RequestMapping(value = "/nacos/provider/get/{id}",method = RequestMethod.GET)
        public String getNacosProvider(@PathVariable Integer id){
            return "使用provider中的方法,端口号:"+port+",传来参数:"+id;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    改造消费者nacos-consumer-project

    配置负载均衡

    @Configuration
    public class ConsumerConfig {
    
        @Bean
        @LoadBalanced
        public RestTemplate getRestTemplate(){
            return new RestTemplate();
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    controller

    @RestController
    public class ConsumerController {
    
        @Autowired
        private RestTemplate restTemplate;
    
        @RequestMapping(value = "/nacos/consumer/get/{id}",method = RequestMethod.GET)
        public String getNacosConsumer(@PathVariable Integer id){
            return restTemplate.getForObject("http://nacos-provider/nacos/provider/get/"+id,String.class);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    测试

    现在启动两个生产者,先启动一个生产者然后修改一下端口号再启动一个生产者
    在这里插入图片描述
    在这里插入图片描述
    现在有两个 生产者,端口号分别为8081和8082。
    启动消费者消费者端口号为8091
    现在通过apifox调用消费者的接口
    在这里插入图片描述
    在这里插入图片描述
    根据返回值可以看到,消费者分别调用了两个生产者的接口,达成负载均衡的效果。
    可以在nacos网站未各个生产者分配权重。权重越高被访问的频率越高,权重设置为0则实例完全不会被访问。
    在这里插入图片描述
    在这里插入图片描述
    使用负载均衡,可以合理利用资源,服务器性能有差异,当实例部署在性能不同的机器上时,可以通过设置权重,让性能好的机器承担更多的用户请求;另外,在升级服务时,通过调整权重进行平滑升级,例如,把实例1权重调节为0,用户只能去调用实例2、实例3的情况,待实例1升级后,也可以将实例1的权重设置为0.1,让一部分用户先体验,实例1稳定后再调高权重。


    nacos配置中心

    SpringCLoud Alibaba的Nacos相对于SpringCloud而言,实现了Eureka和Config和Ribbon的作用,上面已经介绍了nacos对应eureka可ribbon的内容,下面介绍config的内容。
    nacos的配置中心中,所有服务使用nacos上面的配置,不走本地配置。

    创建命名空间

    现在nacos网站上创建一个新的命名空间
    在这里插入图片描述
    在这里插入图片描述

    修改生产者nacos-provider-project

    增加一个配置文件bootstrap.properties

    配置文件是先加载bootstrap再加载application,所有读取nacos的配置写在bootstrap配置里。

    spring.application.name=nacos-provide-config-center
    spring.cloud.nacos.config.server-addr=http://192.168.220.1:8848
    spring.cloud.nacos.config.file-extension=yaml
    spring.cloud.nacos.config.namespace=8302a253-b30a-4a13-bdeb-0caf566317b9
    spring.profiles.active=dev
    spring.cloud.nacos.config.refresh-enabled=true
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    在nacos网站里同样需要配置
    在这里插入图片描述

    bootstrap.properties文件中输入的内容与在网页里配置的内容相一致

    application.name会对应nacos上面配置文件的dataid值
    
    server-addr是nacos的地址
    
    file-extension是对应nacos上面配置文件的扩展名
    
    namespace是对应nacos上面配置文件所属的命名空间
    
    active是表示后缀使用哪个配置文件,例如nacos-provide-config-center-dev.yaml,nacos-provide-config-center-test.yaml
    
    refresh-enabled是开启配置文件自动刷新(修改nacos的配置文件后默认不会自动刷新,除非重启服务。注意:需要结合@RefreshScope注解一起使用)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在这里插入图片描述

    在controller层增加注解@RefreshScope

    在这里插入图片描述

    测试

    启动生产者与消费者后,可以在nacos网站的配置中看到,端口号与本地不同。

  • 相关阅读:
    js 获取字符串中某字符出现的次数
    2023CSP-J游寄
    WebGL 与 WebGPU比对[5] - 渲染计算的过程
    Three Ammo实现物理作用实例
    java毕业设计体育论坛网站源码+lw文档+mybatis+系统+mysql数据库+调试
    Linux Shell入门常用命令使用
    (5)SpringMVC处理携带JSON格式(“key“:value)请求数据的Ajax请求
    走进SpringBoot源码吃透Spring扩展点「扩展点实战系列」- 第450篇
    Android S(31) PMS 服务启动原理
    Linux安装宝塔,并实现公网远程登录宝塔面板【内网穿透】
  • 原文地址:https://blog.csdn.net/qq_41841482/article/details/134030981