From 47b6874bbeb53eae6f78d7a1ed55c70c332a1bc9 Mon Sep 17 00:00:00 2001 From: Meng Sen Date: Tue, 30 Jan 2024 10:52:06 +0800 Subject: [PATCH] Add Nacos-2.2.0 (#863) * Add Nacos-2.2.0 * Add Sentinel-Dashboard --- nacos/2.2.0-derby/data.yml | 88 +++++++ nacos/2.2.0-derby/docker-compose.yml | 27 +++ nacos/2.2.0-mysql/data.yml | 156 +++++++++++++ nacos/2.2.0-mysql/derby-schema.sql | 231 +++++++++++++++++++ nacos/2.2.0-mysql/docker-compose.yml | 32 +++ nacos/2.2.0-mysql/mysql-schema.sql | 221 ++++++++++++++++++ nacos/README.md | 89 +++++++ nacos/data.yml | 19 ++ nacos/logo.png | Bin 0 -> 12708 bytes sentinel-dashboard/1.8.6/data.yml | 18 ++ sentinel-dashboard/1.8.6/docker-compose.yml | 12 + sentinel-dashboard/README.md | 47 ++++ sentinel-dashboard/data.yml | 19 ++ sentinel-dashboard/latest/data.yml | 18 ++ sentinel-dashboard/latest/docker-compose.yml | 12 + sentinel-dashboard/logo.png | Bin 0 -> 12548 bytes 16 files changed, 989 insertions(+) create mode 100644 nacos/2.2.0-derby/data.yml create mode 100644 nacos/2.2.0-derby/docker-compose.yml create mode 100644 nacos/2.2.0-mysql/data.yml create mode 100644 nacos/2.2.0-mysql/derby-schema.sql create mode 100644 nacos/2.2.0-mysql/docker-compose.yml create mode 100644 nacos/2.2.0-mysql/mysql-schema.sql create mode 100644 nacos/README.md create mode 100644 nacos/data.yml create mode 100644 nacos/logo.png create mode 100644 sentinel-dashboard/1.8.6/data.yml create mode 100644 sentinel-dashboard/1.8.6/docker-compose.yml create mode 100644 sentinel-dashboard/README.md create mode 100644 sentinel-dashboard/data.yml create mode 100644 sentinel-dashboard/latest/data.yml create mode 100644 sentinel-dashboard/latest/docker-compose.yml create mode 100644 sentinel-dashboard/logo.png diff --git a/nacos/2.2.0-derby/data.yml b/nacos/2.2.0-derby/data.yml new file mode 100644 index 000000000..81b683454 --- /dev/null +++ b/nacos/2.2.0-derby/data.yml @@ -0,0 +1,88 @@ +additionalProperties: + formFields: + - default: "serverIdentity" + edit: true + envKey: NACOS_AUTH_IDENTITY_KEY + labelEn: Nacos auth identity key + labelZh: Nacos身份验证密钥键 + required: true + type: text + - default: "security" + edit: true + envKey: NACOS_AUTH_IDENTITY_VALUE + labelEn: Nacos auth identity value + labelZh: Nacos身份验证密钥值 + required: true + type: text + - default: "SecretKey012345678901234567890123456789012345678901234567890123456789" + edit: true + envKey: NACOS_AUTH_TOKEN + labelEn: Nacos auth token + labelZh: Nacos身份验证令牌 + required: true + type: text + - default: 8848 + edit: true + envKey: PANEL_APP_PORT_HTTP + labelEn: Nacos run port + labelZh: Nacos 运行端口 + required: true + rule: paramPort + type: number + - default: 9848 + edit: true + envKey: NACOS_COMMUNICATION_PORT + labelEn: Nacos communication port + labelZh: Nacos 通讯端口 + required: true + rule: paramPort + type: number + - default: "/home/nacos" + edit: true + envKey: NACOS_DATA_ROOT_PATH + labelEn: Nacos root directory of data storage + labelZh: Nacos 数据存储根目录 + required: true + type: text + - default: "" + edit: true + envKey: NACOS_SERVER_IP + labelEn: IP can be specified in multi network card mode + labelZh: 多网卡模式下可以指定IP + required: false + type: text + - default: "2g" + edit: true + envKey: JVM_XMS + labelEn: JVM_XMS + labelZh: JVM_XMS + required: true + type: text + - default: "2g" + edit: true + envKey: JVM_XMX + labelEn: JVM_XMX + labelZh: JVM_XMX + required: true + type: text + - default: "1g" + edit: true + envKey: JVM_XMN + labelEn: JVM_XMN + labelZh: JVM_XMN + required: true + type: text + - default: "128m" + edit: true + envKey: JVM_MS + labelEn: JVM_MS + labelZh: JVM_MS + required: true + type: text + - default: "320m" + edit: true + envKey: JVM_MMS + labelEn: JVM_MMS + labelZh: JVM_MMS + required: true + type: text diff --git a/nacos/2.2.0-derby/docker-compose.yml b/nacos/2.2.0-derby/docker-compose.yml new file mode 100644 index 000000000..7055992c0 --- /dev/null +++ b/nacos/2.2.0-derby/docker-compose.yml @@ -0,0 +1,27 @@ +version: "2" +services: + nacos: + image: nacos/nacos-server:v2.2.0 + container_name: ${CONTAINER_NAME}-standalone + restart: always + environment: + - PREFER_HOST_MODE=hostname + - MODE=standalone + - JVM_XMS=${JVM_XMS} + - JVM_XMX=${JVM_XMX} + - JVM_XMN=${JVM_XMN} + - JVM_MS=${JVM_MS} + - JVM_MMS=${JVM_MMS} + - NACOS_AUTH_IDENTITY_KEY=${NACOS_AUTH_IDENTITY_KEY} + - NACOS_AUTH_IDENTITY_VALUE=${NACOS_AUTH_IDENTITY_VALUE} + - NACOS_AUTH_TOKEN=${NACOS_AUTH_TOKEN} + - NACOS_SERVER_IP=${NACOS_SERVER_IP} + volumes: + - ${NACOS_DATA_ROOT_PATH}/logs:/home/nacos/logs + - ${NACOS_DATA_ROOT_PATH}/data:/home/nacos/data + ports: + - "${PANEL_APP_PORT_HTTP}:8848" + - "${NACOS_COMMUNICATION_PORT}:9848" +networks: + 1panel-network: + external: true diff --git a/nacos/2.2.0-mysql/data.yml b/nacos/2.2.0-mysql/data.yml new file mode 100644 index 000000000..85cce1914 --- /dev/null +++ b/nacos/2.2.0-mysql/data.yml @@ -0,0 +1,156 @@ +additionalProperties: + formFields: + - child: + default: "" + envKey: PANEL_DB_HOST + required: true + type: service + default: mysql + envKey: PANEL_DB_TYPE + labelEn: Database Service + labelZh: 数据库服务 + required: true + type: apps + values: + - label: MySQL + value: mysql + - label: MariaDB + value: mariadb + - default: "serverIdentity" + edit: true + envKey: NACOS_AUTH_IDENTITY_KEY + labelEn: Nacos auth identity key + labelZh: Nacos身份验证密钥键 + required: true + type: text + - default: "security" + edit: true + envKey: NACOS_AUTH_IDENTITY_VALUE + labelEn: Nacos auth identity value + labelZh: Nacos身份验证密钥值 + required: true + type: text + - default: "SecretKey012345678901234567890123456789012345678901234567890123456789" + edit: true + envKey: NACOS_AUTH_TOKEN + labelEn: Nacos auth token + labelZh: Nacos身份验证令牌 + required: true + type: text + - default: 8848 + edit: true + envKey: PANEL_APP_PORT_HTTP + labelEn: Nacos run port + labelZh: Nacos 运行端口 + required: true + rule: paramPort + type: number + - default: 9848 + edit: true + envKey: NACOS_COMMUNICATION_PORT + labelEn: Nacos communication port + labelZh: Nacos 通讯端口 + required: true + rule: paramPort + type: number + - default: "/home/nacos" + edit: true + envKey: NACOS_DATA_ROOT_PATH + labelEn: Nacos root directory of data storage + labelZh: Nacos 数据存储根目录 + required: true + type: text + - default: "" + edit: true + envKey: NACOS_SERVER_IP + labelEn: IP can be specified in multi network card mode + labelZh: 多网卡模式下可以指定IP + required: false + type: text + - default: "mysql" + edit: true + envKey: SPRING_DATASOURCE_PLATFORM + labelEn: Database type + labelZh: 数据库驱动类型 + required: true + type: select + values: + - label: MySQL + value: mysql + - default: "" + edit: true + envKey: MYSQL_SERVICE_HOST + labelEn: Database host IP + labelZh: 数据库主机IP + required: true + type: text + - default: "nacos" + edit: true + envKey: MYSQL_SERVICE_DB_NAME + labelEn: Database Name + labelZh: 数据库名称 + required: true + type: text + - default: 3306 + edit: true + envKey: MYSQL_SERVICE_PORT + labelEn: Database Port + labelZh: 数据库端口 + rule: paramPort + type: number + - default: "nacos" + edit: true + envKey: MYSQL_SERVICE_USER + labelEn: Database Connection Users + labelZh: 数据库连接用户 + required: true + type: text + - default: "nacos" + edit: true + envKey: MYSQL_SERVICE_PASSWORD + labelEn: Database connection password + labelZh: 数据库连接密码 + required: true + type: password + - default: "characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true" + edit: true + envKey: MYSQL_SERVICE_DB_PARAM + labelEn: Database connection parameters + labelZh: 数据库连接参数 + required: true + type: text + - default: "2g" + edit: true + envKey: JVM_XMS + labelEn: JVM_XMS + labelZh: JVM_XMS + required: true + type: text + - default: "2g" + edit: true + envKey: JVM_XMX + labelEn: JVM_XMX + labelZh: JVM_XMX + required: true + type: text + - default: "1g" + edit: true + envKey: JVM_XMN + labelEn: JVM_XMN + labelZh: JVM_XMN + required: true + type: text + - default: "128m" + edit: true + envKey: JVM_MS + labelEn: JVM_MS + labelZh: JVM_MS + required: true + type: text + - default: "320m" + edit: true + envKey: JVM_MMS + labelEn: JVM_MMS + labelZh: JVM_MMS + required: true + type: text diff --git a/nacos/2.2.0-mysql/derby-schema.sql b/nacos/2.2.0-mysql/derby-schema.sql new file mode 100644 index 000000000..0f8dbbe70 --- /dev/null +++ b/nacos/2.2.0-mysql/derby-schema.sql @@ -0,0 +1,231 @@ +/* + * 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. + */ + +CREATE SCHEMA nacos AUTHORIZATION nacos; + +CREATE TABLE config_info ( + id bigint NOT NULL generated by default as identity, + data_id varchar(255) NOT NULL, + group_id varchar(128) NOT NULL, + tenant_id varchar(128) default '', + app_name varchar(128), + content CLOB, + md5 varchar(32) DEFAULT NULL, + gmt_create timestamp NOT NULL DEFAULT '2010-05-05 00:00:00', + gmt_modified timestamp NOT NULL DEFAULT '2010-05-05 00:00:00', + src_user varchar(128) DEFAULT NULL, + src_ip varchar(50) DEFAULT NULL, + c_desc varchar(256) DEFAULT NULL, + c_use varchar(64) DEFAULT NULL, + effect varchar(64) DEFAULT NULL, + type varchar(64) DEFAULT NULL, + c_schema LONG VARCHAR DEFAULT NULL, + encrypted_data_key LONG VARCHAR DEFAULT NULL, + constraint configinfo_id_key PRIMARY KEY (id), + constraint uk_configinfo_datagrouptenant UNIQUE (data_id,group_id,tenant_id)); + +CREATE INDEX configinfo_dataid_key_idx ON config_info(data_id); +CREATE INDEX configinfo_groupid_key_idx ON config_info(group_id); +CREATE INDEX configinfo_dataid_group_key_idx ON config_info(data_id, group_id); + +CREATE TABLE his_config_info ( + id bigint NOT NULL, + nid bigint NOT NULL generated by default as identity, + data_id varchar(255) NOT NULL, + group_id varchar(128) NOT NULL, + tenant_id varchar(128) default '', + app_name varchar(128), + content CLOB, + md5 varchar(32) DEFAULT NULL, + gmt_create timestamp NOT NULL DEFAULT '2010-05-05 00:00:00.000', + gmt_modified timestamp NOT NULL DEFAULT '2010-05-05 00:00:00.000', + src_user varchar(128), + src_ip varchar(50) DEFAULT NULL, + op_type char(10) DEFAULT NULL, + encrypted_data_key LONG VARCHAR DEFAULT NULL, + constraint hisconfiginfo_nid_key PRIMARY KEY (nid)); + +CREATE INDEX hisconfiginfo_dataid_key_idx ON his_config_info(data_id); +CREATE INDEX hisconfiginfo_gmt_create_idx ON his_config_info(gmt_create); +CREATE INDEX hisconfiginfo_gmt_modified_idx ON his_config_info(gmt_modified); + + +CREATE TABLE config_info_beta ( + id bigint NOT NULL generated by default as identity, + data_id varchar(255) NOT NULL, + group_id varchar(128) NOT NULL, + tenant_id varchar(128) default '', + app_name varchar(128), + content CLOB, + beta_ips varchar(1024), + md5 varchar(32) DEFAULT NULL, + gmt_create timestamp NOT NULL DEFAULT '2010-05-05 00:00:00', + gmt_modified timestamp NOT NULL DEFAULT '2010-05-05 00:00:00', + src_user varchar(128), + src_ip varchar(50) DEFAULT NULL, + encrypted_data_key LONG VARCHAR DEFAULT NULL, + constraint configinfobeta_id_key PRIMARY KEY (id), + constraint uk_configinfobeta_datagrouptenant UNIQUE (data_id,group_id,tenant_id)); + +CREATE TABLE config_info_tag ( + id bigint NOT NULL generated by default as identity, + data_id varchar(255) NOT NULL, + group_id varchar(128) NOT NULL, + tenant_id varchar(128) default '', + tag_id varchar(128) NOT NULL, + app_name varchar(128), + content CLOB, + md5 varchar(32) DEFAULT NULL, + gmt_create timestamp NOT NULL DEFAULT '2010-05-05 00:00:00', + gmt_modified timestamp NOT NULL DEFAULT '2010-05-05 00:00:00', + src_user varchar(128), + src_ip varchar(50) DEFAULT NULL, + constraint configinfotag_id_key PRIMARY KEY (id), + constraint uk_configinfotag_datagrouptenanttag UNIQUE (data_id,group_id,tenant_id,tag_id)); + +CREATE TABLE config_info_aggr ( + id bigint NOT NULL generated by default as identity, + data_id varchar(255) NOT NULL, + group_id varchar(128) NOT NULL, + tenant_id varchar(128) default '', + datum_id varchar(255) NOT NULL, + app_name varchar(128), + content CLOB, + gmt_modified timestamp NOT NULL DEFAULT '2010-05-05 00:00:00', + constraint configinfoaggr_id_key PRIMARY KEY (id), + constraint uk_configinfoaggr_datagrouptenantdatum UNIQUE (data_id,group_id,tenant_id,datum_id)); + +CREATE TABLE app_list ( + id bigint NOT NULL generated by default as identity, + app_name varchar(128) NOT NULL, + is_dynamic_collect_disabled smallint DEFAULT 0, + last_sub_info_collected_time timestamp DEFAULT '1970-01-01 08:00:00.0', + sub_info_lock_owner varchar(128), + sub_info_lock_time timestamp DEFAULT '1970-01-01 08:00:00.0', + constraint applist_id_key PRIMARY KEY (id), + constraint uk_appname UNIQUE (app_name)); + +CREATE TABLE app_configdata_relation_subs ( + id bigint NOT NULL generated by default as identity, + app_name varchar(128) NOT NULL, + data_id varchar(255) NOT NULL, + group_id varchar(128) NOT NULL, + gmt_modified timestamp DEFAULT '2010-05-05 00:00:00', + constraint configdatarelationsubs_id_key PRIMARY KEY (id), + constraint uk_app_sub_config_datagroup UNIQUE (app_name, data_id, group_id)); + + +CREATE TABLE app_configdata_relation_pubs ( + id bigint NOT NULL generated by default as identity, + app_name varchar(128) NOT NULL, + data_id varchar(255) NOT NULL, + group_id varchar(128) NOT NULL, + gmt_modified timestamp DEFAULT '2010-05-05 00:00:00', + constraint configdatarelationpubs_id_key PRIMARY KEY (id), + constraint uk_app_pub_config_datagroup UNIQUE (app_name, data_id, group_id)); + +CREATE TABLE config_tags_relation ( + id bigint NOT NULL, + tag_name varchar(128) NOT NULL, + tag_type varchar(64) DEFAULT NULL, + data_id varchar(255) NOT NULL, + group_id varchar(128) NOT NULL, + tenant_id varchar(128) DEFAULT '', + nid bigint NOT NULL generated by default as identity, + constraint config_tags_id_key PRIMARY KEY (nid), + constraint uk_configtagrelation_configidtag UNIQUE (id, tag_name, tag_type)); + +CREATE INDEX config_tags_tenant_id_idx ON config_tags_relation(tenant_id); + +CREATE TABLE group_capacity ( + id bigint NOT NULL generated by default as identity, + group_id varchar(128) DEFAULT '', + quota int DEFAULT 0, + usage int DEFAULT 0, + max_size int DEFAULT 0, + max_aggr_count int DEFAULT 0, + max_aggr_size int DEFAULT 0, + max_history_count int DEFAULT 0, + gmt_create timestamp DEFAULT '2010-05-05 00:00:00', + gmt_modified timestamp DEFAULT '2010-05-05 00:00:00', + constraint group_capacity_id_key PRIMARY KEY (id), + constraint uk_group_id UNIQUE (group_id)); + +CREATE TABLE tenant_capacity ( + id bigint NOT NULL generated by default as identity, + tenant_id varchar(128) DEFAULT '', + quota int DEFAULT 0, + usage int DEFAULT 0, + max_size int DEFAULT 0, + max_aggr_count int DEFAULT 0, + max_aggr_size int DEFAULT 0, + max_history_count int DEFAULT 0, + gmt_create timestamp DEFAULT '2010-05-05 00:00:00', + gmt_modified timestamp DEFAULT '2010-05-05 00:00:00', + constraint tenant_capacity_id_key PRIMARY KEY (id), + constraint uk_tenant_id UNIQUE (tenant_id)); + +CREATE TABLE tenant_info ( + id bigint NOT NULL generated by default as identity, + kp varchar(128) NOT NULL, + tenant_id varchar(128) DEFAULT '', + tenant_name varchar(128) DEFAULT '', + tenant_desc varchar(256) DEFAULT NULL, + create_source varchar(32) DEFAULT NULL, + gmt_create bigint NOT NULL, + gmt_modified bigint NOT NULL, + constraint tenant_info_id_key PRIMARY KEY (id), + constraint uk_tenant_info_kptenantid UNIQUE (kp,tenant_id)); +CREATE INDEX tenant_info_tenant_id_idx ON tenant_info(tenant_id); + +CREATE TABLE users ( + username varchar(50) NOT NULL PRIMARY KEY, + password varchar(500) NOT NULL, + enabled boolean NOT NULL DEFAULT true +); + +CREATE TABLE roles ( + username varchar(50) NOT NULL, + role varchar(50) NOT NULL, + constraint uk_username_role UNIQUE (username,role) +); + +CREATE TABLE permissions ( + role varchar(50) NOT NULL, + resource varchar(512) NOT NULL, + action varchar(8) NOT NULL, + constraint uk_role_permission UNIQUE (role,resource,action) +); + +INSERT INTO users (username, password, enabled) VALUES ('nacos', '$2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu', TRUE); + +INSERT INTO roles (username, role) VALUES ('nacos', 'ROLE_ADMIN'); + + +/******************************************/ +/* ipv6 support */ +/******************************************/ +ALTER TABLE `config_info_tag` +MODIFY COLUMN `src_ip` varchar(50) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL COMMENT 'source ip' AFTER `src_user`; + +ALTER TABLE `his_config_info` +MODIFY COLUMN `src_ip` varchar(50) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL AFTER `src_user`; + +ALTER TABLE `config_info` +MODIFY COLUMN `src_ip` varchar(50) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL COMMENT 'source ip' AFTER `src_user`; + +ALTER TABLE `config_info_beta` +MODIFY COLUMN `src_ip` varchar(50) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL COMMENT 'source ip' AFTER `src_user`; \ No newline at end of file diff --git a/nacos/2.2.0-mysql/docker-compose.yml b/nacos/2.2.0-mysql/docker-compose.yml new file mode 100644 index 000000000..956ebb5b3 --- /dev/null +++ b/nacos/2.2.0-mysql/docker-compose.yml @@ -0,0 +1,32 @@ +version: "2" +services: + nacos: + image: nacos/nacos-server:v2.2.0 + container_name: ${CONTAINER_NAME}-mysql + restart: always + environment: + - PREFER_HOST_MODE=hostname + - MODE=standalone + - JVM_XMS=${JVM_XMS} + - JVM_XMX=${JVM_XMX} + - JVM_XMN=${JVM_XMN} + - JVM_MS=${JVM_MS} + - JVM_MMS=${JVM_MMS} + - NACOS_AUTH_IDENTITY_KEY=${NACOS_AUTH_IDENTITY_KEY} + - NACOS_AUTH_IDENTITY_VALUE=${NACOS_AUTH_IDENTITY_VALUE} + - NACOS_AUTH_TOKEN=${NACOS_AUTH_TOKEN} + - NACOS_SERVER_IP=${NACOS_SERVER_IP} + - SPRING_DATASOURCE_PLATFORM=${SPRING_DATASOURCE_PLATFORM} + - MYSQL_SERVICE_HOST=${MYSQL_SERVICE_HOST} + - MYSQL_SERVICE_PORT=${MYSQL_SERVICE_PORT} + - MYSQL_SERVICE_USER=${MYSQL_SERVICE_USER} + - MYSQL_SERVICE_PASSWORD=${MYSQL_SERVICE_PASSWORD} + - MYSQL_SERVICE_DB_NAME=${MYSQL_SERVICE_DB_NAME} + volumes: + - ./log/standalone-logs/:/home/nacos/logs + ports: + - "${PANEL_APP_PORT_HTTP}:8848" + - "${NACOS_COMMUNICATION_PORT}:9848" +networks: + 1panel-network: + external: true diff --git a/nacos/2.2.0-mysql/mysql-schema.sql b/nacos/2.2.0-mysql/mysql-schema.sql new file mode 100644 index 000000000..146626488 --- /dev/null +++ b/nacos/2.2.0-mysql/mysql-schema.sql @@ -0,0 +1,221 @@ +/* + * 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(128) 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, + `c_schema` text, + `encrypted_data_key` text NOT NULL 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 */ +/******************************************/ +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(128) 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 '租户字段', + `encrypted_data_key` text NOT NULL 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(20) 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` text NOT NULL 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 */ +/******************************************/ +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'); diff --git a/nacos/README.md b/nacos/README.md new file mode 100644 index 000000000..5df940eb5 --- /dev/null +++ b/nacos/README.md @@ -0,0 +1,89 @@ +# Nacos + +Nacos `/nɑ:kəʊs/` 是 Dynamic Naming and Configuration Service的首字母简称,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。 + +Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。 + +Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 ( +例如微服务范式、云原生范式) 的服务基础设施。 + +## 快速启动 + +访问地址 +`http://IP:8848/nacos` + +> 用户名 +> nacos +> +> 密码 +> nacos + +## Nacos 的关键特性 + +### 服务发现和服务健康监测 + +Nacos 支持基于 DNS 和基于 RPC 的服务发现。服务提供者使用 原生SDK、OpenAPI、或一个独立的Agent TODO注册 Service +后,服务消费者可以使用DNS TODO 或HTTP&API查找和发现服务。 + +Nacos 提供对服务的实时的健康检查,阻止向不健康的主机或服务实例发送请求。Nacos 支持传输层 (PING 或 TCP)和应用层 (如 +HTTP、MySQL、用户自定义)的健康检查。 对于复杂的云环境和网络拓扑环境中(如 VPC、边缘网络等)服务的健康检查,Nacos 提供了 agent +上报模式和服务端主动检测2种健康检查模式。Nacos 还提供了统一的健康检查仪表盘,帮助您根据健康状态管理服务的可用性及流量。 + +### 动态配置服务 + +动态配置服务可以让您以中心化、外部化和动态化的方式管理所有环境的应用配置和服务配置。 + +动态配置消除了配置变更时重新部署应用和服务的需要,让配置管理变得更加高效和敏捷。 + +配置中心化管理让实现无状态服务变得更简单,让服务按需弹性扩展变得更容易。 + +Nacos 提供了一个简洁易用的UI (控制台样例 Demo) 帮助您管理所有的服务和应用的配置。Nacos +还提供包括配置版本跟踪、金丝雀发布、一键回滚配置以及客户端配置更新状态跟踪在内的一系列开箱即用的配置管理特性,帮助您更安全地在生产环境中管理配置变更和降低配置变更带来的风险。 + +### 动态 DNS 服务 + +动态 DNS 服务支持权重路由,让您更容易地实现中间层负载均衡、更灵活的路由策略、流量控制以及数据中心内网的简单DNS解析服务。动态DNS服务还能让您更容易地实现以 +DNS 协议为基础的服务发现,以帮助您消除耦合到厂商私有服务发现 API 上的风险。 + +Nacos 提供了一些简单的 DNS APIs TODO 帮助您管理服务的关联域名和可用的 IP 列表. + +### 服务及其元数据管理 + +Nacos 能让您从微服务平台建设的视角管理数据中心的所有服务及元数据,包括管理服务的描述、生命周期、服务的静态依赖分析、服务的健康状态、服务的流量管理、路由及安全策略、服务的 +SLA 以及最首要的 metrics 统计数据。 + +## 版本说明 + +### 2.2.0-derby + +derby 单机模式 + +数据存于本地文件目录 +`/home/nacos` + +### 2.2.0-mysql + +derby 单机模式 + mysql +数据存于mysql + +#### 数据库初始化 + +下载数据库文件 `mysql-schema.sql` + +[https://github.com/alibaba/nacos/tree/develop/distribution/conf](https://github.com/alibaba/nacos/tree/develop/distribution/conf) + +导入数据文件 `mysql-schema.sql` 或通过工具导入/执行语句 + +```shell +mysql -uroot -p123456 -h127.0.0.1 -P3306 nacos < mysql-schema.sql +``` + +## 参数调优 + +```shell +- JVM_XMS=64m #-Xms default :2g +- JVM_XMX=64m #-Xmx default :2g +- JVM_XMN=16m #-Xmn default :1g +- JVM_MS=8m #-XX:MetaspaceSize default :128m +- JVM_MMS=8m #-XX:MaxMetaspaceSize default :320m +``` diff --git a/nacos/data.yml b/nacos/data.yml new file mode 100644 index 000000000..8011019f0 --- /dev/null +++ b/nacos/data.yml @@ -0,0 +1,19 @@ +name: Nacos +tags: + - 中间件 +title: Nacos +type: 中间件 +description: 动态服务发现、配置管理和服务管理平台 +additionalProperties: + key: nacos + name: Nacos + tags: + - Middleware + shortDescZh: 动态命名和配置服务 + shortDescEn: Dynamic Naming and Configuration Service + type: runtime + crossVersionUpdate: false + limit: 1 + website: https://nacos.io/ + github: https://github.com/alibaba/nacos + document: https://github.com/alibaba/nacos/blob/develop/README.md diff --git a/nacos/logo.png b/nacos/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..33270c30e3504acbddcc93eed4ac84d5f781fdb7 GIT binary patch literal 12708 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 用户名 +> sentinel +> +> 密码 +> sentinel + +## Sentinel 的历史 + ++ 2012 年,Sentinel 诞生,主要功能为入口流量控制。 ++ 2013-2017 年,Sentinel 在阿里巴巴集团内部迅速发展,成为基础技术模块,覆盖了所有的核心场景。Sentinel 也因此积累了大量的流量归整场景以及生产实践。 ++ 2018 年,Sentinel 开源,并持续演进。 ++ 2019 年,Sentinel 朝着多语言扩展的方向不断探索,推出 C++ 原生版本,同时针对 Service Mesh 场景也推出了 Envoy 集群流量控制支持,以解决 + Service Mesh 架构下多语言限流的问题。 ++ 2020 年,推出 Sentinel Go 版本,继续朝着云原生方向演进。 ++ 2021 年,Sentinel 正在朝着 2.0 云原生高可用决策中心组件进行演进;同时推出了 Sentinel Rust 原生版本。同时我们也在 Rust + 社区进行了 Envoy WASM extension 及 eBPF extension 等场景探索。 ++ 2022 年,Sentinel 品牌升级为流量治理,领域涵盖流量路由/调度、流量染色、流控降级、过载保护/实例摘除等;同时社区将流量治理相关标准抽出到 + OpenSergo 标准中,Sentinel 作为流量治理标准实现。 + +## Sentinel 基本概念 + +### 资源 + +资源是 Sentinel 的关键概念。它可以是 Java 应用程序中的任何内容,例如,由应用程序提供的服务,或由应用程序调用的其它应用提供的服务,甚至可以是一段代码。在接下来的文档中,我们都会用资源来描述代码块。 + +只要通过 Sentinel API 定义的代码,就是资源,能够被 Sentinel 保护起来。大部分情况下,可以使用方法签名,URL,甚至服务名称作为资源名来标示资源。 + +### 规则 + +围绕资源的实时状态设定的规则,可以包括流量控制规则、熔断降级规则以及系统保护规则。所有规则可以动态实时调整。 + +## Sentinel 是如何工作的 + +Sentinel 的主要工作机制如下: + ++ 对主流框架提供适配或者显示的 API,来定义需要保护的资源,并提供设施对资源进行实时统计和调用链路分析。 ++ 根据预设的规则,结合对资源的实时统计信息,对流量进行控制。同时,Sentinel 提供开放的接口,方便您定义及改变规则。 ++ Sentinel 提供实时的监控系统,方便您快速了解目前系统的状态。 diff --git a/sentinel-dashboard/data.yml b/sentinel-dashboard/data.yml new file mode 100644 index 000000000..e222608ef --- /dev/null +++ b/sentinel-dashboard/data.yml @@ -0,0 +1,19 @@ +name: sentinel-dashboard +tags: + - 中间件 +title: Sentinel-Dashboard +type: 中间件 +description: 阿里巴巴流量卫兵 +additionalProperties: + key: sentinel-dashboard + name: Sentinel-Dashboard + tags: + - Middleware + shortDescZh: 阿里巴巴流量卫兵 + shortDescEn: Alibaba Traffic Guard + type: runtime + crossVersionUpdate: false + limit: 0 + website: https://sentinelguard.io/ + github: https://github.com/alibaba/Sentinel + document: https://sentinelguard.io/zh-cn/docs/introduction.html diff --git a/sentinel-dashboard/latest/data.yml b/sentinel-dashboard/latest/data.yml new file mode 100644 index 000000000..ca5f82f11 --- /dev/null +++ b/sentinel-dashboard/latest/data.yml @@ -0,0 +1,18 @@ +additionalProperties: + formFields: + - default: 8858 + edit: true + envKey: PANEL_APP_PORT_HTTP + labelEn: Web port + labelZh: Web 端口 + required: true + rule: paramPort + type: number + - default: 8719 + edit: true + envKey: COMMUNICATION_PORT + labelEn: Communication port + labelZh: 通讯端口 + required: true + rule: paramPort + type: number diff --git a/sentinel-dashboard/latest/docker-compose.yml b/sentinel-dashboard/latest/docker-compose.yml new file mode 100644 index 000000000..bff233bc5 --- /dev/null +++ b/sentinel-dashboard/latest/docker-compose.yml @@ -0,0 +1,12 @@ +version: "3" +services: + "sentinel-dashboard": + image: bladex/sentinel-dashboard:latest + container_name: ${CONTAINER_NAME} + restart: always + ports: + - "${PANEL_APP_PORT_HTTP}:8858" + - "${COMMUNICATION_PORT}:8719" +networks: + 1panel-network: + external: true diff --git a/sentinel-dashboard/logo.png b/sentinel-dashboard/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..3f493afc779f6e2021bbbcae4696dce4b7a6219d GIT binary patch literal 12548 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 s-+rP&