Docker之nacos集群部署

ChatYU. 2024-06-30 12:37:03 阅读 72

前言

Nacos 是一个开源的注册中心和配置中心,用于实现微服务架构中的服务发现、服务治理和动态配置管理。在 Docker 中使用 Nacos,你可以通过拉取官方提供的 Docker 镜像并运行容器的方式来快速部署 

一.Nacos镜像拉取及独立模式

镜像拉取命令详解:

当前命令为创建Nacos容器(没有Nacos镜像会自动拉取Nacos镜像)

docker run: 运行一个 Docker 容器的命令。

-itd: 这是参数的一部分,其中:

-i: 保持标准输入(stdin)打开。

-t: 为容器分配一个伪终端(pseudo-TTY)。

-d: 在后台运行容器,并返回容器 ID。

-e PREFER_HOST_MODE=ip: 设置环境变量 PREFER_HOST_MODE 的值为 ip,表示使用 IP 模式。

-e MODE=standalone: 设置环境变量 MODE 的值为 standalone,表示以独立模式运行 Nacos。

-e SPRING_DATASOURCE_PLATFORM=mysql: 设置环境变量 SPRING_DATASOURCE_PLATFORM 的值为 mysql,指定 Nacos 使用 MySQL 数据库作为存储后端。

-e MYSQL_SERVICE_HOST=172.17.0.2: 设置环境变量 MYSQL_SERVICE_HOST 的值为 MySQL 服务的主机 IP 地址。

-e MYSQL_SERVICE_PORT=3306: 设置环境变量 MYSQL_SERVICE_PORT 的值为 MySQL 服务的端口号。

-e MYSQL_SERVICE_DB_NAME=nacos: 设置环境变量 MYSQL_SERVICE_DB_NAME 的值为 MySQL 数据库的名称,这里为 nacos

-e MYSQL_SERVICE_USER=root: 设置环境变量 MYSQL_SERVICE_USER 的值为 MySQL 连接的用户名,这里为 root

-e MYSQL_SERVICE_PASSWORD=123456: 设置环境变量 MYSQL_SERVICE_PASSWORD 的值为 MySQL 连接的密码,这里为 123456

-p 8848:8848: 将容器内部的 8848 端口映射到主机的 8848 端口,允许通过主机访问 Nacos。

--name nacos: 为容器指定一个名称,这里为 nacos

--restart=always: 设置容器总是在停止时自动重启。

nacos/nacos-server: 指定要运行的 Docker 镜像,这里是 Nacos 官方提供的 nacos-server 镜像。

这个命令的目的是在 Docker 中启动一个 Nacos 服务,配置使用 MySQL 数据库作为后端存储,并且在容器内部的 8848 端口上提供服务

docker run -itd \

-e PREFER_HOST_MODE=ip \

-e MODE=standalone \

-e SPRING_DATASOURCE_PLATFORM=mysql \

-e MYSQL_SERVICE_HOST=172.17.0.2 \

-e MYSQL_SERVICE_PORT=3306 \

-e MYSQL_SERVICE_DB_NAME=nacos \

-e MYSQL_SERVICE_USER=root \

-e MYSQL_SERVICE_PASSWORD=123456 \

-p 8848:8848 \

--name nacos \

--restart=always \

nacos/nacos-server

拉取镜像后我们需要开放8848端口,并刷新防火墙规则

开放端口

firewall-cmd --zone=public --add-port=8080/tcp --permanent 

 刷新防火墙规则

firewall-cmd --reload

同时我们可以通过查看防火墙开放端口列表是否开启

查看防火墙开放端口列表

firewall-cmd --zone=public --list-ports

当我们进入到nacos内网控制台说明NACOS创建成功了

 

二.Nacos集群部署

对比上面我们使用的是独立模式(standalone),当我们需要将独立模式改成集群模式时,要将环境遍历MODE设置为cluster

1.搭建集群

docker network create --subnet=172.20.0.1/16 my_net

为原有Mysql容器再连接一个网络

my_net为自定义网络名 m1为容器名

docker network connect my_net m1

当我们为m1连接上网络后,它不仅拥有原有的网段还有刚刚连接的网段

 

创建集群部署容器 

docker run -itd \

-e PREFER_HOST_MODE=ip \

-e MODE=cluster\

-e NACOS_SERVERS="172.20.0.102:8848 172.20.0.103:8848" \

-e SPRING_DATASOURCE_PLATFORM=mysql \

-e MYSQL_SERVICE_HOST=m1 \

-e MYSQL_SERVICE_PORT=3306 \

-e MYSQL_SERVICE_DB_NAME=nacos \

-e MYSQL_SERVICE_USER=root \

-e MYSQL_SERVICE_PASSWORD=123456 \

-p 8848:8848 \

--name nacos2 \

--net my_net \

--ip 172.20.0.101 \

--restart=always \

nacos/nacos-server

为测试完成集群部署,我们只需要将容器名--name 容器名和网段ip进行修改,分别创建三台nacos

虽然我们的三台nacos搭建完成了,但是我们只有一个或者两个容器能运行,所以要完成多台同时运行,还是要借助nginx实现负载均衡

2.Nginx实现负载均衡

在我们的工作目录中创建Niginx目录及所需文件夹

mkdir -p nginx/{conf.d}

cd /nginx/conf.d

 新建default.conf 配置文件放在conf.d目录中

upstream nacosList {

server nacos1:8848 weight=1;

server nacos2:8848 weight=1;

server nacos3:8848 weight=1;

}

server {

listen 80;

server_name www.ChatYULin.com;

location / {

root /etc/nginx/html/;

index index.html index.htm;

}

error_page 500 502 503 504 /50x.html;

location = /50x.html {

root /usr/share/nginx/html;

}

location /nacos {

proxy_pass http://nacosList;

}

location /nacos {

rewrite ^/api/(.*)$ /$1 break;

proxy_pass http://tomcatList;

proxy_redirect default;

}

}

 创建nginx容器

docker run -itd \

--name nginx \

-v /soft/nginx/conf.d:/etc/nginx/conf.d \

-p 80:80 \

--net my_net \

nginx

进入到我们本机的C:\Windows\System32\drivers\etc目录下

找到Host打开进行修改你要映射的域名

输入你的虚拟机IP以及域名

当我们创建并运行完nginx容器后利用可以使用自定义域名访问到说明我们的域名映射和nginx容器已完成

 

我们登录到nacos中,看到三台容器同时运行时就说明完成负载均衡了

 

报错解决 

这个报错解释为数据源配置出错,也就是我们在配置数据库时要与Nacos配置对应,多半存在与网段问题,我们可以通过命令查看nacos/mysql容器网段是否一致

docker inspect 容器名

Nacos网段必须要与Mysql网段一致

在我配置MySQL容器时因为没有去指定网段而是默认使用网桥模式,而我的Nacos容器指定网段为172.17.0.2,但是在这之前我还有一个容器占用了当前网段,所以我使用配置Nacos的网段为172.17.0.3配置信息不一致,导致我的Nacos配置的数据源一直是之前的MySQL容器所以一直报错

解决措施

解决思路:两者要在同一个网段

1.自定义网络为MySQL容器指定网段

2.为Nacos容器指定网段

3.像nacos集群一样创建自定义网络然后连接MySQL容器



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。