在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)

在Docker上用Nacos1.3容器连接MySQL5.6和8.0.18容器进入持久化的具体操作(Nacos单机版)

这里直接在linux中启动三个Nacos容器。

文章目录

    • 3个Nacos1.3容器+一个MySQL5.6容器+一个Nginx容器
        • 配置MySQL5.6数据库
        • 配置Nacos1.3
        • 配置Nginx1.16.1
    • 3个Nacos1.3容器+一个MySQL8.0.18容器+一个Nginx容器
        • 配置MySQL8.0.18数据库
        • 配置Nacos1.3
        • 配置Nginx1.16.1

3个Nacos1.3容器+一个MySQL5.6容器+一个Nginx容器

配置MySQL5.6数据库

配置mysql数据库在上面那篇文章里有提到,这里就不再写了。
配置完数据库后启动数据库容器。

配置Nacos1.3

3个Nacos在同一台虚拟机上运行。

#启动第一台nacos(修改完后直接复制到linux上运行启动容器)
#NACOS_...开头的是配置nacos的信息,MYSQL_...是配置nacos连接的数据库的信息,JVM_...是配置nacos虚拟机的信息,根据你们自己的配置进行更改。
#10.211.55.17是我linux的IP地址
#注意,这里我的mysql5.6容器对外暴露的是3305端口。
#端口只能修改对外暴露的端口号,nacos里的8848不能修改,如果使用NACOS_SERVER_PORT去修改里面的端口号,会启动后无法访问。
docker run -d \
--name nacos_1 \
--hostname=nacos_1 \
-e MODE=cluster \
-e NACOS_SERVERS="10.211.55.17:3333 10.211.55.17:4444 10.211.55.17:5555" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=10.211.55.17 \
-e MYSQL_SERVICE_PORT=3305 \
-e MYSQL_SERVICE_DB_NAME=nacos_config \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=123456 \
-e JVM_XMS=512m \
-e JVM_XMX=512m \
-e JVM_XMN=256m \
-e JVM_MS=32m \
-e JVM_MMS=80m \
-p 3333:8848 nacos/nacos-server

#启动第二台nacos
docker run -d \
--name nacos_2 \
--hostname=nacos_2 \
-e MODE=cluster \
-e NACOS_SERVERS="10.211.55.17:3333 10.211.55.17:4444 10.211.55.17:5555" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=10.211.55.17 \
-e MYSQL_SERVICE_PORT=3305 \
-e MYSQL_SERVICE_DB_NAME=nacos_config \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=123456 \
-e JVM_XMS=512m \
-e JVM_XMX=512m \
-e JVM_XMN=256m \
-e JVM_MS=32m \
-e JVM_MMS=80m \
-p 4444:8848 nacos/nacos-server

#启动第三台nacos
docker run -d \
--name nacos_3 \
--hostname=nacos_3 \
-e MODE=cluster \
-e NACOS_SERVERS="10.211.55.17:3333 10.211.55.17:4444 10.211.55.17:5555" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=10.211.55.17 \
-e MYSQL_SERVICE_PORT=3305 \
-e MYSQL_SERVICE_DB_NAME=nacos_config \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=123456 \
-e JVM_XMS=512m \
-e JVM_XMX=512m \
-e JVM_XMN=256m \
-e JVM_MS=32m \
-e JVM_MMS=80m \
-p 5555:8848 nacos/nacos-server

在这里插入图片描述
http://10.211.55.17:3333/nacos/
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第1张图片
http://10.211.55.17:4444/nacos/
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第2张图片
http://10.211.55.17:5555/nacos/
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第3张图片
并且里面也有我们在做单机持久化时保留的配置。

配置Nginx1.16.1

这里我拉取的镜像是Nginx1.16.1。

#拉取镜像
docker pull nginx:1.16.1

#启动nginx容器(对外暴露1111端口)
docker run -d --name nginx1.16.1 -p 1111:80 nginx:1.16.1

#进入nginx容器,修改配置
docker exec -it 容器ID /bin/bash
cd /etc/nginx
#因为nginx容器没有装vim,所以我们要先安装vim
apt-get update
apt-get install vim
#备份nginx.conf文件
cp nginx.conf nginx.conf.bk
#修改nginx.conf文件
vim nginx.conf

在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第4张图片

然后在http{…}里的#gzip on;下添加:

	upstream cluster{
		server 10.211.55.17:3333;
		server 10.211.55.17:4444;
		server 10.211.55.17:5555;
	}

	server{
		listen		80;
		server_name	10.211.55.17;
		
		location / {
			proxy_pass	http://cluster;
		}
	}

在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第5张图片

#退出nginx容器
exit

#重启nginx
docker restart 容器ID

在浏览器输入:http://10.211.55.17:1111/nacos/
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第6张图片
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第7张图片
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第8张图片

新建一个配置:
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第9张图片

#进入mysql5.6容器
docker exec -it 容器ID /bin/bash
#进入mysql
mysql -uroot -p123456
#切换到nacos_config数据库
use nacos_config;
查看config_info表
select * from config_info;

在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第10张图片

3个Nacos1.3容器+一个MySQL8.0.18容器+一个Nginx容器

配置MySQL8.0.18数据库

配置mysql数据库在上面那篇文章里有提到,这里就不再写了。
配置完数据库后启动数据库容器。

配置Nacos1.3

3个Nacos在同一台虚拟机上运行。

#启动第一台nacos(修改完后直接复制到linux上运行启动容器)
#NACOS_...开头的是配置nacos的信息,MYSQL_...是配置nacos连接的数据库的信息,JVM_...是配置nacos虚拟机的信息,根据你们自己的配置进行更改。
#10.211.55.17是我linux的IP地址
#端口只能修改对外暴露的端口号,nacos里的8848不能修改,如果使用NACOS_SERVER_PORT去修改里面的端口号,会启动后无法访问。
#和上面mysql5.6版的配置差不多
docker run -d \
--name nacos_11 \
--hostname=nacos_11 \
-e MODE=cluster \
-e NACOS_SERVERS="10.211.55.17:3333 10.211.55.17:4444 10.211.55.17:5555" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=10.211.55.17 \
-e MYSQL_SERVICE_PORT=3306 \
-e MYSQL_SERVICE_DB_NAME=nacos_config \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=123456 \
-e JVM_XMS=512m \
-e JVM_XMX=512m \
-e JVM_XMN=256m \
-e JVM_MS=32m \
-e JVM_MMS=80m \
-p 3333:8848 nacos/nacos-server

#启动第二台nacos
docker run -d \
--name nacos_22 \
--hostname=nacos_22 \
-e MODE=cluster \
-e NACOS_SERVERS="10.211.55.17:3333 10.211.55.17:4444 10.211.55.17:5555" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=10.211.55.17 \
-e MYSQL_SERVICE_PORT=3306 \
-e MYSQL_SERVICE_DB_NAME=nacos_config \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=123456 \
-e JVM_XMS=512m \
-e JVM_XMX=512m \
-e JVM_XMN=256m \
-e JVM_MS=32m \
-e JVM_MMS=80m \
-p 4444:8848 nacos/nacos-server

#启动第三台nacos
docker run -d \
--name nacos_33 \
--hostname=nacos_33 \
-e MODE=cluster \
-e NACOS_SERVERS="10.211.55.17:3333 10.211.55.17:4444 10.211.55.17:5555" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=10.211.55.17 \
-e MYSQL_SERVICE_PORT=3306 \
-e MYSQL_SERVICE_DB_NAME=nacos_config \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=123456 \
-e JVM_XMS=512m \
-e JVM_XMX=512m \
-e JVM_XMN=256m \
-e JVM_MS=32m \
-e JVM_MMS=80m \
-p 5555:8848 nacos/nacos-server




#然后把/home下的plugins目录分别传入到三个nacos容器中。
docker cp /home/plugins 容器ID:/home/nacos/
#把三个nacos容器都重启
docker restart 容器ID

这一步和上一篇文章单机版持久化的配置一样,没看的同学可以点这里看一下,mysql8的驱动也在上一篇文章里。

在这里插入图片描述
nginx容器是做mysql5.6版时启动的,因为配置一样,就没关掉,nginx配置也写在下面了,不用往上翻。

http://10.211.55.17:3333/nacos/
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第11张图片
http://10.211.55.17:4444/nacos/
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第12张图片
http://10.211.55.17:5555/nacos/
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第13张图片
并且里面也有我们在做单机持久化时保留的配置。

配置Nginx1.16.1

这里我拉取的镜像是Nginx1.16.1。

#拉取镜像
docker pull nginx:1.16.1

#启动nginx容器(对外暴露1111端口)
docker run -d --name nginx1.16.1 -p 1111:80 nginx:1.16.1

#进入nginx容器,修改配置
docker exec -it 容器ID /bin/bash
cd /etc/nginx
#因为nginx容器没有装vim,所以我们要先安装vim
apt-get update
apt-get install vim
#备份nginx.conf文件
cp nginx.conf nginx.conf.bk
#修改nginx.conf文件
vim nginx.conf

在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第14张图片

然后在http{…}里的#gzip on;下添加:

	upstream cluster{
		server 10.211.55.17:3333;
		server 10.211.55.17:4444;
		server 10.211.55.17:5555;
	}

	server{
		listen		80;
		server_name	10.211.55.17;
		
		location / {
			proxy_pass	http://cluster;
		}
	}

在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第15张图片

#退出nginx容器
exit

#重启nginx
docker restart 容器ID

在浏览器输入:http://10.211.55.17:1111/nacos/
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第16张图片
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第17张图片

新建一个配置:
在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第18张图片

#进入mysql8.0.18容器
docker exec -it 容器ID /bin/bash
#进入mysql
mysql -uroot -p123456
#切换到nacos_config数据库
use nacos_config;
查看config_info表
select * from config_info;

在Docker上用3个Nacos1.3容器+一个MySQL5和8容器+一个Nginx容器进行集群的具体操作(Nacos集群版)_第19张图片

nacos的配置终于结束了,搞得我心态都快崩了,4个视频用了2天,一直配置不成功,然后就一直在找资料,因为我用的mysql是8.0.18,就顺便把mysql5.6的配置也写了。

你可能感兴趣的:(遇到的坑)