• Docker:docker部署Nacos(单例与集群)并配置自定义Mysql


    拉取Nacos镜像

    下载nacos镜像

    #默认拉取最新的Nacos镜像
    docker pull nacos/nacos-server

    容器生成一:单例容器创建

        1. 创建简单的单例Nacos服务

    # 启动容器
    docker run -d --name nacos -p 8848:8848 -e PREFER_HOST_MODE=hostname -e MODE=standalone -t nacos/nacos-server

        2. Nacos容器生成可配参数表

    Nacos配置参数

    参数描述

    参数可选值域

    默认值

    MODE

    cluster模式/standalone模式

    cluster/standalone 

    cluster 

    NACOS_SERVERS

    nacos cluster地址

    ip1 ip2 ip3

    示例:

    NACOS_SERVERS="nacos1-ip:8848 nacos2-ip:8848 nacos3-ip:8848"

    PREFER_HOST_MODE

    是否支持hostname 

     hostname/ip

    ip 

    NACOS_SERVER_PORT

    nacos服务器端口 

     

    8848 

    NACOS_SERVER_IP

     多网卡下的自定义nacos服务器IP

     

     

    SPRING_DATASOURCE_PLATFORM

    MODE的配置参数(standalone) 支持 mysql 

     mysql/empty

    empty 

    MYSQL_MASTER_SERVICE_HOST

    mysql 主节点host 

     

    示例:

    MYSQL_SERVICE_HOST=119.90.153.96

    MYSQL_MASTER_SERVICE_PORT

     mysql 主节点端口

     

     3306

    MYSQL_MASTER_SERVICE_DB_NAME

    mysql 主节点数据库 

     

    指定nacos库表:

    MYSQL_SERVICE_DB_NAME=nacos

    MYSQL_MASTER_SERVICE_USER

     数据库用户名

     

     

    MYSQL_MASTER_SERVICE_PASSWORD

     数据库密码

     

     

    MYSQL_SLAVE_SERVICE_HOST

    mysql从节点host 

     

     

    MYSQL_SLAVE_SERVICE_PORT

    mysql从节点端口 

     

     3306

    MYSQL_DATABASE_NUM

     数据库数量

     

    JVM_XMS

    JVM虚拟机设置-Xms 

     

     2g

    JVM_XMX

     JVM虚拟机设置-Xmx

     

     2g

    JVM_XMN

     JVM虚拟机设置-Xmn

     

     1g

    JVM_MS

    JVM虚拟机设置-XX:MetaspaceSize  

     

     128m

    JVM_MMS

     JVM虚拟机设置-XX:MaxMetaspaceSize 

     

     320m

    NACOS_DEBUG

    开启远程调试 

     y/n

    TOMCAT_ACCESSLOG_ENABLED

    server.tomcat.accesslog.enabled 

     

     false

        3. Nacos服务访问地址

          地址:http://ip:8848/nacos 账号:nacos 密码:nacos

    容器生成二:集群容器搭建

        1. 创建Nacos-1容器

    docker run -it \
    -e PREFER_HOST_MODE=ip \
    -e MODE=cluster \
    -e NACOS_SERVERS="172.18.1.42:8848 172.18.1.43:8848" \
    -e SPRING_DATASOURCE_PLATFORM=mysql \
    -e MYSQL_SERVICE_HOST=172.18.1.30 \
    -e MYSQL_SERVICE_PORT=3306 \
    -e MYSQL_SERVICE_DB_NAME=nacos \
    -e MYSQL_SERVICE_USER=root \
    -e MYSQL_SERVICE_PASSWORD=password \
    -p 9901:8848 \
    --name nacos01 \
    --net mynet --ip 172.18.1.41 \
    --restart=always \
    nacos/nacos-server

        2. 创建Nacos-2容器

    docker run -it \
    -e PREFER_HOST_MODE=ip \
    -e MODE=cluster \
    -e NACOS_SERVERS="172.18.1.41:8848 172.18.1.43:8848" \
    -e SPRING_DATASOURCE_PLATFORM=mysql \
    -e MYSQL_SERVICE_HOST=172.18.1.30 \
    -e MYSQL_SERVICE_PORT=3306 \
    -e MYSQL_SERVICE_DB_NAME=nacos \
    -e MYSQL_SERVICE_USER=root \
    -e MYSQL_SERVICE_PASSWORD=root123 \
    -p 9902:8848 \
    --name nacos02 \
    --net mynet --ip 172.18.1.42 \
    --restart=always \
    nacos/nacos-server

        3. Nacos容器生成可配参数表

    Nacos配置参数

    参数描述

    参数可选值域

    默认值

    MODE

    cluster模式/standalone模式

    cluster/standalone 

    cluster 

    NACOS_SERVERS

    nacos cluster地址

    ip1 ip2 ip3

    示例:

    NACOS_SERVERS="nacos1-ip:8848 nacos2-ip:8848 nacos3-ip:8848"

    PREFER_HOST_MODE

    是否支持hostname 

     hostname/ip

    ip 

    NACOS_SERVER_PORT

    nacos服务器端口 

     

    8848 

    NACOS_SERVER_IP

     多网卡下的自定义nacos服务器IP

     

     

    SPRING_DATASOURCE_PLATFORM

    MODE的配置参数(standalone) 支持 mysql 

     mysql/empty

    empty 

    MYSQL_MASTER_SERVICE_HOST

    mysql 主节点host 

     

    示例:

    MYSQL_SERVICE_HOST=119.90.153.96

    MYSQL_MASTER_SERVICE_PORT

     mysql 主节点端口

     

     3306

    MYSQL_MASTER_SERVICE_DB_NAME

    mysql 主节点数据库 

     

    指定nacos库表:

    MYSQL_SERVICE_DB_NAME=nacos

    MYSQL_MASTER_SERVICE_USER

     数据库用户名

     

     

    MYSQL_MASTER_SERVICE_PASSWORD

     数据库密码

     

     

    MYSQL_SLAVE_SERVICE_HOST

    mysql从节点host 

     

     

    MYSQL_SLAVE_SERVICE_PORT

    mysql从节点端口 

     

     3306

    MYSQL_DATABASE_NUM

     数据库数量

     

    JVM_XMS

    JVM虚拟机设置-Xms 

     

     2g

    JVM_XMX

     JVM虚拟机设置-Xmx

     

     2g

    JVM_XMN

     JVM虚拟机设置-Xmn

     

     1g

    JVM_MS

    JVM虚拟机设置-XX:MetaspaceSize  

     

     128m

    JVM_MMS

     JVM虚拟机设置-XX:MaxMetaspaceSize 

     

     320m

    NACOS_DEBUG

    开启远程调试 

     y/n

    TOMCAT_ACCESSLOG_ENABLED

    server.tomcat.accesslog.enabled 

     

     false

     

        4. 查看到集群中有多少台服务器

        5. 实现Nginx搭建负载均衡

          1) 为什么要实现反向代理?

               因为一个集群中两台服务之间没有联系,必须给这两台服务进行建立联系,才能登一个账号可以进行同步操作。

          2) 修改Nginx的配置文件 defalut.conf

    upstream nacosList {
        server 172.18.1.41:8848 weight=1;
        server 172.18.1.42:8848 weight=2;
    }
    
    server {
        listen  80;
        server_name  www.zking.com;
    
        location / {
            root   /etc/nginx/html/;
            index  index.html index.htm;
        }
    
        error_page   500 502 503 504  /50x.html;
    
        location = /50x.html {
            root   /usr/share/nginx/html;
        }
    
        location /nacos {
            proxy_pass  http://nacosList;
        }
    
    }

          3)生成Nginx容器

    docker run -itd \
    --name nginx \
    --net mynet \
    -v /home/nginx/conf.d:/etc/nginx/conf.d \ -v /home/nginx/html:/etc/nginx/html \ -v /home/nginx/log:/usr/log/nginx \ -p 8080:80 \ nginx

           4) 访问Nginx的地址

            地址 http://localhost:80/nacos

    在这里插入图片描述

     Nacos的Mysql文件

    /*
     * 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,
      `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 '租户字段',
      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');
    Nacos Mysql Table

    文章整合至:https://blog.csdn.net/qq_34807429/article/details/103779305https://blog.csdn.net/m0_53151031/article/details/123118920https://copyfuture.com/blogs-details/20200117121620859lkygduriq48ayjc

  • 相关阅读:
    Python:起步
    实战Django:Rango Part8
    实战Django:Rango Part7
    实战Django:Rango Part6
    实战Django:Rango Part5
    实战Django:Rango Part4
    Fitnesse集成TestLink
    oracle存储过程代码覆盖率统计工具
    ant svn
    Jenkins中关于一些插件的使用方法
  • 原文地址:https://www.cnblogs.com/nhdlb/p/16139178.html
Copyright © 2020-2023  润新知