前面的话
默认你已经懂 Docker、docker-compose
Nacos版本:v2.2.3
MySQL 版本:8.2.0
一、下载
- 打开
Nacos
官网
官网地址:官网
- 点击手册
- 左侧
Nacos Docker
- 克隆项目到本地
# 克隆项目,如果提示连接不到 github 请自行解决git clone https://github.com/nacos-group/nacos-docker.git
# 进入项目目录cd nacos-docker
**
注意:
**
如果这里你git clone 报错:fatal: unable to access*** github Failure when receiving data from
请参考我这篇文章配置代理(前提是你有高科技,否则自行到github仓库下载源码或者使用第三方github加速服务):
点击跳转
- 可以看到项目已经下载到本地
- 使用 IDE打开项目,方便编辑(这里我使用 IDEA 打开)
二、创建数据库(以 MySQL8 为例)
因为我本地已经有数据库了,不打算使用 nacos-docker项目帮我用 Docker 创建数据库,所以我需要修改一下它的 docker-compose.yaml文件,也需要手动在我本地创建存储 nacos 数据的数据库。
- 找到官方的 MySQL 表结构文件(直接看图)
- 手动创建数据库(我使用 Navicat16 操作)
排序规则我不选,让它默认就好了
- 执行官方给的 sql 文件
- 放入到 Navicat 中执行
- 可以看到创建好的数据表
三、修改项目配置
本人本地配置,所以只配置单机模式,集群模式请自行配置多个并修改相关的模式
- 修改
example/standalone-mysql-8.yaml
文件
去掉 MySQL 部分的配置,因为我们不需要docker再帮我部署 MySQL 数据库了
代码,可直接拷贝
version:"3.8"services:nacos:image: nacos/nacos-server:${NACOS_VERSION}container_name: nacos-standalone-mysql # 这里写你想要的容器名称env_file:- ../env/nacos-standlone-mysql.env
volumes:- ./standalone-logs/:/home/nacos/logs # 这里看你需求修改成你自己的目录映射,这里我演示,不改ports:-"8848:8848"-"9848:9848"restart: always
network_mode: host # 加上这一行,使用 host 模式,这样子容器内部直接访问 localhost 就是宿主机本身,方便一些,反正端口不冲突
- 修改
env/nacos-standlone-mysql.env
文件
代码:
PREFER_HOST_MODE=hostname
MODE=standalone # 单机模式
SPRING_DATASOURCE_PLATFORM=mysql # 使用 MySQL 作为存储
MYSQL_SERVICE_HOST=127.0.0.1 # 本机的话直接使用这个或者 localhost,刚刚设置的 host 网络模式可以直接访问到宿主机
MYSQL_SERVICE_DB_NAME=nacos_config # 存储 Nacos 配置信息的数据库名称
MYSQL_SERVICE_PORT=3306 # 数据库访问端口
MYSQL_SERVICE_USER=root # 访问你数据库的用户,默认用 root 即可,你设置有别的用户也可以
MYSQL_SERVICE_PASSWORD=root # root 密码
# 下面这行可以跟着我写,保险起见,加上时区,官方给的只有 UTC 时区在 .properties 中
MYSQL_SERVICE_DB_PARAM=characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true
如果你需要开启鉴权,则继续追加以下配置在上面的内容之后
开启之后登录 nacos 需要账号密码:默认都是
nacos
# 开启鉴权
NACOS_AUTH_IDENTITY_KEY=2222
NACOS_AUTH_IDENTITY_VALUE=2222
NACOS_AUTH_TOKEN=SecretKey012345678901234567890123456789012345678901234567890123456789
NACOS_AUTH_SYSTEM_TYPE=nacos
NACOS_AUTH_ENABLE=true
- 修改
mysql.env
文件
代码:
MYSQL_ROOT_PASSWORD=root
MYSQL_DATABASE=nacos_config
MYSQL_USER=root
MYSQL_PASSWORD=root
LANG=C.UTF-8
- 修改
example/init.d/application.properties
我没仔细看这个文件是否有被加载(直觉是没加载这个文件的,使用的是
build/conf/application.properties
这个文件的配置,这个文件都是引用外部定义好的变量,不需要手动修改),保险起见还是修改一下
修改后:
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true
db.user.0=root
db.password.0=root
- 以上修改之后就完成了
四、构建镜像&运行容器
以下是在项目根目录下执行命令
# 执行以下命令,会以standalone-mysql-8.yaml中定义的容器信息进行创建并运行容器docker-compose-f example/standalone-mysql-8.yaml up # 为了方便看控制台,我们用这个演示# 或者docker-compose-f example/standalone-mysql-8.yaml up -d# 后台启动
执行命令后,容器部署成功:
查看容器:
这里我使用的不是 DockerDesktop,所以界面是不一样的。我这个是 OrbStack,相对于 DockerDesktop 比较节约资源也更加快。除了界面没那么美观,端口映射没DockerDesktop 那么直观,其它还好。
有想了解的小伙伴可以去官网看看:https://orbstack.dev/ 或者点击 官网链接 跳转
- 注意:OrbStack 暂时不支持 Windows 平台
浏览器访问地址:http://localhost:8848/nacos
或直接点击跳转地址
我们再新建一个命名空间测试
查看数据库:
五、完成
至此,我们就完成了使用 Docker 部署 Nacos 容器。如果帮助到你们别忘了点赞哦~
版权归原作者 落魄程序员在线炒粉 所有, 如有侵权,请联系我们删除。