diff --git a/austin-common/src/main/java/com/java3y/austin/common/constant/CommonConstant.java b/austin-common/src/main/java/com/java3y/austin/common/constant/CommonConstant.java
new file mode 100644
index 0000000..ffc9088
--- /dev/null
+++ b/austin-common/src/main/java/com/java3y/austin/common/constant/CommonConstant.java
@@ -0,0 +1,18 @@
+package com.java3y.austin.common.constant;
+
+public class CommonConstant {
+ public final static String PERIOD = ".";
+ public final static String COMMA = ",";
+ public final static String COLON = ":";
+ public final static String SEMICOLON = ";";
+ public final static String POUND = "#";
+ public final static String SLASH = "/";
+ public final static String BACKSLASH = "\\";
+ public final static String EMPTY_STRING = "";
+ //
+ public final static String ONE = "1";
+ public final static String ZERO = "0";
+ public final static String MINUS_ONE = "-1";
+ public final static String YES = "Y";
+ public final static String NO = "N";
+}
\ No newline at end of file
diff --git a/austin-support/pom.xml b/austin-support/pom.xml
index 29a3619..f6dfb2b 100644
--- a/austin-support/pom.xml
+++ b/austin-support/pom.xml
@@ -103,6 +103,11 @@
org.springframework.amqp
spring-rabbit
+
+
+ com.alibaba.boot
+ nacos-config-spring-boot-starter
+
diff --git a/austin-support/src/main/java/com/java3y/austin/support/service/ConfigService.java b/austin-support/src/main/java/com/java3y/austin/support/service/ConfigService.java
index 29b37f2..b73e09a 100644
--- a/austin-support/src/main/java/com/java3y/austin/support/service/ConfigService.java
+++ b/austin-support/src/main/java/com/java3y/austin/support/service/ConfigService.java
@@ -10,8 +10,8 @@ public interface ConfigService {
/**
* 读取配置
- * 1、当启动使用了apollo,优先读取apollo
- * 2、当没有启动apollo,读取本地 local.properties 配置文件的内容
+ * 1、当启动使用了apollo或者nacos,优先读取远程配置
+ * 2、当没有启动远程配置,读取本地 local.properties 配置文件的内容
* @param key
* @param defaultValue
* @return
diff --git a/austin-support/src/main/java/com/java3y/austin/support/service/impl/ConfigServiceImpl.java b/austin-support/src/main/java/com/java3y/austin/support/service/impl/ConfigServiceImpl.java
index 860e84e..c14a948 100644
--- a/austin-support/src/main/java/com/java3y/austin/support/service/impl/ConfigServiceImpl.java
+++ b/austin-support/src/main/java/com/java3y/austin/support/service/impl/ConfigServiceImpl.java
@@ -4,6 +4,8 @@ import cn.hutool.core.util.StrUtil;
import cn.hutool.setting.dialect.Props;
import com.ctrip.framework.apollo.Config;
import com.java3y.austin.support.service.ConfigService;
+import com.java3y.austin.support.utils.NacosUtils;
+import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
@@ -30,12 +32,22 @@ public class ConfigServiceImpl implements ConfigService {
private Boolean enableApollo;
@Value("${apollo.bootstrap.namespaces}")
private String namespaces;
+ /**
+ * nacos配置
+ */
+ @Value("${austin.nacos.enabled}")
+ private Boolean enableNacos;
+ @Autowired
+ private NacosUtils nacosUtils;
+
@Override
public String getProperty(String key, String defaultValue) {
if (enableApollo) {
Config config = com.ctrip.framework.apollo.ConfigService.getConfig(namespaces.split(StrUtil.COMMA)[0]);
return config.getProperty(key, defaultValue);
+ } else if (enableNacos) {
+ return nacosUtils.getProperty(key, defaultValue);
} else {
return props.getProperty(key, defaultValue);
}
diff --git a/austin-support/src/main/java/com/java3y/austin/support/utils/NacosUtils.java b/austin-support/src/main/java/com/java3y/austin/support/utils/NacosUtils.java
new file mode 100644
index 0000000..dc6a54a
--- /dev/null
+++ b/austin-support/src/main/java/com/java3y/austin/support/utils/NacosUtils.java
@@ -0,0 +1,61 @@
+package com.java3y.austin.support.utils;
+
+import cn.hutool.core.util.StrUtil;
+import com.alibaba.nacos.api.NacosFactory;
+import com.alibaba.nacos.api.PropertyKeyConst;
+import com.alibaba.nacos.api.exception.NacosException;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang3.exception.ExceptionUtils;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.stereotype.Component;
+import org.springframework.util.StringUtils;
+
+import java.io.StringReader;
+import java.util.Properties;
+
+/**
+ * @program: austin
+ * @description:
+ * @author: Giorno
+ * @create: 2022-07-28
+ **/
+@Slf4j
+@Component
+public class NacosUtils {
+ @Value("${austin.nacos.server}")
+ private String nacosServer;
+ @Value("${austin.nacos.group}")
+ private String nacosGroup;
+ @Value("${austin.nacos.dataId}")
+ private String nacosDataId;
+ @Value("${austin.nacos.namespace}")
+ private String nacosNamespace;
+ private final Properties request = new Properties();
+ private final Properties properties = new Properties();
+
+ public String getProperty(String key, String defaultValue) {
+ try {
+ String property = this.getContext();
+ if (StringUtils.hasText(property)) {
+ properties.load(new StringReader(property));
+ }
+ } catch (Exception e) {
+ log.error("Nacos error:{}", ExceptionUtils.getStackTrace(e));
+ }
+ String property = properties.getProperty(key);
+ return StrUtil.isBlank(property) ? defaultValue : property;
+ }
+
+ private String getContext() {
+ String context = null;
+ try {
+ request.put(PropertyKeyConst.SERVER_ADDR, nacosServer);
+ request.put(PropertyKeyConst.NAMESPACE, nacosNamespace);
+ context = NacosFactory.createConfigService(request)
+ .getConfig(nacosDataId, nacosGroup, 5000);
+ } catch (NacosException e) {
+ log.error("Nacos error:{}", ExceptionUtils.getStackTrace(e));
+ }
+ return context;
+ }
+}
diff --git a/austin-web/src/main/resources/application.properties b/austin-web/src/main/resources/application.properties
index 42bf920..860c299 100644
--- a/austin-web/src/main/resources/application.properties
+++ b/austin-web/src/main/resources/application.properties
@@ -89,7 +89,6 @@ spring.rabbitmq.virtual-host=/
austin.rabbitmq.topic.name=austinRabbit
austin.rabbitmq.exchange.name=austin.point
-
##################### redis properties #####################
spring.redis.host=${austin-redis-ip}
spring.redis.port=${austin-redis-port}
@@ -126,6 +125,13 @@ app.id=austin
apollo.bootstrap.enabled=${apollo.enabled}
apollo.bootstrap.namespaces=boss.austin,dynamic-tp-apollo-dtp.yml
+##################### nacos #####################
+austin.nacos.enabled=true
+austin.nacos.server=
+austin.nacos.dataId=
+austin.nacos.group=
+austin.nacos.namespace=
+
##################### httpUtils properties #####################
ok.http.connect-timeout=30
ok.http.keep-alive-duration=300
diff --git a/docker/nacos/cluster/docker-compose.yml b/docker/nacos/cluster/docker-compose.yml
new file mode 100644
index 0000000..475088e
--- /dev/null
+++ b/docker/nacos/cluster/docker-compose.yml
@@ -0,0 +1,75 @@
+version: "3"
+
+services:
+ nacos1:
+ container_name: nacos-server-1
+ hostname: nacos-server01
+ image: nacos/nacos-server
+ environment:
+ - MODE=cluster
+ - PREFER_HOST_MODE=hostname
+ - NACOS_SERVERS=nacos-server01:8848 nacos-server02:8848 nacos-server03:8848
+ - SPRING_DATASOURCE_PLATFORM=mysql
+ - MYSQL_SERVICE_HOST=mysql
+ - MYSQL_SERVICE_PORT=3306
+ - MYSQL_SERVICE_USER=root
+ - MYSQL_SERVICE_PASSWORD=123456
+ - MYSQL_SERVICE_DB_NAME=nacos-db
+ - JVM_XMS=128m
+ - JVM_XMX=128m
+ - JVM_XMN=128m
+ volumes:
+ - /home/nacos/cluster-logs/nacos-server01:/home/nacos/logs
+ - /home/nacos/init.d:/home/nacos/init.d
+ ports:
+ - 8846:8848
+ - 9555:9555
+ restart: on-failure
+
+ nacos2:
+ container_name: nacos-server-2
+ hostname: nacos-server02
+ image: nacos/nacos-server
+ environment:
+ - MODE=cluster
+ - PREFER_HOST_MODE=hostname
+ - NACOS_SERVERS=nacos-server01:8848 nacos-server02:8848 nacos-server03:8848
+ - SPRING_DATASOURCE_PLATFORM=mysql
+ - MYSQL_SERVICE_HOST=mysql
+ - MYSQL_SERVICE_PORT=3306
+ - MYSQL_SERVICE_USER=root
+ - MYSQL_SERVICE_PASSWORD=123456
+ - MYSQL_SERVICE_DB_NAME=nacos-db
+ - JVM_XMS=128m
+ - JVM_XMX=128m
+ - JVM_XMN=128m
+ volumes:
+ - /home/nacos/cluster-logs/nacos-server02:/home/nacos/logs
+ - /home/nacos/init.d:/home/nacos/init.d
+ ports:
+ - 8847:8848
+ restart: on-failure
+
+ nacos3:
+ container_name: nacos-server-3
+ hostname: nacos-server03
+ image: nacos/nacos-server
+ environment:
+ - MODE=cluster
+ - PREFER_HOST_MODE=hostname
+ - NACOS_SERVERS=nacos-server01:8848 nacos-server02:8848 nacos-server03:8848
+ - SPRING_DATASOURCE_PLATFORM=mysql
+ - MYSQL_SERVICE_HOST=mysql
+ - MYSQL_SERVICE_PORT=3306
+ - MYSQL_SERVICE_USER=root
+ - MYSQL_SERVICE_PASSWORD=123456
+ - MYSQL_SERVICE_DB_NAME=nacos-db
+ - JVM_XMS=128m
+ - JVM_XMX=128m
+ - JVM_XMN=128m
+ volumes:
+ - /home/nacos/cluster-logs/nacos-server03:/home/nacos/logs
+ - /home/nacos/init.d:/home/nacos/init.d
+ ports:
+ - 8848:8848
+ restart: on-failure
\ No newline at end of file
diff --git a/docker/nacos/single/docker-compose.yml b/docker/nacos/single/docker-compose.yml
new file mode 100644
index 0000000..ba713ed
--- /dev/null
+++ b/docker/nacos/single/docker-compose.yml
@@ -0,0 +1,25 @@
+version: "3"
+
+services:
+ nacos1:
+ container_name: nacos-server
+ hostname: nacos-server
+ image: nacos/nacos-server
+ environment:
+ - MODE=standalone
+ - PREFER_HOST_MODE=hostname
+ - SPRING_DATASOURCE_PLATFORM=mysql
+ - MYSQL_SERVICE_HOST=mysql
+ - MYSQL_SERVICE_PORT=3306
+ - MYSQL_SERVICE_USER=root
+ - MYSQL_SERVICE_PASSWORD=123456
+ - MYSQL_SERVICE_DB_NAME=nacos-db
+ - JVM_XMS=128m
+ - JVM_XMX=128m
+ - JVM_XMN=128m
+ volumes:
+ - /home/nacos/single-logs/nacos-server:/home/nacos/logs
+ - /home/nacos/init.d:/home/nacos/init.d
+ ports:
+ - 8848:8848
+ restart: on-failure
\ No newline at end of file
diff --git a/docker/nacos/sql/config.sql b/docker/nacos/sql/config.sql
new file mode 100644
index 0000000..3c0de79
--- /dev/null
+++ b/docker/nacos/sql/config.sql
@@ -0,0 +1,234 @@
+/*
+ * 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 */
+/******************************************/
+CREATE TABLE `config_info`
+(
+ `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
+ `data_id` varchar(255) NOT NULL COMMENT 'data_id',
+ `group_id` varchar(255) DEFAULT NULL,
+ `content` longtext NOT NULL COMMENT 'content',
+ `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
+ `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
+ `gmt_modified` datetime NOT NULL 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,
+ `encrypted_data_key` varchar(255) DEFAULT NULL,
+ `c_schema` text,
+ 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 */
+/******************************************/
+CREATE TABLE `config_info_aggr`
+(
+ `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
+ `data_id` varchar(255) NOT NULL COMMENT 'data_id',
+ `group_id` varchar(255) NOT NULL COMMENT 'group_id',
+ `datum_id` varchar(255) NOT NULL COMMENT 'datum_id',
+ `content` longtext NOT NULL COMMENT '内容',
+ `gmt_modified` datetime NOT NULL 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 */
+/******************************************/
+CREATE TABLE `config_info_beta`
+(
+ `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
+ `data_id` varchar(255) NOT NULL COMMENT 'data_id',
+ `group_id` varchar(128) NOT NULL COMMENT 'group_id',
+ `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
+ `content` longtext NOT NULL COMMENT 'content',
+ `beta_ips` varchar(1024) DEFAULT NULL COMMENT 'betaIps',
+ `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
+ `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
+ `gmt_modified` datetime NOT NULL 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 '租户字段',
+ 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 */
+/******************************************/
+CREATE TABLE `config_info_tag`
+(
+ `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
+ `data_id` varchar(255) NOT NULL COMMENT 'data_id',
+ `group_id` varchar(128) NOT NULL COMMENT 'group_id',
+ `tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id',
+ `tag_id` varchar(128) NOT NULL COMMENT 'tag_id',
+ `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
+ `content` longtext NOT NULL COMMENT 'content',
+ `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
+ `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
+ `gmt_modified` datetime NOT NULL 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 */
+/******************************************/
+CREATE TABLE `config_tags_relation`
+(
+ `id` bigint(20) NOT NULL COMMENT 'id',
+ `tag_name` varchar(128) NOT NULL COMMENT 'tag_name',
+ `tag_type` varchar(64) DEFAULT NULL COMMENT 'tag_type',
+ `data_id` varchar(255) NOT NULL COMMENT 'data_id',
+ `group_id` varchar(128) NOT NULL COMMENT 'group_id',
+ `tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id',
+ `nid` bigint(20) NOT NULL 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 */
+/******************************************/
+CREATE TABLE `group_capacity`
+(
+ `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
+ `group_id` varchar(128) NOT NULL DEFAULT '' COMMENT 'Group ID,空字符表示整个集群',
+ `quota` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表示使用默认值',
+ `usage` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '使用量',
+ `max_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值',
+ `max_aggr_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '聚合子配置最大个数,,0表示使用默认值',
+ `max_aggr_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值',
+ `max_history_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最大变更历史数量',
+ `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
+ `gmt_modified` datetime NOT NULL 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 */
+/******************************************/
+CREATE TABLE `his_config_info`
+(
+ `id` bigint(64) unsigned NOT NULL,
+ `nid` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
+ `data_id` varchar(255) NOT NULL,
+ `group_id` varchar(128) NOT NULL,
+ `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
+ `content` longtext NOT NULL,
+ `md5` varchar(32) DEFAULT NULL,
+ `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
+ `gmt_modified` datetime NOT NULL 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` varchar(255) DEFAULT NULL,
+ 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 */
+/******************************************/
+CREATE TABLE `tenant_capacity`
+(
+ `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
+ `tenant_id` varchar(128) NOT NULL DEFAULT '' COMMENT 'Tenant ID',
+ `quota` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表示使用默认值',
+ `usage` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '使用量',
+ `max_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值',
+ `max_aggr_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '聚合子配置最大个数',
+ `max_aggr_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值',
+ `max_history_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最大变更历史数量',
+ `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
+ `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
+ PRIMARY KEY (`id`),
+ UNIQUE KEY `uk_tenant_id` (`tenant_id`)
+) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='租户容量信息表';
+
+
+CREATE TABLE `tenant_info`
+(
+ `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
+ `kp` varchar(128) NOT NULL 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) NOT NULL COMMENT '创建时间',
+ `gmt_modified` bigint(20) NOT NULL 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';
+
+CREATE TABLE `users`
+(
+ `username` varchar(50) NOT NULL PRIMARY KEY,
+ `password` varchar(500) NOT NULL,
+ `enabled` boolean NOT NULL
+);
+
+CREATE TABLE `roles`
+(
+ `username` varchar(50) NOT NULL,
+ `role` varchar(50) NOT NULL,
+ UNIQUE INDEX `idx_user_role` (`username` ASC, `role` ASC) USING BTREE
+);
+
+CREATE TABLE `permissions`
+(
+ `role` varchar(50) NOT NULL,
+ `resource` varchar(255) NOT NULL,
+ `action` varchar(8) NOT NULL,
+ UNIQUE INDEX `uk_role_permission` (`role`,`resource`,`action`) USING BTREE
+);
+
+INSERT INTO users (username, password, enabled)
+VALUES ('nacos', '$2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu', TRUE);
+
+INSERT INTO roles (username, role)
+VALUES ('nacos', 'ROLE_ADMIN');
\ No newline at end of file
diff --git a/pom.xml b/pom.xml
index e69a5da..8fca343 100644
--- a/pom.xml
+++ b/pom.xml
@@ -84,6 +84,13 @@
3.1.510
+
+
+ com.alibaba.boot
+ nacos-config-spring-boot-starter
+ 0.2.1
+
+
com.ctrip.framework.apollo
@@ -205,5 +212,4 @@
-