注1:小插曲
由于虚拟机分配的内存为1G,开到第四个容器时,由于内存不够导致容器启动失败,重新设置4G内存后启动成功
ok,正式进入主题!
①mysql镜像(docker mysql:5.7的持久化存储及远程连接)
docker pull mysql/mysql-server:5.7
注:后面的mysql标签是版本号,可选择,有:5.5/5.6/5.7/8.0
mkdir -p /data/mysql/{conf,data}
建立目录用来放置mysql数据的
添加到mysql中的conf目录下(conf就是前面我们自己创建的)
docker run -p 3306:3306 \
--name mysql \
-v /data/mysql/conf/my.cnf:/etc/my.cnf \
-v /data/mysql/data:/var/lib/mysql \
--privileged=true \
--restart=always \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql/mysql-server:5.7
-p 3306:3306:宿主机端口:容器端口
--name mysql:容器名字
-v:挂载宿主机的一个目录, 持久化存储的关键所在,将主机目录挂载到容器对应目录,分别是:配置文件、日志文件、数据文件
-v /data/mysql/conf:/etc/mysql/conf.d
-v /data/mysql/logs:/logs
-v /data/mysql/data:/var/lib/mysq
--privileged=true:使用该参数,container内的root拥有真正的root权限, 否则,container内的root只是外部的一个普通用户权限
--restart=always:容器自动启动参数,其值可以为[no,on-failure,always]
no为默认值,表示容器退出时,docker不自动重启容器
on-failure表示,若容器的退出状态非0,则docker自动重启容器,还可以指定重启次数,若超过指定次数未能启动容器则放弃
always表示,只要容器退出,则docker将自动重启容器
-e MYSQL_ROOT_PASSWORD=123456:设置root的密码
-d mysql/mysql-server:5.7:后台启动模式及使用的镜像
注意:
最好把没用的容器都清除掉,以防出现问题
清除所有容器:
docker rm -f $(docker ps -aq)
以及查看相关端口号是否被占用:
lsof -i:查看的端口号
查看某个端口的运行状态:
systemctl status mysqld
关闭某个端口号的运行状态:
systemctl stop mysqld
①进入mysql5.7容器
docker exec -it mysql /bin/bash
②登录mysql服务器,之后输入
mysql -u root -p;
mysql密码:123456
③给用户授权
grant all privileges on *.* to root@'%' identified by '123456' with grant option;
查看数据库字符集:
show variables like'character%';
这三步操作步骤展示:
⑥.创建数据库nacos_config,并进行初始化
运行脚本
OK,现在如果想用外网访问内部容器的可以使用桥接网络模式进行访问:
步骤:【目前网络模式为:bridge】
docker pull nacos/nacos-server:1.1.4
拉取成功!
docker run -d \
-e PREFER_HOST_MODE=ip \
-e MODE=standalone \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_MASTER_SERVICE_HOST=172.17.0.2 \
-e MYSQL_MASTER_SERVICE_PORT=3306 \
-e MYSQL_MASTER_SERVICE_USER=root \
-e MYSQL_MASTER_SERVICE_PASSWORD=123456 \
-e MYSQL_MASTER_SERVICE_DB_NAME=nacos_config \
-e MYSQL_SLAVE_SERVICE_HOST=172.17.0.2 \
-p 8848:8848 \
--name nacos \
--restart=always \
nacos/nacos-server:1.1.4
参数解析:
docker run -d \ #后台支行模式
-e PREFER_HOST_MODE=hostname \ #是否支持hostname,可选项:hostname/ip,默认值ip
-e MODE=standalone \ #cluster模式/standalone模式,可选项:cluster/standalone,默认值cluster
-e SPRING_DATASOURCE_PLATFORM=mysql \ #standalone支持 mysql,可选项:mysql/empty,默认值empty
-e MYSQL_MASTER_SERVICE_HOST=172.17.0.2 \ #mysql主节点数据库IP,这有个坑:因为网络模式为bridge重启系统后IP会变导致nacos的再次启动失败
-e MYSQL_MASTER_SERVICE_PORT=3306 \ #mysql主节点端口
-e MYSQL_MASTER_SERVICE_USER=root \ #数据库用户名
-e MYSQL_MASTER_SERVICE_PASSWORD=123456 \ #数据库密码
-e MYSQL_MASTER_SERVICE_DB_NAME=nacos_config \ #mysql主节点数据库名
-e MYSQL_SLAVE_SERVICE_HOST=172.17.0.2 \ #mysql从节点数据库IP
-p 8848:8848 \ #主机端口映射
--name nacos \ #容器名
--restart=always \ #容器自动启动
nacos/nacos-server:1.1.4 #镜像名注意:
注1:由于没有配置mysql的主、从集群、本以为MYSQL_SLAVE_SERVICE_HOST可以不用配置,但通过查看nacos容器内的config/application.properties文件,
会发现这此值未设置默认值,所以会导致启动报错,容器启动不起来,这里可以与主数据库一致。还有一个解决方案就是
##删除从库的配置,将配置数据库数量改为1也行,后面例子就是这样做的
//-e MYSQL_SLAVE_SERVICE_HOST=172.17.0.2 \
-e MYSQL_DATABASE_NUM=1 \注2:相关命令
#停止并删除所有容器
docker stop nacos && docker rm nacos
#docker logs-查看docker容器日志
docker logs -f -t --tail=100 nacos
ip:8848/nacos
http://192.168.3.128:8848/nacos
登录进来
查看容器的运行情况:
docker logs -f -t --tail=100 nacos
启动成功则显示success:
这一步完成呢就代表着nacos搭建完成了,可以简单的测试一下。
①进入控制器,并添加测试数据,新建配置test.yml并添加数据
username:zs
②查看数据库是否更新
数据库配置没有问题的话可以在表config_info中看到刚才新增的配置信息
③在Linux控制台输入一下命令获得配置
curl -X GET "http://192.168.3.128:8848/nacos/v1/cs/configs?dataId=test.yml&group=DEFAULT_GROUP"
即可获得配置信息。
这样就拿到刚才我们所编辑的内容啦!
但是这样是非常不安全的,nacos中的ip地址端口以及相关配置信息都会被外网所访问,所以我们会进入下一个环节,改为内网集群部署:
优点:具备安全性和稳定性。
还是老规矩为了接下来的演示,我将所有容器都删除,避免出现问题。
删除所有容器:
docker rm -f $(docker ps -aq)
既然容器删了,那么数据库也就连接不了了。
步骤:【目前网络模式为:自定义网络mynet】
docker run \
--name mysql \
--net mynet \
--ip 192.168.0.11 \
-v /data/mysql/conf/my.cnf:/etc/my.cnf \
-v /data/mysql/data:/var/lib/mysql \
--privileged=true \
--restart=always \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql/mysql-server:5.7
①检查是否启动成功:
docker ps
②守护进程方式进入容器
docker exec -it mysql /bin/bash
③输入数据库账户和密码
mysql -u root -p
ex123456
继续输入 :
show databases;
这里我们可以看到在创建前面那个容器的时候创建的nacos_config文件,然后删除容器了,重新创建容器时,同样也会有这个文件,那么是什么原因呢?
答:是因为挂载,在使用桥接模式挂载容器的时候,也就是创建第一个容器的时候,我们在容器中创建了该文件,那么既然挂载了,所有宿主机也会实时更新,创建同样的文件;即使把容器删除,宿主机中的文件是不会变动的,而这时候我们又重新创建了一个容器使用自定义网络模式挂载宿主机,那么容器就会自动创建该文件。
创建集群节点1:
docker run -d \
--net mynet \
--ip 192.168.0.21 \
-e PREFER_HOST_MODE=ip \
-e MODE=cluster \
-e NACOS_SERVERS="192.168.0.22:8848 192.168.0.23:8848" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_MASTER_SERVICE_HOST=192.168.0.11 \
-e MYSQL_MASTER_SERVICE_PORT=3306 \
-e MYSQL_MASTER_SERVICE_USER=root \
-e MYSQL_MASTER_SERVICE_PASSWORD=123456 \
-e MYSQL_MASTER_SERVICE_DB_NAME=nacos_config \
-e MYSQL_DATABASE_NUM=1 \
-e NACOS_SERVER_PORT=8848 \
--name nacos01 \
--restart=always \
nacos/nacos-server:1.1.4
创建集群节点2:
docker run -d \
--net mynet \
--ip 192.168.0.22 \
-e PREFER_HOST_MODE=ip \
-e MODE=cluster \
-e NACOS_SERVERS="192.168.0.21:8848 192.168.0.23:8848" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_MASTER_SERVICE_HOST=192.168.0.11 \
-e MYSQL_MASTER_SERVICE_PORT=3306 \
-e MYSQL_MASTER_SERVICE_USER=root \
-e MYSQL_MASTER_SERVICE_PASSWORD=123456 \
-e MYSQL_MASTER_SERVICE_DB_NAME=nacos_config \
-e MYSQL_DATABASE_NUM=1 \
-e NACOS_SERVER_PORT=8848 \
--name nacos02 \
--restart=always \
nacos/nacos-server:1.1.4
创建集群节点3:
docker run -d \
--net mynet \
--ip 192.168.0.23 \
-e PREFER_HOST_MODE=ip \
-e MODE=cluster \
-e NACOS_SERVERS="192.168.0.21:8848 192.168.0.22:8848" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_MASTER_SERVICE_HOST=192.168.0.11 \
-e MYSQL_MASTER_SERVICE_PORT=3306 \
-e MYSQL_MASTER_SERVICE_USER=root \
-e MYSQL_MASTER_SERVICE_PASSWORD=123456 \
-e MYSQL_MASTER_SERVICE_DB_NAME=nacos_config \
-e MYSQL_DATABASE_NUM=1 \
-e NACOS_SERVER_PORT=8848 \
--name nacos03 \
--restart=always \
nacos/nacos-server:1.1.4
容器创建完之后,不代表就启动了,输入以下命令可以查看是否跑完:
查看docker容器日志:
docker logs -f -t --tail=100 nacos
直到出现success才是启动完毕!
也可以通过访问任何一节点进行查看:
curl http://192.168.0.21:8848/nacos/index.html
curl http://192.168.0.22:8848/nacos/index.html
curl http://192.168.0.23:8848/nacos/index.html
如果出现拒绝访问则代表启动失败,可以删除重新创建了,若出现以下效果则代表启动成功:
同样的当我们在linux控制台输入以下内容,是可以看到text.yml文件中的内容的,只不过外网访问不到了:
curl -X GET "http://192.168.0.23:8848/nacos/v1/cs/configs?dataId=test.yml&group=DEFAULT_GROUP"
所以这时候如何才能使外网能够访问我们内部呢,这里就需要使用到Nginx动态代理nacos集群啦!
docker run \
--name mynginx \
-d -p 80:80 \
-v /data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /data/nginx/log:/var/log/nginx \
-v /data/nginx/html:/usr/share/nginx/html \
nginx:latest
docker network connect mynet mynginx
首先要进入nginx的目录中去,找到原有的配置文件进行备份
然后将已经修改好的配置文件添加进去
添加成功!
已经编辑好的nginx.conf文件中的内容:
由于修改了容器中的配置文件,所以需要重启容器:
docker restart mynginx
浏览器输入:192.168.3.128/nacos/
访问成功!地址栏不会出现端口号以及nacas的相关配置信息。
在nginx.conf文件中,一共配置了三个节点,即使其中的一个节点挂了失效了,会重新找到其他的节点,依然能够访问成功!
本篇内容分享到此结束,我们下期再见!