当前位置:   article > 正文

docker中安装MySQL、Nacos_docker nacos mysql

docker nacos mysql

一、安装docker

  1. yum install wget.x86_64 -y
  2. rm -rf /etc/yum.repos.d/*
  3. wget -O /etc/yum.repos.d/centos7.repo http://mirrors.aliyun.com/repo/Centos-7.repo
  4. wget -O /etc/yum.repos.d/epel-7.repo http://mirrors.aliyun.com/repo/epel-7.repo
  5. wget -O /etc/yum.repos.d/docker-ce.repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
  6. yum install docker-ce-20.10.11 -y
  7. systemctl start docker
  8. systemctl enable docker
  9. docker version

配置docker加速器

  1. mkdir -p /etc/docker
  2. tee /etc/docker/daemon.json <<-'EOF'
  3. {
  4. "registry-mirrors": ["https://2tefyfv7.mirror.aliyuncs.com"]
  5. }
  6. EOF
  7. systemctl daemon-reload
  8. systemctl restart docker

二、安装mysql

  1. #可以自己选择安装的数据库版本
  2. docker pull mysql:8.0.27
  3. #下载完成后创建在/home/mysql/下新建两个对应文件夹,可以代码实现,也可以通过图形化工具手动创建
  4. mkdir -p /home/mysql/{date,conf}
  5. #创建完成后在conf文件中新建my.conf文件进行配置:

创建my.cnf文件

vim /home/mysql/conf/my.cnf
  1. [mysqld]
  2. #Mysql服务的唯一编号 每个mysql服务Id需唯一
  3. server-id=1
  4. #服务端口号 默认3306
  5. port=3306
  6. #mysql安装根目录(default /usr)
  7. #basedir=/usr/local/mysql
  8. #mysql数据文件所在位置
  9. datadir=/var/lib/mysql
  10. #pid
  11. pid-file=/var/run/mysqld/mysqld.pid
  12. #设置socke文件所在目录
  13. socket=/var/lib/mysql/mysql.sock
  14. #设置临时目录
  15. #tmpdir=/tmp
  16. # 用户
  17. user=mysql
  18. # 允许访问的IP网段
  19. bind-address=0.0.0.0
  20. # 跳过密码登录
  21. #skip-grant-tables
  22. #主要用于MyISAM存储引擎,如果多台服务器连接一个数据库则建议注释下面内容
  23. #skip-external-locking
  24. #只能用IP地址检查客户端的登录,不用主机名
  25. #skip_name_resolve=1
  26. #事务隔离级别,默认为可重复读,mysql默认可重复读级别(此级别下可能参数很多间隙锁,影响性能)
  27. #transaction_isolation=READ-COMMITTED
  28. #数据库默认字符集,主流字符集支持一些特殊表情符号(特殊表情符占用4个字节)
  29. character-set-server=utf8mb4
  30. #数据库字符集对应一些排序等规则,注意要和character-set-server对应
  31. collation-server=utf8mb4_general_ci
  32. #设置client连接mysql时的字符集,防止乱码
  33. init_connect='SET NAMES utf8mb4'
  34. #是否对sql语句大小写敏感,1表示不敏感
  35. lower_case_table_names=1
  36. #最大连接数
  37. max_connections=400
  38. #最大错误连接数
  39. max_connect_errors=1000
  40. #TIMESTAMP如果没有显示声明NOT NULL,允许NULL值
  41. explicit_defaults_for_timestamp=true
  42. #SQL数据包发送的大小,如果有BLOB对象建议修改成1G
  43. max_allowed_packet=128M
  44. #MySQL连接闲置超过一定时间后(单位:秒)将会被强行关闭
  45. #MySQL默认的wait_timeout 值为8个小时, interactive_timeout参数需要同时配置才能生效
  46. interactive_timeout=1800
  47. wait_timeout=1800
  48. #内部内存临时表的最大值 ,设置成128M。
  49. #比如大数据量的group by ,order by时可能用到临时表,
  50. #超过了这个值将写入磁盘,系统IO压力增大
  51. tmp_table_size=134217728
  52. max_heap_table_size=134217728
  53. #禁用mysql的缓存查询结果集功能
  54. #后期根据业务情况测试决定是否开启
  55. #大部分情况下关闭下面两项
  56. #query_cache_size = 0
  57. #query_cache_type = 0
  58. #数据库错误日志文件
  59. #log-error=/var/log/mysqld.log
  60. #慢查询sql日志设置
  61. #slow_query_log=1
  62. #slow_query_log_file=/var/log/mysqld_slow.log
  63. #检查未使用到索引的sql
  64. log_queries_not_using_indexes=1
  65. #针对log_queries_not_using_indexes开启后,记录慢sql的频次、每分钟记录的条数
  66. log_throttle_queries_not_using_indexes=5
  67. #作为从库时生效,从库复制中如何有慢sql也将被记录
  68. log_slow_slave_statements=1
  69. #慢查询执行的秒数,必须达到此值可被记录
  70. long_query_time=8
  71. #检索的行数必须达到此值才可被记为慢查询
  72. min_examined_row_limit=100
  73. #mysql binlog日志文件保存的过期时间,过期后自动删除
  74. #expire_logs_days=5
  75. binlog_expire_logs_seconds=604800

启动MySQL容器

docker run -itd -p 3306:3306  --name mysql  -v /home/mysql/conf/my.cnf:/etc/my.cnf  -v /home/mysql/data:/var/lib/mysql --privileged=true --restart=always  -e MYSQL_ROOT_PASSWORD=root -d mysql:8.0.27

初始账号密码:root/root

使用工具连接mysql

如果测试连接报错:

Public Key Retrieval is not allowed Public Key Retrieval is not allowed

修改连接属性

三、安装nacos

拉取对应的镜像文件

docker pull nacos/nacos-server:v2.1.1

挂载目录:

  1. mkdir -p /mydata/nacos/logs/ #新建logs目录

启动nacos容器 

  1. docker run \
  2. --name nacos -d \
  3. -p 8848:8848 \
  4. --privileged=true \
  5. --restart=always \
  6. -e JVM_XMS=256m \
  7. -e JVM_XMX=256m \
  8. -e MODE=standalone \
  9. -e PREFER_HOST_MODE=hostname \
  10. -v /mydata/nacos/logs:/home/nacos/logs \
  11. nacos/nacos-server:v2.1.1

 此时nacos容器就安装成功了可以打开浏览器进行登录:

账号:nacos 密码:nacos

四、nacos持久化MySQL

Nacos 以standalone(单机模式)启动后,默认使用的内嵌式数据库 Derby;

在MySQL中创建nacos数据库

执行sql脚本

  1. -- nacos.config_info definition
  2. CREATE TABLE `config_info` (
  3. `id` bigint NOT NULL AUTO_INCREMENT COMMENT 'id',
  4. `data_id` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL COMMENT 'data_id',
  5. `group_id` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  6. `content` longtext CHARACTER SET utf8 COLLATE utf8_bin COMMENT 'content',
  7. `md5` varchar(32) COLLATE utf8_bin DEFAULT NULL COMMENT 'md5',
  8. `gmt_create` datetime DEFAULT '2010-05-05 00:00:00' COMMENT '创建时间',
  9. `gmt_modified` datetime DEFAULT '2010-05-05 00:00:00' COMMENT '修改时间',
  10. `src_user` text COLLATE utf8_bin COMMENT 'source user',
  11. `src_ip` varchar(20) COLLATE utf8_bin DEFAULT NULL COMMENT 'source ip',
  12. `app_name` varchar(128) COLLATE utf8_bin DEFAULT NULL,
  13. `tenant_id` varchar(128) COLLATE utf8_bin DEFAULT '' COMMENT '租户字段',
  14. `c_desc` varchar(256) COLLATE utf8_bin DEFAULT NULL,
  15. `c_use` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  16. `effect` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  17. `type` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  18. `c_schema` text COLLATE utf8_bin,
  19. `encrypted_data_key` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  20. PRIMARY KEY (`id`),
  21. UNIQUE KEY `uk_configinfo_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)
  22. ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb3 COLLATE=utf8_bin COMMENT='config_info';
  23. -- nacos.config_info_aggr definition
  24. CREATE TABLE `config_info_aggr` (
  25. `id` bigint NOT NULL AUTO_INCREMENT COMMENT 'id',
  26. `data_id` varchar(255) COLLATE utf8_bin NOT NULL COMMENT 'data_id',
  27. `group_id` varchar(255) COLLATE utf8_bin NOT NULL COMMENT 'group_id',
  28. `datum_id` varchar(255) COLLATE utf8_bin NOT NULL COMMENT 'datum_id',
  29. `content` longtext COLLATE utf8_bin NOT NULL COMMENT '内容',
  30. `gmt_modified` datetime NOT NULL COMMENT '修改时间',
  31. `app_name` varchar(128) COLLATE utf8_bin DEFAULT NULL,
  32. `tenant_id` varchar(128) COLLATE utf8_bin DEFAULT '' COMMENT '租户字段',
  33. PRIMARY KEY (`id`),
  34. UNIQUE KEY `uk_configinfoaggr_datagrouptenantdatum` (`data_id`,`group_id`,`tenant_id`,`datum_id`)
  35. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COLLATE=utf8_bin COMMENT='增加租户字段';
  36. -- nacos.config_info_beta definition
  37. CREATE TABLE `config_info_beta` (
  38. `id` bigint NOT NULL AUTO_INCREMENT COMMENT 'id',
  39. `data_id` varchar(255) COLLATE utf8_bin NOT NULL COMMENT 'data_id',
  40. `group_id` varchar(128) COLLATE utf8_bin NOT NULL COMMENT 'group_id',
  41. `app_name` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'app_name',
  42. `content` longtext COLLATE utf8_bin NOT NULL COMMENT 'content',
  43. `beta_ips` varchar(1024) COLLATE utf8_bin DEFAULT NULL COMMENT 'betaIps',
  44. `md5` varchar(32) COLLATE utf8_bin DEFAULT NULL COMMENT 'md5',
  45. `gmt_create` datetime NOT NULL DEFAULT '2010-05-05 00:00:00' COMMENT '创建时间',
  46. `gmt_modified` datetime NOT NULL DEFAULT '2010-05-05 00:00:00' COMMENT '修改时间',
  47. `src_user` text COLLATE utf8_bin COMMENT 'source user',
  48. `src_ip` varchar(20) COLLATE utf8_bin DEFAULT NULL COMMENT 'source ip',
  49. `tenant_id` varchar(128) COLLATE utf8_bin DEFAULT '' COMMENT '租户字段',
  50. PRIMARY KEY (`id`),
  51. UNIQUE KEY `uk_configinfobeta_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)
  52. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COLLATE=utf8_bin COMMENT='config_info_beta';
  53. -- nacos.config_info_tag definition
  54. CREATE TABLE `config_info_tag` (
  55. `id` bigint NOT NULL AUTO_INCREMENT COMMENT 'id',
  56. `data_id` varchar(255) COLLATE utf8_bin NOT NULL COMMENT 'data_id',
  57. `group_id` varchar(128) COLLATE utf8_bin NOT NULL COMMENT 'group_id',
  58. `tenant_id` varchar(128) COLLATE utf8_bin DEFAULT '' COMMENT 'tenant_id',
  59. `tag_id` varchar(128) COLLATE utf8_bin NOT NULL COMMENT 'tag_id',
  60. `app_name` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'app_name',
  61. `content` longtext COLLATE utf8_bin NOT NULL COMMENT 'content',
  62. `md5` varchar(32) COLLATE utf8_bin DEFAULT NULL COMMENT 'md5',
  63. `gmt_create` datetime NOT NULL DEFAULT '2010-05-05 00:00:00' COMMENT '创建时间',
  64. `gmt_modified` datetime NOT NULL DEFAULT '2010-05-05 00:00:00' COMMENT '修改时间',
  65. `src_user` text COLLATE utf8_bin COMMENT 'source user',
  66. `src_ip` varchar(20) COLLATE utf8_bin DEFAULT NULL COMMENT 'source ip',
  67. PRIMARY KEY (`id`),
  68. UNIQUE KEY `uk_configinfotag_datagrouptenanttag` (`data_id`,`group_id`,`tenant_id`,`tag_id`)
  69. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COLLATE=utf8_bin COMMENT='config_info_tag';
  70. -- nacos.config_tags_relation definition
  71. CREATE TABLE `config_tags_relation` (
  72. `id` bigint NOT NULL COMMENT 'id',
  73. `tag_name` varchar(128) COLLATE utf8_bin NOT NULL COMMENT 'tag_name',
  74. `tag_type` varchar(64) COLLATE utf8_bin DEFAULT NULL COMMENT 'tag_type',
  75. `data_id` varchar(255) COLLATE utf8_bin NOT NULL COMMENT 'data_id',
  76. `group_id` varchar(128) COLLATE utf8_bin NOT NULL COMMENT 'group_id',
  77. `tenant_id` varchar(128) COLLATE utf8_bin DEFAULT '' COMMENT 'tenant_id',
  78. `nid` bigint NOT NULL AUTO_INCREMENT,
  79. PRIMARY KEY (`nid`),
  80. UNIQUE KEY `uk_configtagrelation_configidtag` (`id`,`tag_name`,`tag_type`),
  81. KEY `idx_tenant_id` (`tenant_id`)
  82. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COLLATE=utf8_bin COMMENT='config_tag_relation';
  83. -- nacos.group_capacity definition
  84. CREATE TABLE `group_capacity` (
  85. `id` bigint unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  86. `group_id` varchar(128) COLLATE utf8_bin NOT NULL DEFAULT '' COMMENT 'Group ID,空字符表示整个集群',
  87. `quota` int unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表示使用默认值',
  88. `usage` int unsigned NOT NULL DEFAULT '0' COMMENT '使用量',
  89. `max_size` int unsigned NOT NULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值',
  90. `max_aggr_count` int unsigned NOT NULL DEFAULT '0' COMMENT '聚合子配置最大个数,,0表示使用默认值',
  91. `max_aggr_size` int unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值',
  92. `max_history_count` int unsigned NOT NULL DEFAULT '0' COMMENT '最大变更历史数量',
  93. `gmt_create` datetime NOT NULL DEFAULT '2010-05-05 00:00:00' COMMENT '创建时间',
  94. `gmt_modified` datetime NOT NULL DEFAULT '2010-05-05 00:00:00' COMMENT '修改时间',
  95. PRIMARY KEY (`id`),
  96. UNIQUE KEY `uk_group_id` (`group_id`)
  97. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COLLATE=utf8_bin COMMENT='集群、各Group容量信息表';
  98. -- nacos.his_config_info definition
  99. CREATE TABLE `his_config_info` (
  100. `id` bigint unsigned NOT NULL,
  101. `nid` bigint unsigned NOT NULL AUTO_INCREMENT,
  102. `data_id` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL,
  103. `group_id` varchar(128) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL,
  104. `app_name` varchar(128) COLLATE utf8_bin DEFAULT NULL COMMENT 'app_name',
  105. `content` longtext CHARACTER SET utf8 COLLATE utf8_bin,
  106. `md5` varchar(32) COLLATE utf8_bin DEFAULT NULL,
  107. `gmt_create` datetime NOT NULL DEFAULT '2010-05-05 00:00:00',
  108. `gmt_modified` datetime NOT NULL DEFAULT '2010-05-05 00:00:00',
  109. `src_user` text COLLATE utf8_bin,
  110. `src_ip` varchar(20) COLLATE utf8_bin DEFAULT NULL,
  111. `op_type` char(10) COLLATE utf8_bin DEFAULT NULL,
  112. `tenant_id` varchar(128) COLLATE utf8_bin DEFAULT '' COMMENT '租户字段',
  113. `encrypted_data_key` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  114. PRIMARY KEY (`nid`),
  115. KEY `idx_gmt_create` (`gmt_create`),
  116. KEY `idx_gmt_modified` (`gmt_modified`),
  117. KEY `idx_did` (`data_id`)
  118. ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb3 COLLATE=utf8_bin COMMENT='多租户改造';
  119. -- nacos.permissions definition
  120. CREATE TABLE `permissions` (
  121. `role` varchar(50) NOT NULL,
  122. `resource` varchar(512) NOT NULL,
  123. `action` varchar(8) NOT NULL,
  124. UNIQUE KEY `uk_role_permission` (`role`,`resource`,`action`)
  125. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
  126. -- nacos.roles definition
  127. CREATE TABLE `roles` (
  128. `username` varchar(50) NOT NULL,
  129. `role` varchar(50) NOT NULL,
  130. UNIQUE KEY `uk_username_role` (`username`,`role`)
  131. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
  132. -- nacos.tenant_capacity definition
  133. CREATE TABLE `tenant_capacity` (
  134. `id` bigint unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  135. `tenant_id` varchar(128) COLLATE utf8_bin NOT NULL DEFAULT '' COMMENT 'Tenant ID',
  136. `quota` int unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表示使用默认值',
  137. `usage` int unsigned NOT NULL DEFAULT '0' COMMENT '使用量',
  138. `max_size` int unsigned NOT NULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值',
  139. `max_aggr_count` int unsigned NOT NULL DEFAULT '0' COMMENT '聚合子配置最大个数',
  140. `max_aggr_size` int unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值',
  141. `max_history_count` int unsigned NOT NULL DEFAULT '0' COMMENT '最大变更历史数量',
  142. `gmt_create` datetime NOT NULL DEFAULT '2010-05-05 00:00:00' COMMENT '创建时间',
  143. `gmt_modified` datetime NOT NULL DEFAULT '2010-05-05 00:00:00' COMMENT '修改时间',
  144. PRIMARY KEY (`id`),
  145. UNIQUE KEY `uk_tenant_id` (`tenant_id`)
  146. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COLLATE=utf8_bin COMMENT='租户容量信息表';
  147. -- nacos.tenant_info definition
  148. CREATE TABLE `tenant_info` (
  149. `id` bigint NOT NULL AUTO_INCREMENT COMMENT 'id',
  150. `kp` varchar(128) COLLATE utf8_bin NOT NULL COMMENT 'kp',
  151. `tenant_id` varchar(128) COLLATE utf8_bin DEFAULT '' COMMENT 'tenant_id',
  152. `tenant_name` varchar(128) COLLATE utf8_bin DEFAULT '' COMMENT 'tenant_name',
  153. `tenant_desc` varchar(256) COLLATE utf8_bin DEFAULT NULL COMMENT 'tenant_desc',
  154. `create_source` varchar(32) COLLATE utf8_bin DEFAULT NULL COMMENT 'create_source',
  155. `gmt_create` bigint NOT NULL COMMENT '创建时间',
  156. `gmt_modified` bigint NOT NULL COMMENT '修改时间',
  157. PRIMARY KEY (`id`),
  158. UNIQUE KEY `uk_tenant_info_kptenantid` (`kp`,`tenant_id`),
  159. KEY `idx_tenant_id` (`tenant_id`)
  160. ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb3 COLLATE=utf8_bin COMMENT='tenant_info';
  161. -- nacos.users definition
  162. CREATE TABLE `users` (
  163. `username` varchar(50) NOT NULL,
  164. `password` varchar(500) NOT NULL,
  165. `enabled` tinyint(1) NOT NULL,
  166. PRIMARY KEY (`username`)
  167. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
  168. INSERT INTO users (username, password, enabled) VALUES ('nacos', '$2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu', TRUE);
  169. INSERT INTO roles (username, role) VALUES ('nacos', 'ROLE_ADMIN');

修改nacos配置文件

进入nacos容器

docker exec -it nacos bash
cat /home/nacos/conf/application.properties

vi /home/nacos/conf/application.properties

推出容器,重启nacos容器

docker restart nacos

验证是否持久化mysql

 创建用户

查看mysql数据库中是否有该用户

 

nacos持久化MySQL成功

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小舞很执着/article/detail/892640
推荐阅读
相关标签
  

闽ICP备14008679号