Nacos官方
https://nacos.io/zh-cn/index.html
Nacos单机部署
初始化数据库脚本
脚本下载地址:https://github.com/alibaba/nacos/blob/master/config/src/main/resources/META-INF/nacos-db.sql
- 创建数据库
nacos_config
- 初始化
nacos-db.sql
脚本
操作步骤
1、Docker
拉取Nacos
镜像
查看可用的Nacos
版本
访问Nacos
镜像库地址:https://hub.docker.com/r/nacos/nacos-server/tags?page=1&ordering=last_updated
可以通过Sort by
查看其他版本的Nacos
,本次我使用的是nacos/nacos-server:1.4.0
版本
2、拉取Nacos
镜像
docker pull nacos/nacos-server:1.4.0
3、查看本地镜像
docker images
4、创建本地映射文件
mkdir -p ~/work/nacos/standalone-logs ~/work/nacos/init.d ~/work/nacos/conf
5、运行容器
创建容器,使用standalone
模式并映射容器服务的8848
到宿主机的8848
,外部主机可以直接通过宿主机ip:8848/nacos
访问到Nacos
管理界面。
docker run -d \
-e MODE=standalone \
-e PREFER_HOST_MODE=hostname \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=数据库host \
-e MYSQL_SERVICE_PORT=数据库端口 \
-e MYSQL_SERVICE_USER=数据库用户名 \
-e MYSQL_SERVICE_PASSWORD=数据库密码 \
-e MYSQL_SERVICE_DB_NAME=数据库 \
-e MYSQL_SERVICE_DB_PARAM="autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=CONVERT_TO_NULL&useSSL=false&serverTimezone=Asia/Shanghai" \
-p 8848:8848 \
--restart=always \
--name nacos1.4.0 \
-v ~/work/nacos/standalone-logs/:/home/nacos/logs \
-v ~/work/nacos/init.d/:/home/nacos/init.d \
-v ~/work/nacos/conf/:/home/nacos/conf \
nacos/nacos-server:1.4.0
参数说明:
-
-p 8848:8848: 映射容器服务的
8848
到宿主机的8848
,外部主机可以直接通过宿主机ip:8848/nacos
访问到Nacos
管理界面。
通过docker ps
命令查看是否安装成功:
进入容器:
docker exec -it nacos1.4.0 /bin/bash
cat /home/nacos/conf/application.properties
查看容器中Nacos
的/home/nacos/conf/application.properties
配置文件参数
# spring
server.servlet.contextPath=${SERVER_SERVLET_CONTEXTPATH:/nacos}
server.contextPath=/nacos
server.port=${NACOS_APPLICATION_PORT:8848}
spring.datasource.platform=${SPRING_DATASOURCE_PLATFORM:""}
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://${MYSQL_SERVICE_HOST}:${MYSQL_SERVICE_PORT:3306}/${MYSQL_SERVICE_DB_NAME}?${MYSQL_SERVICE_DB_PARAM:characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true}
db.url.1=jdbc:mysql://${MYSQL_SERVICE_HOST}:${MYSQL_SERVICE_PORT:3306}/${MYSQL_SERVICE_DB_NAME}?${MYSQL_SERVICE_DB_PARAM:characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true}
db.user=${MYSQL_SERVICE_USER}
db.password=${MYSQL_SERVICE_PASSWORD}
### The auth system to use, currently only 'nacos' is supported:
nacos.core.auth.system.type=${NACOS_AUTH_SYSTEM_TYPE:nacos}
### The token expiration in seconds:
nacos.core.auth.default.token.expire.seconds=${NACOS_AUTH_TOKEN_EXPIRE_SECONDS:18000}
### The default token:
nacos.core.auth.default.token.secret.key=${NACOS_AUTH_TOKEN:SecretKey012345678901234567890123456789012345678901234567890123456789}
### 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}
server.tomcat.accesslog.enabled=${TOMCAT_ACCESSLOG_ENABLED:false}
server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %D
# default current work dir
server.tomcat.basedir=
## 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
6、访问Nacos
基本信息
- 访问地址:http://localhost:8848/nacos
- 账号密码:nacos/nacos
遇到问题
-
Mac
下Docker
容器中Nacos
无法连接宿主机MySQL
数据库
答:数据库host
应该使用host.docker.internal
;参考链接:https://docs.docker.com/docker-for-mac/networking/#use-cases-and-workarounds
公共参数配置
name | description | option |
---|---|---|
MODE | cluster模式/standalone模式 | cluster/standalone default cluster |
NACOS_SERVERS | nacos cluster地址 | eg. ip1,ip2,ip3 |
PREFER_HOST_MODE | 是否支持hostname | hostname/ip default ip |
NACOS_SERVER_PORT | nacos服务器端口 | default 8848 |
NACOS_SERVER_IP | 多网卡下的自定义nacos服务器IP | |
SPRING_DATASOURCE_PLATFORM | standalone 支持 mysql | mysql / empty default empty |
MYSQL_MASTER_SERVICE_HOST | mysql 主节点host | |
MYSQL_MASTER_SERVICE_PORT | mysql 主节点端口 | default : 3306 |
MYSQL_MASTER_SERVICE_DB_NAME | mysql 主节点数据库 | |
MYSQL_MASTER_SERVICE_USER | 数据库用户名 | |
MYSQL_MASTER_SERVICE_PASSWORD | 数据库密码 | |
MYSQL_SLAVE_SERVICE_HOST | mysql从节点host | |
MYSQL_SLAVE_SERVICE_PORT | mysql从节点端口 | default :3306 |
MYSQL_DATABASE_NUM | 数据库数量 | default :2 |
JVM_XMS | -Xms | default :2g |
JVM_XMX | -Xmx | default :2g |
JVM_XMN | -Xmn | default :1g |
JVM_MS | -XX:MetaspaceSize | default :128m |
JVM_MMS | -XX:MaxMetaspaceSize | default :320m |
NACOS_DEBUG | 开启远程调试 | y/n default :n |
TOMCAT_ACCESSLOG_ENABLED | server.tomcat.accesslog.enabled | default :false |
相关链接
- Nacos 官网: https://nacos.io/zh-cn/index.html
- Nacos Github: https://github.com/alibaba/nacos
- Nacos Docker Hub: https://hub.docker.com/r/nacos/nacos-server
- Mac下容器连接宿主机:https://docs.docker.com/docker-for-mac/networking/#use-cases-and-workarounds