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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/413823.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[python]裁剪文件夹中所有pdf文档并按名称保存到指定的文件夹

最近在写论文的实验部分,由于latex需要pdf格式的文档,审稿专家需要对pdf图片进行裁剪放大,以保证图片质量。 原图: 裁剪后的图像: 代码粘贴如下。将input_folder和output_folder替换即可。(x1, y1), (x2…

【数据结构与算法】排序算法:冒泡排序,冒泡排序优化,选择排序、选择排序优化

目录 一、冒泡排序 1、冒泡排序思想 2、冒泡排序算法的性能分析 代码实现: 二、选择排序 1、选择排序思想 2、选择排序算法的性能分析 代码实现: 一、冒泡排序 1、冒泡排序思想 冒泡排序的基本思想是通过相邻元素之间的比较和交换来逐步将最大…

IP地址转换:点分十进制数与十进制数

目录 引言一、十进制转换为IP地址1.思路2.示例代码 二、IP地址转换为十进制数1.思路2.示例代码 引言 这个ip地址互换考的还是比较多的,尤其是你做网络方面的工作的话,这肯定是会问你的。本文主要介绍了一个十进制数与点分十进制的ip地址互换的过程。话不…

【Alibaba工具型技术系列】「EasyExcel技术专题」实战技术针对于项目中常用的Excel操作指南

这里写目录标题 EasyExcel教程Maven依赖 EasyExcel API分析介绍EasyExcel 注解通用参数ReadWorkbook(理解成excel对象)参数ReadSheet(就是excel的一个Sheet)参数注解参数通用参数 WriteWorkbook(理解成excel对象&#…

DBA技术栈MongoDB:简介

1.1 什么是MongoDB? MongoDB是一个可扩展、开源、表结构自由、用C语言编写且面向文档的数据库,旨在为Web应用程序提供高性能、高可用性且易扩展的数据存储解决方案。 MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当…

【前端设计】输入框

欢迎来到前端设计专栏&#xff0c;本专栏收藏了一些好看且实用的前端作品&#xff0c;使用简单的html、css语法打造创意有趣的作品&#xff0c;为网站加入更多高级创意的元素。 html <!DOCTYPE html> <html lang"en"> <head><meta charset&quo…

Redis--Zset使用场景举例(滑动窗口实现限流)

文章目录 前言什么是滑动窗口zset实现滑动窗口小结附录 前言 在Redis–Zset的语法和使用场景举例&#xff08;朋友圈点赞&#xff0c;排行榜&#xff09;一文中&#xff0c;提及了redis数据结构zset的指令语法和一些使用场景&#xff0c;今天我们使用zset来实现滑动窗口限流&a…

蓝天采集器,功能逆天的网站数据抓取神器,轻松助你成为采集达人,附带搭建配置文档

源码介绍 蓝天采集器是一款专为web服务器打造的数据采集神器。与市面上常见的桌面端采集工具&#xff08;如火车头等&#xff09;相比&#xff0c;蓝天采集器在易用性、上手成本和灵活性方面更胜一筹。它部署简便&#xff0c;无需复杂的设置&#xff0c;即可迅速融入您的web服…

python统计分析——样本均值的分布(上)

参考资料&#xff1a;用python动手学统计学 1、导入库 import numpy as np import pandas as pd import scipy as sp from scipy import statsfrom matplotlib import pyplot as plt import seaborn as sns 2、设置总体 本次研究总体是均值为4、标准差为0.8的正态总体。 po…

python222网站实战(SpringBoot+SpringSecurity+MybatisPlus+thymeleaf+layui)-热门帖子推荐显示实现

锋哥原创的SpringbootLayui python222网站实战&#xff1a; python222网站实战课程视频教程&#xff08;SpringBootPython爬虫实战&#xff09; ( 火爆连载更新中... )_哔哩哔哩_bilibilipython222网站实战课程视频教程&#xff08;SpringBootPython爬虫实战&#xff09; ( 火…

每日一题——LeetCode1266.访问所有点的最小时间

方法一 个人方法 找规律&#xff1a; 当前的点为current&#xff0c;下一个点为next&#xff0c;x为两点横坐标之间距离&#xff0c;y为两点竖坐标之间距离 1、当两点横坐标相同时&#xff0c;两点距离为y 2、当两点竖坐标相同时&#xff0c;两点距离为x 3、当两点x与y相同…

回归预测 | Matlab实现SSA-BP麻雀算法优化BP神经网络多变量回归预测

回归预测 | Matlab实现SSA-BP麻雀算法优化BP神经网络多变量回归预测 目录 回归预测 | Matlab实现SSA-BP麻雀算法优化BP神经网络多变量回归预测预测效果基本描述程序设计参考资料 预测效果 基本描述 1.Matlab实现SSA-BP麻雀算法优化BP神经网络多变量回归预测&#xff1b; 2.数据…