这里部署的nacos版本是2.1.0
一、前置环境
有一个能够运行的docker和mysql,可以参考Docker中运行一个mysql
二、选择拉取镜像
这里选择了2.1.0
版本
docker pull nacos/nacos-server:v2.1.0
三、创建nacos数据库
将nacos持久化到mysql数据库中
新建nacos数据库
从https://github.com/alibaba/nacos/blob/develop/distribution/conf/nacos-mysql.sql下载建表语句。也可以将下列语句粘贴执行
/* * Copyright 1999-2018 Alibaba Group Holding Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. *//******************************************//* 数据库全名 = nacos_config *//* 表名称 = config_info *//******************************************/CREATETABLE `config_info` ( `id` bigint(20)NOTNULL AUTO_INCREMENT COMMENT 'id', `data_id` varchar(255)NOTNULL COMMENT 'data_id', `group_id` varchar(255) DEFAULT NULL, `content` longtextNOTNULL COMMENT 'content', `md5` varchar(32) DEFAULT NULL COMMENT 'md5', `gmt_create` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `gmt_modified` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间', `src_user` text COMMENT 'source user', `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip', `app_name` varchar(128) DEFAULT NULL, `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段', `c_desc` varchar(256) DEFAULT NULL, `c_use` varchar(64) DEFAULT NULL, `effect` varchar(64) DEFAULT NULL, `type` varchar(64) DEFAULT NULL, `c_schema` text, `encrypted_data_key` textNOTNULL COMMENT '秘钥', PRIMARY KEY (`id`), UNIQUE KEY `uk_configinfo_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info';/******************************************//* 数据库全名 = nacos_config *//* 表名称 = config_info_aggr *//******************************************/CREATETABLE `config_info_aggr` ( `id` bigint(20)NOTNULL AUTO_INCREMENT COMMENT 'id', `data_id` varchar(255)NOTNULL COMMENT 'data_id', `group_id` varchar(255)NOTNULL COMMENT 'group_id', `datum_id` varchar(255)NOTNULL COMMENT 'datum_id', `content` longtextNOTNULL COMMENT '内容', `gmt_modified` datetimeNOTNULL COMMENT '修改时间', `app_name` varchar(128) DEFAULT NULL, `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段', PRIMARY KEY (`id`), UNIQUE KEY `uk_configinfoaggr_datagrouptenantdatum` (`data_id`,`group_id`,`tenant_id`,`datum_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='增加租户字段';/******************************************//* 数据库全名 = nacos_config *//* 表名称 = config_info_beta *//******************************************/CREATETABLE `config_info_beta` ( `id` bigint(20)NOTNULL AUTO_INCREMENT COMMENT 'id', `data_id` varchar(255)NOTNULL COMMENT 'data_id', `group_id` varchar(128)NOTNULL COMMENT 'group_id', `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name', `content` longtextNOTNULL COMMENT 'content', `beta_ips` varchar(1024) DEFAULT NULL COMMENT 'betaIps', `md5` varchar(32) DEFAULT NULL COMMENT 'md5', `gmt_create` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `gmt_modified` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间', `src_user` text COMMENT 'source user', `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip', `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段', `encrypted_data_key` textNOTNULL COMMENT '秘钥', PRIMARY KEY (`id`), UNIQUE KEY `uk_configinfobeta_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info_beta';/******************************************//* 数据库全名 = nacos_config *//* 表名称 = config_info_tag *//******************************************/CREATETABLE `config_info_tag` ( `id` bigint(20)NOTNULL AUTO_INCREMENT COMMENT 'id', `data_id` varchar(255)NOTNULL COMMENT 'data_id', `group_id` varchar(128)NOTNULL COMMENT 'group_id', `tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id', `tag_id` varchar(128)NOTNULL COMMENT 'tag_id', `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name', `content` longtextNOTNULL COMMENT 'content', `md5` varchar(32) DEFAULT NULL COMMENT 'md5', `gmt_create` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `gmt_modified` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间', `src_user` text COMMENT 'source user', `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip', PRIMARY KEY (`id`), UNIQUE KEY `uk_configinfotag_datagrouptenanttag` (`data_id`,`group_id`,`tenant_id`,`tag_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info_tag';/******************************************//* 数据库全名 = nacos_config *//* 表名称 = config_tags_relation *//******************************************/CREATETABLE `config_tags_relation` ( `id` bigint(20)NOTNULL COMMENT 'id', `tag_name` varchar(128)NOTNULL COMMENT 'tag_name', `tag_type` varchar(64) DEFAULT NULL COMMENT 'tag_type', `data_id` varchar(255)NOTNULL COMMENT 'data_id', `group_id` varchar(128)NOTNULL COMMENT 'group_id', `tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id', `nid` bigint(20)NOTNULL AUTO_INCREMENT, PRIMARY KEY (`nid`), UNIQUE KEY `uk_configtagrelation_configidtag` (`id`,`tag_name`,`tag_type`), KEY `idx_tenant_id` (`tenant_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_tag_relation';/******************************************//* 数据库全名 = nacos_config *//* 表名称 = group_capacity *//******************************************/CREATETABLE `group_capacity` ( `id` bigint(20)unsignedNOTNULL AUTO_INCREMENT COMMENT '主键ID', `group_id` varchar(128)NOTNULL DEFAULT '' COMMENT 'Group ID,空字符表示整个集群', `quota` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '配额,0表示使用默认值', `usage` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '使用量', `max_size` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值', `max_aggr_count` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '聚合子配置最大个数,,0表示使用默认值', `max_aggr_size` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值', `max_history_count` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '最大变更历史数量', `gmt_create` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `gmt_modified` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_group_id` (`group_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='集群、各Group容量信息表';/******************************************//* 数据库全名 = nacos_config *//* 表名称 = his_config_info *//******************************************/CREATETABLE `his_config_info` ( `id` bigint(64)unsignedNOTNULL, `nid` bigint(20)unsignedNOTNULL AUTO_INCREMENT, `data_id` varchar(255)NOTNULL, `group_id` varchar(128)NOTNULL, `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name', `content` longtextNOTNULL, `md5` varchar(32) DEFAULT NULL, `gmt_create` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP, `gmt_modified` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP, `src_user` text, `src_ip` varchar(50) DEFAULT NULL, `op_type` char(10) DEFAULT NULL, `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段', `encrypted_data_key` textNOTNULL COMMENT '秘钥', PRIMARY KEY (`nid`), KEY `idx_gmt_create` (`gmt_create`), KEY `idx_gmt_modified` (`gmt_modified`), KEY `idx_did` (`data_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='多租户改造';/******************************************//* 数据库全名 = nacos_config *//* 表名称 = tenant_capacity *//******************************************/CREATETABLE `tenant_capacity` ( `id` bigint(20)unsignedNOTNULL AUTO_INCREMENT COMMENT '主键ID', `tenant_id` varchar(128)NOTNULL DEFAULT '' COMMENT 'Tenant ID', `quota` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '配额,0表示使用默认值', `usage` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '使用量', `max_size` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值', `max_aggr_count` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '聚合子配置最大个数', `max_aggr_size` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值', `max_history_count` int(10)unsignedNOTNULL DEFAULT '0' COMMENT '最大变更历史数量', `gmt_create` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `gmt_modified` datetimeNOTNULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_tenant_id` (`tenant_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='租户容量信息表';CREATETABLE `tenant_info` ( `id` bigint(20)NOTNULL AUTO_INCREMENT COMMENT 'id', `kp` varchar(128)NOTNULL COMMENT 'kp', `tenant_id` varchar(128) default '' COMMENT 'tenant_id', `tenant_name` varchar(128) default '' COMMENT 'tenant_name', `tenant_desc` varchar(256) DEFAULT NULL COMMENT 'tenant_desc', `create_source` varchar(32) DEFAULT NULL COMMENT 'create_source', `gmt_create` bigint(20)NOTNULL COMMENT '创建时间', `gmt_modified` bigint(20)NOTNULL COMMENT '修改时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_tenant_info_kptenantid` (`kp`,`tenant_id`), KEY `idx_tenant_id` (`tenant_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='tenant_info';CREATETABLE `users` ( `username` varchar(50)NOTNULL PRIMARY KEY, `password` varchar(500)NOTNULL, `enabled` booleanNOTNULL);CREATETABLE `roles` ( `username` varchar(50)NOTNULL, `role` varchar(50)NOTNULL, UNIQUE INDEX `idx_user_role` (`username` ASC, `role` ASC) USING BTREE );CREATETABLE `permissions` ( `role` varchar(50)NOTNULL, `resource` varchar(255)NOTNULL, `action` varchar(8)NOTNULL, UNIQUE INDEX `uk_role_permission` (`role`,`resource`,`action`) USING BTREE );INSERTINTO users (username, password, enabled)VALUES('nacos','$2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu',TRUE);INSERTINTO roles (username, role)VALUES('nacos','ROLE_ADMIN');
这里的建表语句,与之前版本有点初入,主要是这个字段encrypted_data_key
的初入。之前有一个低版本的nacos数据库,配置使用之后导致encrypted_data_key
这个字段找不到而报错
四、运行容器
4.1 先直接部署一个容器
是为了拿到application.properties等配置文件
docker run -d \ -eMODE=standalone \ -ePREFER_HOST_MODE=hostname \ -eSPRING_DATASOURCE_PLATFORM=mysql \ -eMYSQL_SERVICE_HOST=192.168.120.1 \ -eMYSQL_SERVICE_PORT=3306 \ -eMYSQL_SERVICE_USER=root \ -eMYSQL_SERVICE_PASSWORD=root \ -eMYSQL_SERVICE_DB_NAME=nacos \ -p8848:8848 \ --name nacos \ --restart=always \ nacos/nacos-server:v2.1.0
参数说明
- MODE=standalone 单节点模式
- SPRING_DATASOURCE_PLATFORM=mysql 使用mysql数据库连接方式
- MYSQL_SERVICE_HOST=192.168.120.1 指定数据库地址
- MYSQL_SERVICE_PORT 数据库端口
- MYSQL_SERVICE_USER 数据库用户名
- MYSQL_SERVICE_PASSWORD 数据库密码
- MYSQL_SERVICE_DB_NAME 数据库名称
- -p 8848:8848 端口映射
- --name nacos 容器命名
- --restart=always 任意时候重启容器,开机就能自动启动容器(需设置docker为开机自启)
Ncaos Docker支持的参数有:
具体的可以参见官方文档:https://nacos.io/en-us/docs/quick-start-docker.html
4.2 宿主机配置文件映射
4.2.1 拷贝配置文件
docker cp nacos:/home/nacos/conf/application.properties /data/nacos/config/
4.2.2 拷贝logback日志配置文件
docker cp nacos:/home/nacos/conf/nacos-logback.xml /data/nacos/config/
4.2.3 修改application.properties的配置
# springserver.servlet.contextPath=${SERVER_SERVLET_CONTEXTPATH:/nacos}server.contextPath=/nacos server.port=${NACOS_APPLICATION_PORT:8848}# 修改此行,将SPRING_DATASOURCE_PLATFORM的默认值""改为mysqlspring.datasource.platform=${SPRING_DATASOURCE_PLATFORM:mysql}nacos.cmdb.dumpTaskInterval=3600nacos.cmdb.eventTaskInterval=10nacos.cmdb.labelTaskInterval=300nacos.cmdb.loadDataAtStart=falsedb.num=${MYSQL_DATABASE_NUM:1}# 修改此行,添加MYSQL_SERVICE_HOST的默认值为192.168.120.1,MYSQL_SERVICE_DB_NAME的默认值为nacosdb.url.0=jdbc:mysql://${MYSQL_SERVICE_HOST:192.168.120.1}:${MYSQL_SERVICE_PORT:3306}/${MYSQL_SERVICE_DB_NAME:nacos}?${MYSQL_SERVICE_DB_PARAM:characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useSSL=false}# 修改此行,添加MYSQL_SERVICE_HOST的默认值为192.168.120.1,MYSQL_SERVICE_DB_NAME的默认值为nacosdb.url.1=jdbc:mysql://${MYSQL_SERVICE_HOST:192.168.120.1}:${MYSQL_SERVICE_PORT:3306}/${MYSQL_SERVICE_DB_NAME:nacos}?${MYSQL_SERVICE_DB_PARAM:characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useSSL=false}# 修改此行,添加MYSQL_SERVICE_USER的默认值为rootdb.user=${MYSQL_SERVICE_USER:root}# 修改此行,添加MYSQL_SERVICE_PASSWORD的默认值为rootdb.password=${MYSQL_SERVICE_PASSWORD:root}### 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}nacos.core.auth.enable.userAgentAuthWhite=${NACOS_AUTH_USER_AGENT_AUTH_WHITE_ENABLE:false}nacos.core.auth.server.identity.key=${NACOS_AUTH_IDENTITY_KEY:serverIdentity}nacos.core.auth.server.identity.value=${NACOS_AUTH_IDENTITY_VALUE:security}server.tomcat.accesslog.enabled=${TOMCAT_ACCESSLOG_ENABLED:false}server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %D # default current work dirserver.tomcat.basedir=## spring security config### turn off securitynacos.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/**}
采用添加默认值的方式,这样不会影响指定命令行的参数
4.3 运行容器
运行之前先删除之前启动的容器
docker stop nacos docker rm nacos
重新运行容器
docker run -d \ -eMODE=standalone \ -p8848:8848 \ -v /data/nacos/conf:/home/nacos/conf \ -v /data/nacos/logs:/home/nacos/logs \ -v /data/nacos/data:/home/nacos/data \ --name nacos-mysql \ --restart=always \ nacos/nacos-server:v2.1.0
访问:ip:8848/nacos