您的位置:

CentOS 7下Nacos安装详解

一、安装前准备

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