拉取镜像
docker pull nacos/nacos-server:v2.2.1
查看拉取的结果
docker images
第一次运行容器
docker run --env MODE=standalone \
--name nacos -d -p 8848:8848 \
nacos/nacos-server:v2.2.1
这次运行会失败!!!因为配置文件还没改,运行的目的是将其配置文件挂载出来!!!
查看容器
docker ps -a
创建挂载目录
mkdir -p /docker/nacos/config
挂载
docker cp nacos:/home/nacos/conf/ /docker/nacos/
修改配置文件
# spring
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}
# default current work dir
server.tomcat.basedir=file:.
server.servlet.contextPath=/nacos
server.contextPath=/nacos
server.port=8848
spring.datasource.platform=mysql
spring.sql.init.platform=mysql
nacos.cmdb.dumpTaskInterval=3600
nacos.cmdb.eventTaskInterval=10
nacos.cmdb.labelTaskInterval=300
nacos.cmdb.loadDataAtStart=false
db.num=1
db.url.0=jdbc:mysql://192.168.10.100:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user.0=root
db.password.0=123456
# nacos.core.auth.system.type=${NACOS_AUTH_SYSTEM_TYPE:nacos}
# 2.0版本后需要开启鉴权
nacos.core.auth.enabled=true
### The default token: 使用 openssl rand -base64 32 命令生产
nacos.core.auth.default.token.secret.key=ekpYHl2xZ7/kwKJ23D5fNMJgSF30Bc6l9MAqXEL9W40=
# 使用 openssl rand -base64 32 命令生产
nacos.core.auth.server.identity.key=E+QFQ0PpoEq66jlIuEGs/gl+RRelIHoOt0k2etirRFQ=
# 使用 openssl rand -base64 32 命令生产
nacos.core.auth.server.identity.value=+Z92g5a+WWXcp72tEFZmfYoZmomB4qd3iuo7uoMS2NU=
# 使用 openssl rand -base64 32 命令生产
nacos.core.auth.plugin.nacos.token.secret.key=IJChZTCVSSrhLJYfdptAWH4Xy42FcZnEdxrPJDU61Tc=
nacos.core.auth.plugin.nacos.token.expire.seconds=18000
### 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=false
# 使用 openssl rand -base64 32 命令生产
nacos.core.auth.server.identity.key=bos+fS7brzLSqdkcHxHCZpl2UeCRhzulLjqbST8syAY=
# 使用 openssl rand -base64 32 命令生产
nacos.core.auth.server.identity.value=xuXJD6GNdPkuDTuih7l0tFkHLWjW58xxcHYhh6rLLXI=
# 使用 openssl rand -base64 32 命令生产
nacos.core.auth.default.token.secret.key=d8FyKICBgiGQjOEEbwC1bYR0I9wUgH1v3bvCA0dYaIU=
## spring security config
### turn off security
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
这里要改成自己的环境,不要写127.0.0.1,docker容器相当于是一个单独的环境
2.0版本以后要开启鉴权
生成7次鉴权密钥
openssl rand -base64 32
访问mysql
docker exec -it mysql8 mysql -uroot -p
运行容器单节点运行
docker run --name nacos -p 8848:8848 --privileged=true -e MODE=standalone -v /docker/nacos/conf/:/home/nacos/conf -d nacos/nacos-server:v2.2.1
访问Nacos
http://192.168.10.100:8848/nacos
默认账号密码是 nacos nacos