一、安装前准备
1、在命令行终端中输入以下命令,以升级yum及其提示缺失的依赖包:
yum update -y yum install net-tools -y
2、安装JDK,Nacos的运行环境是Java 8或更高版本,因此需要安装openjdk-8-jdk:
yum install java-1.8.0-openjdk -y java -version
安装完成后在命令行中输入java -version,可以看到jdk的版本信息:openjdk version "1.8.0_302"
二、下载及安装Nacos
1、在浏览器输入网址http://github.com/alibaba/nacos/releases,到nacos的发行版repo下载最新版本的nacos-server-$version.tar.gz:
wget https://github.com/alibaba/nacos/releases/download/2.0.3/nacos-server-2.0.3.tar.gz
2、解压nacos-server-$version.tar.gz:
tar -xvf nacos-server-2.0.3.tar.gz
3、进入解压后的nacos文件夹:
cd nacos/bin
4、执行startup.sh脚本以启动nacos:
./startup.sh -m standalone
Nacos启动后,在浏览器输入地址http://localhost:8848/nacos/,进行访问,如果能看到网页,说明nacos已经正常启动。
三、使用Nacos
1、注册服务
在Nacos中,注册中心的重要作用是向外界注册服务和从外界获取服务列表。注册服务可以通过Nacos中的服务管理页面来完成。
首先创建配置文件${nacos_home}/conf/application.properties:
server.port=8080 spring.application.name=example spring.cloud.nacos.config.server-addr=127.0.0.1:8848
然后在Spring Boot应用程序的pom.xml中添加如下配置:
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency>
接下来在启动类上添加@EnableDiscoveryClient注解:
@SpringBootApplication @EnableDiscoveryClient public class ExampleApplication { public static void main(String[] args) { SpringApplication.run(ExampleApplication.class, args); } }
最后在需要注册服务的Controller中添加@NacosInjected注解:
@RestController @RequestMapping("/example") public class ExampleController { @NacosInjected private NamingService namingService; @GetMapping("/service") public List<Instance> getService() throws NacosException { return namingService.getAllInstances("example"); } }
访问http://localhost:8080/example/service,即可看到注册的服务列表。
2、配置管理
Nacos还可以用于配置管理。Nacos的配置可以分为命名空间、分组、配置等级、配置监听器等。
首先创建配置文件${nacos_home}/conf/application.properties:
server.port=8080 spring.application.name=example spring.cloud.nacos.config.server-addr=127.0.0.1:8848 spring.cloud.nacos.config.namespace=example-config
然后在配置管理页面添加配置信息,并选择分组及配置等级:
data: example.yaml: | name: example port: 8080
修改配置内容并保存,可以在应用程序中获取配置信息,如下:
@RestController @RequestMapping("/example") @RefreshScope public class ExampleController { @Value("${name}") private String name; @GetMapping("/config") public String getConfig() { return "name: " + name; } }
访问http://127.0.0.1:8080/example/config,即可看到获取的配置信息。
四、Nacos集群部署
1、配置集群信息
首先在${nacos_home}/conf/cluster.conf文件中添加集群信息:
172.16.100.110:8848 172.16.100.111:8848 172.16.100.112:8848
其中,IP地址为各个nacos服务器的IP地址。
2、启动所有Nacos实例
使用启动命令启动所有Nacos实例,并在每个Nacos实例所在的主机上运行一个实例,例如:
./startup.sh -p 8848 -m standalone ./startup.sh -p 8849 -m standalone ./startup.sh -p 8850 -m standalone
3、在nacos中创建集群
在Nacos后台管理系统中,单击“命名空间管理”,然后单击“新建命名空间”
输入集群信息,完成创建。
4、查看集群状态
进入页面http://127.0.0.1:8848/nacos/v1/ns/raft/health,即可看到Nacos集群的健康状态,如下:
{"message":"CLUSTER_HEALTHY","code":200}
五、总结
Nacos是一个功能强大的服务发现和配置管理平台,可以满足大部分企业的服务管理需求。在CentOS 7上安装Nacos并进行简单的示例演示后,可以看到Nacos易于使用并集成Spring Boot非常方便。同时,在Nacos后台管理系统中可以很方便地进行配置管理和集群管理。