Yuandupier

Yuandupier

Nacos使用实践

29
0
0
2022-08-02

背景

本文主要整理了如何使用nacos作为微服务的注册中心、配置中心以及开启鉴权。

软件版本

Spring Boot 2.6.7

Spring Cloud 2021.0.2

Spring Cloud Alibaba 2021.0.1.0

Nacos 2.1.0

Nacos Server部署

本次部署采用的是源码构建的方式。

通过官方github,下载Nacos最新源码,执行如下命令编译项目:

git clone https://github.com/alibaba/nacos.git
cd nacos/
mvn -Prelease-nacos -Dmaven.test.skip=true clean install -U  

进入编译后的目录,启动nacos服务,本次使用的单机模式运行:

cd distribution/target/nacos-server-$version/nacos/bin
sh startup.sh -m standalone

启动ok: 在这里插入图片描述 通过url http://localhost:8848/nacos/index.html 访问nacos控制台,账号密码默认为nacos/nacos: 在这里插入图片描述

服务注册发现

Eureka可以很平滑的切换到Nacos,只需要修改部分依赖和配置信息,就可以实现之前Eureka提供的服务注册发现和客户端负载均衡的功能。

本次验证的工程图示如下: 在这里插入图片描述 提供一个生产者和消费者,注册到Nacos Server上面。并且由消费者consumer去请求生产者provider提供的接口。

服务注册发现

首先添加依赖:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

在application.properties配置文件中添加Nacos Server地址:

spring.application.name=nacos-provider
server.port=8088
spring.cloud.nacos.discovery.server-addr=http://localhost:8848

启动类配置@EnableDiscoveryClient注解开启服务注册发现功能,和之前eureka一样:

/**
 * 生产者
 *
 * @author yuanzhihao
 * @since 2022/8/1
 */
@SpringBootApplication
@EnableDiscoveryClient
public class NacosProviderApplication {
    public static void main(String[] args) {
        SpringApplication.run(NacosProviderApplication.class, args);
    }
}

启动服务,可以看到服务nacos-provider已经注册到nacos上,这样就完成了服务注册: 在这里插入图片描述

客户端负载均衡

对于消费端nacos-consumer,还是和生产端nacos-provider一样,需要注册到nacos上,不过要实现负载均衡的话,还需要添加loadbalancer依赖。

具体配置如下:

添加依赖,需要额外添加一个loadbalancer依赖:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!--负载均衡 -->
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>

application.properties配置文件中添加Nacos Server地址:

spring.application.name=nacos-consumer
server.port=8089
spring.cloud.nacos.discovery.server-addr=http://localhost:8848

启动类配置@EnableDiscoveryClient注解开启服务注册发现功能:

/**
 * 消费者
 *
 * @author yuanzhihao
 * @since 2022/8/1
 */
@SpringBootApplication
@EnableDiscoveryClient
public class NacosConsumerApplication {

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

之后可以通过http客户端来请求生产者提供的接口,下面分别整理了RestTemplate和OpenFeign两种方式的实现。

RestTemplate

RestTemplate和之前使用一样,通过和@LoadBalanced注解配置使用,就可以通过服务名的方式,请求对应生产者provider提供的接口,在nacos-consumer中注入一个RestTemplate类型的bean:

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

生产者nacos-provider中提供接口:

@RestController
public static class HelloController {
  @GetMapping("/hello/{name}")
  public String hello(@PathVariable("name") String name) {
    return "hello " + name;
  }
}

在消费者nacos-consumer中使用RestTemplate去请求生产者提供的接口:

@RestController
public static class HelloController {
  @Autowired
  private RestTemplate restTemplate;

  @GetMapping("/hello/{name}")
  public String hello(@PathVariable("name") String name) {
    return restTemplate.getForObject(String.format(Locale.ROOT, "http://nacos-provider/hello/%s", name), String.class);
  }
}

其实代码不需要做任何适配就可以完成nacos的切换,验证ok: 在这里插入图片描述

Spring Cloud OpenFeign

OpenFeign使用和RestTemplate一样,不用做任何代码适配,也简单整理下:

首先添加openfeign依赖:

<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

添加feignclient接口,配置生产者provider信息:

/**
 * 配置生产者provider
 * 
 * @author yuanzhihao
 * @since 2022/8/1
 */
@FeignClient(value = "nacos-provider")
public interface ProviderFeign {
    
    @GetMapping("/hello/{name}")
    String hello(@PathVariable("name") String name);
}

添加@EnableFeignClients注解扫描指定的feign客户端:

@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients("com.yzh.feign")
public class NacosConsumerApplication {
}

请求接口:

@Autowired
private ProviderFeign providerFeign;

@GetMapping("/hello2/{name}")
public String hello2(@PathVariable("name") String name) {
  return providerFeign.hello(name);
}

验证ok: 在这里插入图片描述

Nacos作为配置中心

nacos除了可以作为注册中心以外,还可以用作配置中心,nacos可以用来替换eureka和Spring Cloud Config两个组件的功能,下面整理了如何使用nacos作为配置中心。

验证工程图示如下: 在这里插入图片描述

微服务配置拉取

首先添加依赖,这边需要添加一个spring-cloud-starter-bootstrap依赖,这样就可以读取bootstrap.properties中的配置文件:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!--配置中心 -->
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>

在bootstrap.properties配置文件中添加Nacos Server的地址:

spring.application.name=nacos-config1
server.port=8087
spring.cloud.nacos.config.server-addr=http://localhost:8848
spring.cloud.nacos.discovery.server-addr=http://localhost:8848
# 指定拉取配置文件的名称
spring.cloud.nacos.config.prefix=nacos-config1

这边参考官网,客户端拉取配置文件的格式如下:

${prefix}-${spring.profiles.active}.${file-extension}
  • prefix 默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。
  • spring.profiles.active 即为当前环境对应的 profile,详情可以参考 Spring Boot文档注意:当 spring.profiles.active 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成 ${prefix}.${file-extension}
  • file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置,默认参数为properties。目前只支持 propertiesyaml 类型。

所以,我上面bootstrap.properties配置中,因为手动指定了spring.cloud.nacos.config.prefix配置,并且spring.profiles.active参数为空,然后没有显示指定file-exetension配置数据格式,所以默认会拉取nacos-config1.properties配置文件。

之后需要在nacos页面上添加对应的配置文件,在配置管理->配置列表->新建配置添加nacos-config1.properties配置。 在这里插入图片描述 客户端中读取配置文件:

/**
 * nacos config
 *
 * @author yuanzhihao
 * @since 2022/8/1
 */
@SpringBootApplication
@EnableDiscoveryClient
@RestController
public class NacosConfig1Application {
    @Value("${nacos.name}")
    private String name;
    
    @GetMapping("/name")
    public String name() {
        return "name is " + name;
    }
    
    public static void main(String[] args) {
        SpringApplication.run(NacosConfig1Application.class, args);
    }
}

启动验证ok: 在这里插入图片描述

共享配置拉取

在开发中,微服务非常多的情况下,会有很多的重复的配置,比如服务注册中心,服务证书信息这些,我们可以把这些配置信息都提取出来放到一个公共的配置文件中,之前在Spring Cloud Config中有类似的能力,在Nacos中也提供了这种共享配置的能力。

首先添加spring.cloud.nacos.config.shared-configs[x]配置,该配置是一个数组,表示公共配置的一个集合:

spring.application.name=nacos-config2
server.port=8086
spring.cloud.nacos.config.server-addr=http://localhost:8848
spring.cloud.nacos.discovery.server-addr=http://localhost:8848
# 指定拉取配置文件的名称
spring.cloud.nacos.config.prefix=nacos-config2
spring.cloud.nacos.config.shared-configs[0]=shared-config1.properties
spring.cloud.nacos.config.shared-configs[1]=shared-config2.properties

在nacos中添加对应配置,配置如下:

shared-config1.properties 在这里插入图片描述 shared-config2.properties 在这里插入图片描述 在客户端中读取对应配置:

/**
 * nacos config
 *
 * @author yuanzhihao
 * @since 2022/8/1
 */
@SpringBootApplication
@EnableDiscoveryClient
@RestController
public class NacosConfig2Application {
    @Value("${nacos.name}")
    private String name;

    @Value("${shared1.name}")
    private String shared1Name;

    @Value("${shared2.name}")
    private String shared2Name;

    @GetMapping("/name")
    public String name() {
        return "name is " + name + ";  shared1Name is " + shared1Name + ";  shared2Name is " + shared2Name;
    }

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

验证ok: 在这里插入图片描述

其他

如何开启鉴权

nacos提供了一个简单的鉴权插件,只需要开启一个开关和在配置中添加用户名和密码就ok。

首先在Nacos Server的配置文件application.properties中,配置文件在**/distribution/target/nacos-server-$version/nacos/conf/application.properties**中,需要修改nacos.core.auth.enabled配置为true,官方说不需要重启服务端,但是我还是重启了下、、、 在这里插入图片描述 在客户端配置文件中,添加用户的账号和密码信息,默认就是nacos/nacos:

spring.cloud.nacos.username=nacos
spring.cloud.nacos.password=nacos

开启ok,之后如果不配置账号和密码的话,或者账号密码错误,启动会报错导致注册失败。

结语

关于nacos最基础的用法就整理到这里,这里除了没有支持https以外,基本上都能满足我们项目的需求了,之后文章还会整理下Nacos Server如何开启https以及客户端如何注册到https的Nacos Server上。

参考:

https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html

https://nacos.io/zh-cn/docs/auth.html

代码地址:https://github.com/yzh19961031/blogDemo/tree/master/nacosDemo