一、配置网络
为什么要配置网络?因为 Nacos 内要连接MySQL数据库的,我的 MySQL 数据库也是用 Docker启动的,所以2个容器间要通信是需要配置他们使用相同的网络。这个操作要在启动Nacos容器之前。
注意:这里配置的网络只在镜像内部生效,外部的访问IP是不变,比如我的访问数据库和Nacos 的IP都是 127.0.0.1
1、查看原有网络:
docker network ls
2、创建自己的网络:
docker network create --driver bridge --subnet 192.168.0.0/16 --gateway 192.168.0.1 mynetwork
# --driver bridge 设置桥接模式 # --subnet 192.168.0.0/16 子网掩码,16表示65535个网络,192.168.0.2~~192.168.255.255 # --gateway 192.168.0.1 网关
查看创建后的网络多了一个mynetwork
3、查看mynetwork的网络详情
docker network inspect mynetwork
二、安装mysql
1、拉取mysql镜像
docker pull mysql:8.0
2、查看镜像
3、创建mysql容器
指定使用的网络是刚才创建的 mynetwork。这个操作是为了保证 MySQL8 和 Nacos 属于一个网段内
docker run -itd --name mysql-8 -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 --net mynetwork mysql:8.0 --lower_case_table_names=1
--net mynetwork 就是指定创建mysql容器时,使用mynetwork网络
4、查看mynetwork网络详情
docker network inspect mynetwork
[ { "Name": "mynetwork", "Id": "f4ba5f0abfe9f8b46ff8f7df5e7d877a2a292282547758cb5bd88da5d6049be8", "Created": "2024-01-09T09:36:59.555378902Z", "Scope": "local", "Driver": "bridge", "EnableIPv6": false, "IPAM": { "Driver": "default", "Options": {}, "Config": [ { "Subnet": "192.168.0.0/16", "Gateway": "192.168.0.1" } ] }, "Internal": false, "Attachable": false, "Ingress": false, "ConfigFrom": { "Network": "" }, "ConfigOnly": false, "Containers": { "9e414a95d43ddae6373f8539cd6720bba0c9d87d9e85fb8acc9f064f12c00752": { "Name": "mysql-8", "EndpointID": "d773fb1392eed8376380e5dfb94046a610d3cebee213dd9ea9abd17f3c4c9ea7", "MacAddress": "02:42:c0:a8:00:02", "IPv4Address": "192.168.0.2/16", "IPv6Address": "" } }, "Options": {}, "Labels": {} } ]
三、安装nacos
1、拉取nacos镜像
docker pull nacos/nacos-server
2、查看镜像
3、创建nacos容器
Windows PowerShell 下是不支持命令换行的,为了方便展示,改成了下面的格式。
启动命令时,指定了MySQL8的IP地址, 并且指定在 mynetwork 的网络内,至于数据库的连接参数,因为 Windows PowerShell 下是不支持使用 & 符号的,所以要用双引号括起来。
docker run --env MODE=standalone --env SPRING_DATASOURCE_PLATFORM=mysql --env MYSQL_DATABASE_NUM=1 --env MYSQL_SERVICE_HOST=192.168.0.2 --env MYSQL_SERVICE_PORT=3307 --env MYSQL_SERVICE_DB_NAME=nacos_db --env MYSQL_SERVICE_DB_PARAM=characterEncoding=utf8"&"connectTimeout=1000"&"socketTimeout=3000"&"autoReconnect=true"&"useUnicode=true"&"useSSL=false"&"serverTimezone=UTC --env MYSQL_SERVICE_USER=root --env MYSQL_SERVICE_PASSWORD=123456 --env JVM_XMS=512m --env JVM_XMX=512m --env JVM_XMN=256m --env JVM_MS=64m --env JVM_MMS=256m --name mynacos -d -p 8849:8848 --net mynetwork nacos/nacos-server
docker run --env MODE=standalone
--env SPRING_DATASOURCE_PLATFORM=mysql
--env MYSQL_DATABASE_NUM=1
--env MYSQL_SERVICE_HOST=192.168.0.2
--env MYSQL_SERVICE_PORT=3307
--env MYSQL_SERVICE_DB_NAME=nacos_db
--env MYSQL_SERVICE_DB_PARAM=characterEncoding=utf8"&"connectTimeout=1000"&"socketTimeout=3000"&"autoReconnect=true"&"useUnicode=true"&"useSSL=false"&"serverTimezone=UTC
--env MYSQL_SERVICE_USER=root
--env MYSQL_SERVICE_PASSWORD=123456
--env JVM_XMS=512m
--env JVM_XMX=512m
--env JVM_XMN=256m
--env JVM_MS=64m
--env JVM_MMS=256m
--name mynacos -d -p 8849:8848
--net mynetwork nacos/nacos-server
4、访问nacos
http://127.0.0.1:8849/nacos/
相关链接
发表评论