0


Docker之nacos集群部署

前言

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容器

标签: docker java linux

本文转载自: https://blog.csdn.net/weixin_73320743/article/details/135681831
版权归原作者 ChatYU. 所有, 如有侵权,请联系我们删除。

“Docker之nacos集群部署”的评论:

还没有评论