Nacos 整合 spring boot 和 spring cloud

4 篇文章 0 订阅
2 篇文章 0 订阅

Nacos搭建

Nacos是什么

服务发现和服务健康监测
	可以作为微服务的注册中心,为其他的微服务提供注册与发现
动态配置服务
	可以对配置文件进行动态的刷新

Nacos搭建

  1. 下载Nacos的安装包
    gitHub下载地址
    由于github下载过于缓慢,这里提供一份1.3.1的百度云下载地址
    百度云下载地址
    提取码 :d14q
  2. 启动服务器
    解压完成后,进入bin目录,双击startup.cmd启动
  3. 登录管理平台
    启动成功后访问 http://localhost:8848/nacos
    账号和密码都是 nacos

整合springBoot

整合配置中心

pom文件

<?xml version="1.0" encoding="UTF-8"?>
<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>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    
    <groupId>org.example</groupId>
    <artifactId>nacos-study</artifactId>
    <packaging>pom</packaging>
    <version>1.0-SNAPSHOT</version>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>config</artifactId>
    <properties>
        <nacos-config-spring-boot.version>0.2.1</nacos-config-spring-boot.version>
    </properties>

    <dependencies>
        <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>com.alibaba.boot</groupId>
            <artifactId>nacos-config-spring-boot-starter</artifactId>
            <version>${nacos-config-spring-boot.version}</version>
        </dependency>

        <dependency>
            <groupId>com.alibaba.boot</groupId>
            <artifactId>nacos-config-spring-boot-actuator</artifactId>
            <version>${nacos-config-spring-boot.version}</version>
        </dependency>
    </dependencies>

</project>

配置文件application.yml

nacos:
  config:
    server-addr: 127.0.0.1:8848
server:
  port: 8080

ConfigApplication启动类

@SpringBootApplication
// 加载dataId为 example的配置源,并开启自动更新
@NacosPropertySource(dataId = "example", autoRefreshed = true, groupId = "DEFAULT_GROUP")
public class ConfigApplication {

    public static void main(String[] args) {
        SpringApplication.run(ConfigApplication.class, args);
    }
}

ConfigController

@Controller
@RequestMapping("/config")
public class ConfigController {

    @NacosValue(value = "${useLocalCache:false}",autoRefreshed = true)
    private boolean useLocalCache;

    @RequestMapping("/get")
    @ResponseBody
    public boolean get(){
        return useLocalCache;
    }
}

配置到这里基本完成,然后启动服务 接来下所有的请求调用,全部都使用postman来完成 获取刚刚自定义的配置
http://localhost:8080/config/get 此时发现得到的返回值为false 然后调用Nacos的Api,来动态修改这个配置,注意这里请求方式必须为POST
http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=example&group=DEFAULT_GROUP&content=useLocalCache=true
结果返回true,表示调用成功 这时我们再次调用上面获取配置的接口
http://localhost:8080/config/get 发现返回值以及是true,表示动态刷新成功了

启动服务发现

pom文件

 <?xml version="1.0" encoding="UTF-8"?>
<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>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
		
	<groupId>org.example</groupId>
    <artifactId>nacos-study</artifactId>
    <packaging>pom</packaging>
    <version>1.0-SNAPSHOT</version>

    <modelVersion>4.0.0</modelVersion>

    <artifactId>discovery</artifactId>
    <properties>
        <nacos-discovery-spring-boot.version>0.2.1</nacos-discovery-spring-boot.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>com.alibaba.boot</groupId>
            <artifactId>nacos-discovery-spring-boot-starter</artifactId>
            <version>${nacos-discovery-spring-boot.version}</version>
        </dependency>
    </dependencies>

</project>

application.yml配置文件

nacos:
  discovery:
    server-addr: 127.0.0.1:8848
server:
  port: 8081

DiscoveryApplication启动类

@SpringBootApplication
public class DiscoveryApplication {

    public static void main(String[] args){
            SpringApplication.run(DiscoveryApplication.class, args);
        }
}

通过NamingService来获取指定名称注册的实例信息

@RestController
@RequestMapping("/discovery")
public class DiscoveryController {

    @NacosInjected
    private NamingService namingService;

    @RequestMapping("/get")
    public List<Instance> get(@RequestParam String serviceName) throws NacosException {
        return namingService.getAllInstances(serviceName);
    }
}

此时我们来获取一个名字为discovery实例的信息
http://localhost:8081/discovery/get?serviceName=discovery
发现返回值为空,因为我们还没有主动的去向Nacos服务端注册discovery实例的信息
我们通过下面的API来注册实例,注意请求方式必须为PUT
http://127.0.0.1:8848/nacos/v1/ns/instance?serviceName=discovery&ip=127.0.0.1&port=8081
此时在调用上面的查询API,就能看到对应的数据了

整合springCloud

整合配置中心

pom文件

<?xml version="1.0" encoding="UTF-8"?>
<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>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
     <groupId>org.example</groupId>
    <artifactId>nacos-study</artifactId>
    <packaging>pom</packaging>
    <version>1.0-SNAPSHOT</version>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>spring-cloud</artifactId>

    <properties>
        <spring-boot.version>2.3.2.RELEASE</spring-boot.version>
        <spring-cloud.version>Hoxton.SR7</spring-cloud.version>

    </properties>
    <dependencies>
  		<dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <version>2.2.1.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

</project>

bootstrap.yaml配置文件

server:
  port: 8082
spring:
  application:
    name: cloudConfig
  cloud:
    nacos:
      config:
        server-addr: 127.0.0.1:8848
        file-extension: yaml

CloudConfigApplication启动类

@SpringBootApplication
public class CloudConfigApplication {

    public static void main(String[] args) {
        SpringApplication.run(CloudConfigApplication.class, args);
    }
}

ConfigController测试类

@RestController
@RequestMapping("/config")
@RefreshScope
public class ConfigController {

    /**
     * 这里备注一下,如果配置文件为yaml格式的,在调用刷新配置文件接口的时候
     * http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=cloudConfig.yaml&group=DEFAULT_GROUP&content=useLocalCache=true
     *
     * 在最后那里,因为yaml配置文件里面参数和冒号“:”中间有一个空格,所有这里也要加一个空格,并且,等于符号也要改成冒号“:”要改成下面这样
     * http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=cloudConfig.yaml&group=DEFAULT_GROUP&content=useLocalCache: true
     */

    @Value("${useLocalCache:false}")
    private boolean useLocalCache;

    @RequestMapping("/get")
    public boolean get() {
        return useLocalCache;
    }
}

首先我们来修改useLocalCache的值为true,注意请求方式为post
http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=cloudConfig.yaml&group=DEFAULT_GROUP&content=useLocalCache: true
这里的dataId的值由三部分组成
${prefix}-${spring.profiles.active}.${file-extension}
prefix:代表应用的名称,也就是spring.application.name配置的值,也可以通过spring.cloud.nacos.config.prefix来指定
spring.profiles.active:对应当前环境的profile,也就是spring.profiles.active配置的值,如果没有的话,这个值可以忽略,对应的-也忽略
file-extension:为当前配置类容的数据格式,通过spring.cloud.nacos.config.file-extension来配置,目前只支持properties 和 yaml
上面的api返回结果true,就证明,修改成功,这时可以去对应的管理平台查看
此时我们调用***http://localhost:8082/config/get***
可以看见返回值为true,证明修改成功

启动服务发现

这里需要一个生产者和一个消费者来证明Nacos提供的服务的注册和发现
在这里插入图片描述

生产者

pom文件

<?xml version="1.0" encoding="UTF-8"?>
<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">
        <groupId>org.example</groupId>
    <artifactId>nacos-study</artifactId>
    <packaging>pom</packaging>
    <version>1.0-SNAPSHOT</version>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>spring-cloud</artifactId>


    <properties>
        <spring-boot.version>2.3.2.RELEASE</spring-boot.version>
        <spring-cloud.version>Hoxton.SR7</spring-cloud.version>

    </properties>
    <dependencies>
	    <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <version>2.2.1.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

</project>

bootstrap.yaml配置文件

server:
  port: 8011
spring:
  application:
    name: cloud-provider
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

ProviderApplication启动类和接口提供

@SpringBootApplication
@EnableDiscoveryClient
public class ProviderApplication {

    public static void main(String[] args) {
        SpringApplication.run(ProviderApplication.class, args);
    }

    @RestController
    class EchoController {
        @RequestMapping(value = "/echo/{string}", method = RequestMethod.GET)
        public String echo(@PathVariable String string) {
            return "Hello Nacos Discovery " + string;
        }
    }
}

消费者

pom文件,和上面生产者的一样

bootstrap.yaml配置文件

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

ConsumerApplication启动类,以及测试方法

@SpringBootApplication
@EnableDiscoveryClient
public class ConsumerApplication {

    @LoadBalanced
    @Bean
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }

    public static void main(String[] args) {
        SpringApplication.run(ConsumerApplication.class, args);
    }

    @RestController
    public class TestController {

        private final RestTemplate restTemplate;

        @Autowired
        public TestController(RestTemplate restTemplate) {
            this.restTemplate = restTemplate;
        }

        @RequestMapping(value = "/echo/{str}", method = RequestMethod.GET)
        public String echo(@PathVariable String str) {
            return restTemplate.getForObject("http://cloud-provider/echo/" + str, String.class);
        }
    }
}

此时调用 http://localhost:8012/echo/2020
获取到返回值 Hello Nacos Discovery 2020

本案例github地址

[点这里](https://github.com/longhao1213/nacos-study)
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: Nacos是一个开源的服务发现、配置管理和动态DNS服务的平台,可以帮助开发者更好地构建微服务架构。而Spring Cloud是一个基于Spring Boot的开发工具,用于快速构建分布式系统中的一些常见模式,如配置管理、服务发现、断路器、路由、微代理、控制总线等。 将NacosSpring Cloud整合,可以实现更好的微服务架构管理。具体来说,可以通过Nacos实现服务注册与发现、配置管理、动态DNS等功能,而Spring Cloud则可以通过集成Nacos实现更加便捷的开发和部署。例如,可以使用Spring Cloud的Feign客户端来调用Nacos注册的服务,也可以使用Spring Cloud Config来管理Nacos中的配置信息。 总之,NacosSpring Cloud整合可以帮助开发者更加方便地构建和管理微服务架构,提高开发效率和系统稳定性。 ### 回答2: Nacos是一个支持动态服务发现、配置管理和服务治理的云原生基础设施。Spring Cloud是一套基于Spring Boot框架实现的微服务开发工具。Nacos整合Spring Cloud可以帮助我们更好地实现微服务架构。 首先,Nacos可以作为Spring Cloud中服务发现和配置中心的实现之一,通过注册中心让所有的微服务能够相互发现,从而实现动态调度。Nacos不仅支持传统的服务注册和发现,也支持DNS,甚至可以支持Kubernetes平台上的服务注册和服务发现。而且,Nacos还支持配置中心。通过Nacos可以统一管理所有的微服务的配置信息,实现配置的灵活调整,从而更好地支持多环境部署。 其次,Nacos还提供了服务的监控、流控和降级等治理功能。这些功能可以帮助我们更好地保证微服务架构的稳定性和高可用性。而且,Nacos还支持多租户的功能,可以让不同的微服务具有不同的权限和控制。 最后,NacosSpring Cloud框架的无缝集成也很值得赞赏。通过Spring Cloud的相关组件,我们可以很容易地通过Nacos对微服务进行调度、发现和治理。 在整合NacosSpring Cloud中,我们需要使用Spring Cloud Alibaba组件中的相应依赖项,如spring-cloud-starter-alibaba-nacos-discovery、spring-cloud-starter-alibaba-nacos-config等。我们还需要在配置文件中配置一些相关的参数信息,例如注册中心地址、配置中心地址等。然后,在代码中我们就可以使用Spring Cloud提供的相关注解和API来实现服务的注册、发现以及配置管理等目的。 总而言之,Nacos整合Spring Cloud可以帮助我们更好地实现微服务架构,提高系统的可靠性和可用性。同时,Nacos也提供了一些治理方面的功能,可以帮助我们更好地实现对微服务的管理和控制。 ### 回答3: Nacos是一个开源的动态服务发现,配置和服务管理平台。它为不同的应用提供了一个共享的服务注册中心,以达到分布式系统中服务管理的目的。在分布式系统中,服务的注册和发现是一件非常重要的事情,因为它可以帮助我们很方便地管理各种不同的服务,从而实现高可用、高性能的服务。而SpringCloud是一个非常流行的微服务框架,它通过丰富的微服务组件和框架,为开发人员提供了完整的微服务开发的工具。 Nacos整合SpringCloud可以很好地实现服务注册和发现。在SpringCloud中,我们可以使用Nacos来注册和发现服务,而不需要其他的注册中心。这样有很多好处,例如更方便的服务管理和自动化、高性能、高可用性、强大的读写分离、多种数据类型的支持等等,使得Nacos在微服务领域得到了广泛的应用。 除了服务注册和发现外,Nacos还提供了配置管理、流量管理等很多功能,与SpringCloud无缝整合,进一步优化微服务架构体系。 总之,Nacos整合SpringCloud是一种非常优秀的微服务开发方式,它为企业提供了完整的服务治理能力,使得企业可以更好地管理和使用微服务。此外,Nacos还具有高可用、高性能、多种功能等诸多优点,让开发人员可以更加自由地进行微服务开发。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值