在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数据库

配置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/
在这里插入图片描述
http://10.211.55.17:4444/nacos/
在这里插入图片描述
http://10.211.55.17:5555/nacos/
在这里插入图片描述
并且里面也有我们在做单机持久化时保留的配置。

配置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

在这里插入图片描述

然后在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;
		}
	}

在这里插入图片描述

#退出nginx容器
exit

#重启nginx
docker restart 容器ID

在浏览器输入:http://10.211.55.17:1111/nacos/
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

新建一个配置:
在这里插入图片描述

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

在这里插入图片描述

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/
在这里插入图片描述
http://10.211.55.17:4444/nacos/
在这里插入图片描述
http://10.211.55.17:5555/nacos/
在这里插入图片描述
并且里面也有我们在做单机持久化时保留的配置。

配置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

在这里插入图片描述

然后在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;
		}
	}

在这里插入图片描述

#退出nginx容器
exit

#重启nginx
docker restart 容器ID

在浏览器输入:http://10.211.55.17:1111/nacos/
在这里插入图片描述
在这里插入图片描述

新建一个配置:
在这里插入图片描述

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

在这里插入图片描述

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

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 19
    评论
运维项目经验是很宝贵的,以下是基于Nginx+Nacos+MySQL+Redis+RabbitMQ的运维项目经验: 1. Nginx Nginx是一款高性能的Web服务器和反向代理服务器。在运维过程中,需要对Nginx进行配置和监控,以确保其运行稳定。 - 配置 Nginx配置文件的路径为"/etc/nginx/nginx.conf",可以使用编辑器进行修改,如vi、nano等。在配置文件中,需要注意以下几点: - worker_processes:指定工作进程数,一般根据CPU核心数进行设置。 - pid:指定进程ID的存储路径。 - error_log:指定错误日志的存储路径。 - access_log:指定访问日志的存储路径。 - http:指定HTTP协议的配置项,如代理服务器、缓存等。 - server:指定服务器的配置项,如监听端口、域名等。 - 监控 可以使用Nginx自带的状态模块,通过访问"http://localhost:8080/nginx_status"来获取Nginx的状态信息。也可以通过第三方监控工具进行监控,如Zabbix、Grafana等。 2. Nacos Nacos是一款开源的服务发现、配置管理和动态DNS解析系统。在运维过程中,需要对Nacos进行部署和配置,以确保其正常运行。 - 部署 Nacos的部署可以使用Docker、Kubernetes等容器化技术进行部署,也可以直接下载二进制包进行部署。在部署过程中,需要注意以下几点: - 需要占用的端口:Nacos默认使用8848端口。 - 数据库配置:Nacos需要使用MySQL或者MariaDB作为数据存储的后端,需要进行相关的数据库配置。 - 配置文件的修改:Nacos的配置文件位于conf目录下,可以根据实际情况进行修改。 - 配置 在Nacos中,需要进行以下配置: - 服务注册:通过Nacos的API,将需要注册的服务注册到Nacos中。 - 配置管理:将需要管理的配置文件上传到Nacos中,并设置相应的命名空间、数据ID和分组。 3. MySQL MySQL是一款流行的关系型数据库管理系统。在运维过程中,需要对MySQL进行配置和监控,以确保其运行稳定。 - 配置 MySQL的配置文件的路径为"/etc/my.cnf",可以使用编辑器进行修改,如vi、nano等。在配置文件中,需要注意以下几点: - port:指定MySQL的监听端口。 - bind-address:指定MySQL的监听地址。 - max_connections:指定MySQL的最大连接数。 - log-error:指定错误日志的存储路径。 - slow-query-log:指定慢查询日志的存储路径。 - 监控 可以使用MySQL自带的状态变量和性能指标,通过执行"SHOW STATUS"和"SHOW VARIABLES"语句来获取MySQL的状态信息。也可以通过第三方监控工具进行监控,如Zabbix、Grafana等。 4. Redis Redis是一款高性能的内存数据库。在运维过程中,需要对Redis进行配置和监控,以确保其运行稳定。 - 配置 Redis的配置文件的路径为"/etc/redis/redis.conf",可以使用编辑器进行修改,如vi、nano等。在配置文件中,需要注意以下几点: - bind:指定Redis的监听地址。 - port:指定Redis的监听端口。 - daemonize:指定Redis是否以守护进程的方式运行。 - logfile:指定Redis的日志文件路径。 - maxclients:指定Redis的最大连接数。 - 监控 可以使用Redis自带的命令,如"INFO",来获取Redis的状态信息。也可以通过第三方监控工具进行监控,如Zabbix、Grafana等。 5. RabbitMQ RabbitMQ是一款开源的消息队列系统。在运维过程中,需要对RabbitMQ进行部署和配置,以确保其正常运行。 - 部署 RabbitMQ的部署可以使用Docker、Kubernetes等容器化技术进行部署,也可以直接下载二进制包进行部署。在部署过程中,需要注意以下几点: - 需要占用的端口:RabbitMQ默认使用5672端口。 - 用户名和密码:在RabbitMQ中,需要使用用户名和密码进行身份验证,需要进行相应的用户配置。 - 配置 在RabbitMQ中,需要进行以下配置: - 队列的创建:通过RabbitMQ的API,创建需要使用的队列。 - 交换机的创建:通过RabbitMQ的API,创建需要使用的交换机。 - 路由键的绑定:通过RabbitMQ的API,将队列和交换机进行绑定,并指定相应的路由键。 总体来说,基于Nginx+Nacos+MySQL+Redis+RabbitMQ的运维项目经验需要对以上组件进行深入理解和熟练掌握,才能更好地进行运维管理。在实践中,需要不断积累经验和总结,以便能够更好地应对各种问题和挑战。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 19
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值