docker镜像安装nacos并配置数据库、nacos鉴权

一、查看Nacos发布版本并下载镜像

nacos官方地址:https://nacos.io/download/nacos-server/
github地址:https://github.com/alibaba/nacos
下载最新镜像:

docker pull nacos/nacos-server

二、配置Nacos并挂在本地目录

1.新建目录并挂载nacos

只需要新建conf的挂载即可,其他目录的挂载会自动生成目录(如logs)

mkdir /mydata/nacos/conf

2.把nacos容器中的/home/nacos/conf文件夹拷贝

上述步骤2中,已经启动了nacos容器,我们把容器中的配置文件拷贝出来即可
linux环境

docker cp nacos:/home/nacos/conf/ /mydata/nacos/

windows环境

docker cp nacos:/home/nacos/conf/ D:/docker/nacos/

在这里插入图片描述

3.删除容器

docker stop nacos
docker remove nacos

4.挂在本地目录并重启Nacos容器

linux挂在目录

docker run --name nacos -p 8848:8848 \
-p 9848:9848 -p 9849:9849 \
--privileged=true \
--restart=always \
-e MODE=standalone \
-e PREFER_HOST_MODE=hostname \
-e JVM_XMS=256m \
-e JVM_XMX=1024m \
-v /mydata/nacos/logs:/home/nacos/logs \
-v /mydata/nacos/conf/:/home/nacos/conf \
-d nacos/nacos-server

windows挂在目录

docker run --name nacos -p 8848:8848 -p 9848:9848 -p 9849:9849 --privileged=true --restart=always -e MODE=standalone -e PREFER_HOST_MODE=hostname -e JVM_XMS=256m -e JVM_XMX=1024m -v D:/docker/nacos/logs:/home/nacos/logs -v D:/docker/nacos/conf:/home/nacos/conf -d nacos/nacos-server

参数解析

-p 8848:8848 # 宿主机端口:容器端口
–name nacos # 容器名字
–privileged=true # 使用该参数,container内的root拥有真正的root权限
–network host # 设置属于该容器的网络
–restart=always # 总是重启
-e PREFER_HOST_MODE=hostname # 是否支持 hostname,可选参数为hostname/ip,默认值是当前宿主机的ip
-e MODE=standalone # 使用 standalone模式(单机模式),MODE值有cluster模式/standalone模式两种
-e JVM_XMS=256m # -Xms 为jvm启动时分配的内存[我设置会导致nacos启动异常,无法访问,故没有设置]
-e JVM_XMX=1024m # -Xmx 为jvm运行过程中分配的最大内存[我设置会导致nacos启动异常,无法访问,故没有设置]
-d nacos/nacos-server # 后台启动模式及使用的镜像
-v /mydata/nacos/logs:/home/nacos/logs \

-v:挂载宿主机的一个目录, 持久化存储的关键所在,将主机目录挂载到容器对应目录,分别是:配置文件、日志文件
–restart=always:容器自动启动参数,其值可以为[no,on-failure,always]
no为默认值,表示容器退出时,docker不自动重启容器
on-failure表示,若容器的退出状态非0,则docker自动重启容器,还可以指定重启次数,若超过指定次数未能启动容器则放弃
always表示,只要容器退出,则docker将自动重启容器

5.配置mysql数据库

方式一:进入nacos容器修改配置
docker exec -it nacos bash
vi conf/application.properties
在这里插入图片描述
方式二:修改宿主挂载目录的配置文件即可

vi /mydata/nacos/conf/application.properties

windows环境可以直接在挂在目录中(我当前的挂在地址:D:\docker\nacos\conf)application.properties文件中修改即可

spring.sql.init.platform=${SPRING_DATASOURCE_PLATFORM:mysql}
nacos.cmdb.dumpTaskInterval=3600
nacos.cmdb.eventTaskInterval=10
nacos.cmdb.labelTaskInterval=300
nacos.cmdb.loadDataAtStart=false
db.num=${MYSQL_DATABASE_NUM:1}
db.url.0=jdbc:mysql://172.16.0.163:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useSSL=false
db.user.0=root
db.password.0=luckserver

在这里插入图片描述
application.properties配置文件完整配置内容:

# spring
server.servlet.contextPath=${SERVER_SERVLET_CONTEXTPATH:/nacos}
server.contextPath=/nacos
server.port=${NACOS_APPLICATION_PORT:8848}
server.tomcat.accesslog.max-days=30
server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %D %{User-Agent}i %{Request-Source}i
server.tomcat.accesslog.enabled=${TOMCAT_ACCESSLOG_ENABLED:false}
server.error.include-message=ALWAYS
# default current work dir
server.tomcat.basedir=file:.
#*************** Config Module Related Configurations ***************#
### Deprecated configuration property, it is recommended to use `spring.sql.init.platform` replaced.
#spring.datasource.platform=${SPRING_DATASOURCE_PLATFORM:}
spring.sql.init.platform=${SPRING_DATASOURCE_PLATFORM:mysql}
nacos.cmdb.dumpTaskInterval=3600
nacos.cmdb.eventTaskInterval=10
nacos.cmdb.labelTaskInterval=300
nacos.cmdb.loadDataAtStart=false
db.num=${MYSQL_DATABASE_NUM:1}
db.url.0=jdbc:mysql://172.16.0.163:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useSSL=false
db.user.0=root
db.password.0=luckserver
## DB connection pool settings
db.pool.config.connectionTimeout=${DB_POOL_CONNECTION_TIMEOUT:30000}
db.pool.config.validationTimeout=10000
db.pool.config.maximumPoolSize=20
db.pool.config.minimumIdle=2
### The auth system to use, currently only 'nacos' and 'ldap' is supported:
nacos.core.auth.system.type=${NACOS_AUTH_SYSTEM_TYPE:nacos}
### worked when nacos.core.auth.system.type=nacos
### The token expiration in seconds:
nacos.core.auth.plugin.nacos.token.expire.seconds=${NACOS_AUTH_TOKEN_EXPIRE_SECONDS:18000}
### The default token:
nacos.core.auth.plugin.nacos.token.secret.key=${NACOS_AUTH_TOKEN:}
### Turn on/off caching of auth information. By turning on this switch, the update of auth information would have a 15 seconds delay.
nacos.core.auth.caching.enabled=${NACOS_AUTH_CACHE_ENABLE:false}
nacos.core.auth.enable.userAgentAuthWhite=${NACOS_AUTH_USER_AGENT_AUTH_WHITE_ENABLE:false}
nacos.core.auth.server.identity.key=${NACOS_AUTH_IDENTITY_KEY:}
nacos.core.auth.server.identity.value=${NACOS_AUTH_IDENTITY_VALUE:}
## spring security config
### turn off security
nacos.security.ignore.urls=${NACOS_SECURITY_IGNORE_URLS:/,/error,/**/*.css,/**/*.js,/**/*.html,/**/*.map,/**/*.svg,/**/*.png,/**/*.ico,/console-fe/public/**,/v1/auth/**,/v1/console/health/**,/actuator/**,/v1/console/server/**}
# metrics for elastic search
management.metrics.export.elastic.enabled=false
management.metrics.export.influx.enabled=false
nacos.naming.distro.taskDispatchThreadCount=10
nacos.naming.distro.taskDispatchPeriod=200
nacos.naming.distro.batchSyncKeyCount=1000
nacos.naming.distro.initDataRatio=0.9
nacos.naming.distro.syncRetryDelay=5000
nacos.naming.data.warmup=true
nacos.console.ui.enabled=true
nacos.core.param.check.enabled=true

#nacos权限配置
nacos.core.auth.enabled=true
nacos.core.auth.server.identity.key=${NACOS_AUTH_IDENTITY_KEY:example}
nacos.core.auth.server.identity.value=${NACOS_AUTH_IDENTITY_KEY:example}
nacos.core.auth.plugin.nacos.token.secret.key=${NACOS_AUTH_TOKEN:SecretKey01234567890123456789012345345678999987654901234567890123456789}

6.dokcer启动mysql

Linux Docker安装mysql并持久化,参考以下地址:

https://blog.youkuaiyun.com/ywj_csdn/article/details/140054883?spm=1001.2014.3001.5501

windows Docker安装mysql并持久化命令:

docker run --name mysql-localhost -p 3306:3306 -v d:/docker/mysql/5.7/conf:/etc/mysql/conf.d -v d:/docker/mysql/5.7/logs:/etc/mysql/logs -v d:/docker/mysql/5.7/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=luckserver -d mysql:5.7 --default-authentication-plugin=mysql_native_password

7.mysql建立nacos数据库并执行相关语句

nacos服务所需的建表语句在挂载的目录中可以获取,以windows环境为例(在D:\docker\nacos\conf目录下)存在mysql-schema.sql文件
在这里插入图片描述

三、配置Nacos鉴权

在挂载的配置文件目录中(以windows环境为例在D:\docker\nacos\conf目录)的application.properties文件下新增如下配置:

#nacos权限配置
nacos.core.auth.enabled=true
nacos.core.auth.server.identity.key=${NACOS_AUTH_IDENTITY_KEY:example}
nacos.core.auth.server.identity.value=${NACOS_AUTH_IDENTITY_KEY:example}
nacos.core.auth.plugin.nacos.token.secret.key=${NACOS_AUTH_TOKEN:SecretKey01234567890123456789012345345678999987654901234567890123456789}

三、启动nacos并访问

docker restart nacos

http://IP地址:8848/nacos
默认账号:nacos
默认密码:nacos


在大佬博客基础上做了补充。
参考:https://blog.youkuaiyun.com/zqskr_/article/details/138952135

<think>我们正在处理用户关于在Docker配置Nacos连接数据库的问题。根据引用内容,我们有以下信息:引用[1]提到了Docker部署Nacos的两种方式:非数据库数据库版本,提到了连接同一个服务器Docker中MySQL的问题。引用[2]提供了docker安装nacos配置数据库的步骤,包括数据库表的创建和重启容器。引用[3]则提到了创建自定义网络、挂载目录以及配置文件的修改,指出在连接数据库时不能使用127.0.0.1,因为容器有特定的IP。根据这些信息,我们可以整理出在Docker配置Nacos连接数据库的步骤:1.准备数据库(MySQL):在某个地方运行MySQL服务,可以是宿主机上的MySQL,也可以是另一个Docker容器中的MySQL。2.初始化数据库:使用Nacos提供的SQL脚本(mysql-schema.sql)创建所需的数据库和表。3.修改Nacos配置文件:在Nacos配置文件中指定数据库连接信息。4.启动Nacos容器:在启动容器时,通过挂载配置文件或设置环境变量来使用数据库配置。具体步骤:步骤1:准备MySQL服务如果使用Docker运行MySQL,可以执行以下命令:```bashdockerrun--namemysql-eMYSQL_ROOT_PASSWORD=root-p3306:3306-dmysql:5.7```然后进入容器或使用客户端工具创建数据库(例如:nacos_config)执行初始化脚本(mysql-schema.sql)。步骤2:获取Nacos的MySQL初始化脚本执行可以从Nacos的GitHub仓库获取:https://github.com/alibaba/nacos/blob/master/distribution/conf/mysql-schema.sql或者使用引用[2]中提供的gitee镜像地址:https://gitee.com/mirrors/Nacos/blob/develop/distribution/conf/mysql-schema.sql将脚本下载后,在MySQL中执行:```bashmysql-uroot-p-h<mysql_host>nacos_config<mysql-schema.sql```步骤3:为Nacos创建自定义配置文件创建一个配置文件,例如`application.properties`,内容如下:```spring.datasource.platform=mysqldb.num=1db.url.0=jdbc:mysql://<mysql_host>:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=truedb.user=rootdb.password=root```注意:这里的`<mysql_host>`不能是127.0.0.1,因为如果MySQL运行在另一个容器中,那么对于Nacos容器来说,MySQL服务在另一个容器。可以使用Docker容器的IP(通过`dockerinspect容器id|grepIPAddress`获取)或者使用Docker网络中的容器名称(如果两个容器在同一个自定义网络中)。步骤4:启动Nacos容器挂载配置文件建议创建一个自定义网络,以便容器间通过容器名称通信:```bashdockernetworkcreatenacos_net```将MySQL容器Nacos容器都加入这个网络(如果MySQL也是容器运行):```bashdockernetworkconnectnacos_netmysql```然后启动Nacos容器挂载配置文件。假设配置文件在宿主机的`/data/nacos/conf/application.properties`,则启动命令如下:```bashdockerrun-d\--namenacos\--networknacos_net\-p8848:8848\-eMODE=standalone\-v/data/nacos/conf/application.properties:/home/nacos/conf/application.properties\nacos/nacos-server```这样,Nacos容器就可以通过容器名称`mysql`来访问MySQL容器了。因此,在配置文件中,`db.url.0`可以写为:```jdbc:mysql://mysql:3306/nacos_config?...```另外,也可以使用环境变量来配置数据库连接,但Nacos官方镜像支持通过挂载配置文件的方式,这样更直观。注意:如果MySQL在宿主机上(而不是容器中),且宿主机的IP是172.17.0.1(Docker默认网桥的宿主机IP),则可以使用这个IP。但更通用的做法是使用自定义网络,通过容器名称访问。引用[3]中提到的创建挂载目录和配置文件的位置,我们这里也创建了`/data/nacos/conf/`目录来存放配置文件。总结:关键点在于网络配置,确保Nacos容器能够访问MySQL服务,配置文件中正确设置数据库连接字符串。最后,启动容器后,访问Nacos控制台(http://宿主机IP:8848/nacos)验证是否成功。如果遇到问题,可以查看Nacos容器的日志:```bashdockerlogsnacos```根据以上步骤,我们可以为用户提供详细的配置指南。</think>### 在Docker配置Nacos连接数据库的完整指南 #### 一、核心步骤 1. **准备数据库** - 创建数据库和用户(以MySQL为例): ```sql CREATE DATABASE nacos_config CHARACTER SET utf8mb4; CREATE USER 'nacos'@'%' IDENTIFIED BY 'your_password'; GRANT ALL PRIVILEGES ON nacos_config.* TO 'nacos'@'%'; ``` - 初始化Nacos表结构([获取SQL脚本](https://github.com/alibaba/nacos/blob/master/distribution/conf/mysql-schema.sql))[^2] 2. **关键配置文件** 创建`/data/nacos/init.d/custom.properties`文件: ```properties spring.datasource.platform=mysql db.num=1 db.url.0=jdbc:mysql://mysql_container:3306/nacos_config?useUnicode=true&characterEncoding=utf-8 db.user=nacos db.password=your_password ``` 3. **启动Nacos容器** ```bash docker run -d \ --name nacos \ --network my_network \ # 必须使用自定义网络 -p 8848:8848 \ -v /data/nacos/logs:/home/nacos/logs \ -v /data/nacos/init.d:/home/nacos/init.d \ -e MODE=standalone \ nacos/nacos-server ``` #### 二、网络配置要点 1. **创建自定义网络** ```bash docker network create my_network ``` 2. **MySQL容器加入同一网络** ```bash docker network connect my_network your_mysql_container ``` 3. **验证容器连通性** ```bash docker exec -it nacos ping mysql_container ``` #### 三、常见问题解决 - **连接错误:** `db.url.0`必须使用**容器名称**而非`127.0.0.1`(例如`jdbc:mysql://mysql_container:3306/...`)[^3] - **限问题:** 确保数据库用户有远程访问限:`'nacos'@'%'`而非`'nacos'@'localhost'` - **表结构缺失:** 必须执行官方提供的`mysql-schema.sql`初始化脚本[^2] #### 四、验证配置 1. 检查Nacos日志: ```bash docker logs nacos | grep "DataSource" ``` 2. 成功标志:日志中出现 `[db-load] begin to load data from db` `[db-load] load data finished` > **重要提示**:首次启动后需**重启容器**使配置生效: > ```bash > docker restart nacos > ```[^2] [^1]: Docker安装使用Nacos_docker安装nacos不使用数据库 [^2]: 【Dockerdocker安装nacos配置数据库 [^3]: docker配置nacos连接数据库
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值