一、安装前准备
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后台管理系统中可以很方便地进行配置管理和集群管理。