SpringCloudAlibaba-Nacos注册中心的使用

目录

1.1.Nacos服务安装

1.2.导入父项目依赖

1.3.子项目依赖

1.4.编写启动类

1.5.编写配置文件

 1.6.启动测试

2.1Nacos添加配置

2.2客户端接入配置中心

1.导入依赖

 

2.动态刷新配置

3.编写bootstrap.yml

2.3命名空间

1.创建命名空间

2.在命名空间创建配置

3.客户端配置


1.1.Nacos服务安装

下载地址:Releases · alibaba/nacos · GitHub

启动Nacos

  • windows执行bin目录下的startup命令 :startup.cmd -m standalone

  • linux 执行 :sh startup.sh -m standalone

访问Nacos

http://127.0.0.1:8848/nacos/index.html

  • 用户名和密码都是:nacos

1.2.导入父项目依赖

	  <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <spring-cloud-alibaba.version>2.2.1.RELEASE</spring-cloud-alibaba.version>
        <spring-boot.version>2.2.5.RELEASE</spring-boot.version>
        <mysql.version>5.1.47</mysql.version>
        <mybatis.version>2.1.1</mybatis.version>
    </properties>

    <!--1.管理 SpringBoot的jar包-->
    <!--SpringBoot-->
    <parent>
        <groupId> org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.5.RELEASE</version>
    </parent>

    <!--2. 统一管理相关依赖,供子项目直接引入使用-->
    <dependencyManagement>
        <dependencies>
            <!-- springCloud-alibaba -->
            <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>
            <!-- mysql驱动 -->
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <version>${mysql.version}</version>
            </dependency>
            <!--mybatis-->
            <dependency>
                <groupId>org.mybatis.spring.boot</groupId>
                <artifactId>mybatis-spring-boot-starter</artifactId>
                <version>${mybatis.version}</version>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <!--3.这里是所有子项目都可以用的jar包-->
    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
    </dependencies>

1.3.子项目依赖

    <dependencies>
        <!--nacos客户端依赖-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!--SpringBootWeb依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--公共库依赖-->
        <dependency>
            <groupId>cn.itsource</groupId>
            <artifactId>common</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
    </dependencies>

1.4.编写启动类

@SpringBootApplication
// 开启Nacos客户端
@EnableDiscoveryClient
public class UserApp {
    public static void main(String[] args) {
        SpringApplication.run(UserApp.class,args);
    }
}

1.5.编写配置文件

server:
  port: 10001 # user服务端口号

spring:
  application:
    name: user-server # 应用名称
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 # 指定nacos注册中心地址

 1.6.启动测试

2.1Nacos添加配置

第一步:打开Nacos监控面板,进入配置列表,新增一个user服务的配置文件

第二步:填写配置文件参数,这里定义了一个名字为application-user-dev.yaml的配置,使用的是YAML格式

  • DataID : 非常重要,可以看做是配置的文件的名字,在程序中拉取配置文件的时候需要指定Data ID。

  • Group : 分组,默认 DEFAULT_GROUP , 可以针对不同的项目指定不同的配置组

 

2.2客户端接入配置中心

1.导入依赖

<dependencies>
    <!--nacos配置中心客户端依赖-->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
    </dependency>
</dependencies>

 

2.动态刷新配置

在配置文件中定义一个dynamicRefreshTest参数,在代码中通过注解获取,测试是否能够动态刷新

  • 第一步:修改注册中心中UserServer服务的配置,新增一个属性值

server:
  port: 1010 # user服务端口号

spring:
  application:
    name: user-server # 应用名称
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 # 指定nacos注册中心地址
dynamicRefreshTest: 我真的很帅

第二步:在UserServer中获取dynamicRefreshTest属性值,后续动态改变配置的值,观察是否改变

@RestController
@RequestMapping("/user")
@RefreshScope // 动态刷新配置注解
public class UserController {
    @Value("${server.port}")
    private String port;

    @Value("${dynamicRefreshTest}")
    private String dynamicRefreshTest;

    @GetMapping("/getById/{id}")
    public User getById(@PathVariable("id") Long id){
        return new User(id, 端口号:" + port+ ", dynamicRefreshTest:" + dynamicRefreshTest);
    }
}

3.编写bootstrap.yml

spring:
  cloud:
    nacos:
      config:
        server-addr: localhost:8848 # 指定注册中心地址
        prefix: application-user # 指定配置文件名称,不需要环境和后缀
        file-extension: yaml # 指定配置文件后缀
        group: DEFAULT_GROUP # 如果是默认分组,那么此配置可以不填写,反之则必须要写
  profiles:
    active: dev # 指定环境

2.3命名空间

1.创建命名空间

修改Nacos,添加命名空间

2.在命名空间创建配置

进入配置列表 ,切换到新建立的命名空间,创建配置文件

 

3.客户端配置

如果不使用默认的public命名空间,那么需要指定namespace配置为要使用的命名空间的Id值

spring:
  cloud:
    nacos:
      config:
        server-addr: localhost:8848 # 指定注册中心地址
        prefix: application-user # 指定配置文件名称,不需要环境和后缀
        file-extension: yaml #指定配置文件后缀
        # group: DEFAULT_GROUP # 如果是默认分组,那么此配置可以不填写,反之则必须要写
        namespace: c48fa123-d6e8-4c00-8751-04492e2c8f71
  profiles:
    active: dev # 指定环境

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!要搭建Spring Cloud Alibaba Nacos项目,您可以按照以下步骤进行操作: 1. 创建Spring Boot项目:首先,在您的IDE中创建一个新的Spring Boot项目。 2. 添加依赖:在项目的pom.xml文件中添加相应的依赖。您需要添加以下四个核心依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> ``` 3. 配置Nacos Server地址:在application.properties(或application.yml)文件中配置Nacos Server的地址。例如: ```yaml spring.cloud.nacos.discovery.server-addr=${NACOS_SERVER_ADDR:localhost:8848} ``` 4. 创建服务提供者和消费者:根据您的需求,创建相应的服务提供者和消费者。您可以使用`@RestController`注解创建简单的RESTful接口。 5. 注册服务:在服务提供者的主类上添加`@EnableDiscoveryClient`注解,以将服务注册到Nacos Server上。 6. 调用服务:在服务消费者中使用`@RestTemplate`或Feign等方式调用服务。您可以通过在方法上添加`@LoadBalanced`注解来实现负载均衡。 7. 启动应用程序:最后,启动应用程序并验证各个微服务之间的通信是否正常。 这些是搭建Spring Cloud Alibaba Nacos项目的基本步骤。根据您的具体需求,您可能还需要配置其他功能,如动态配置等。希望对您有帮助!如有更多问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值