当前位置:   article > 正文

Macbook M1 Pro使用brew安装Docker并安装Nacos【超详细图解】_brew install docker

brew install docker

目录

一、安装 Docker

二、修改 Docker 镜像地址

三、拉取镜像-举例 Nacos

1.拉取镜像

2.查看本地镜像

3.删除镜像 

四、启动容器

1.启动 Nacos 容器: 

I.方式一【推荐】

II.方式二【懒人推荐】

2.访问 Nacos Web 控制台

3.进入容器和退出容器

五、配置 Nacos 数据库存储

1.新建 Nacos 挂载目录

2.修改 Nacos 配置文件

I.方式一:修改宿主挂载目录的配置文件即可【推荐】

II.方式二:进入 Nacos 容器修改配置

3.安装 MySQL 数据库

4.创建 Nacos 数据库 

5.重新启动 Nacos 容器


一、安装Docker

在终端使用 brew 命令安装 Docker 

brew install --cask --appdir=/Applications docker

中间会让你输入电脑开机密码,安装成功后,双击 Docker 图标就可以运行

没有 brew 命令的要么自己装一个Homebrew,要么去官网手动安装Docker。

打开终端输入 docker --version 即可看到安装成功

二、修改 Docker 镜像地址

设置 -> Docker Engine 修改镜像地址,阿里云的镜像要去阿里云服务器那里获取自己的镜像地址

  1. {
  2. "builder": {
  3. "gc": {
  4. "defaultKeepStorage": "20GB",
  5. "enabled": true
  6. }
  7. },
  8. "experimental": false,
  9. "registry-mirrors": [
  10. "https://docker.mirrors.ustc.edu.cn",
  11. "https://registry.docker-cn.com",
  12. "http://hub-mirror.c.163.com"
  13. ]
  14. }

打开终端输入 docker info 即可查看镜像地址是否被更改成功 

三、拉取镜像-举例 Nacos

1.拉取镜像

使用docker pull nacos/nacos-server 总会报错,原因是Docker会根据CPU架构拉取对应的架构版本,而Docker识别到M1/M2芯片需要的架构版本是 linux/arm64/v8 ,而在镜像库里 Nacos 最新版没有 linux/arm64/v8 架构的,其他MySQL、Redis等是有的,正常用命令拉取即可

effy@EFFYdeMacBook-Pro ~ % docker pull nacos/nacos-server

Using default tag: latest

latest: Pulling from nacos/nacos-server

no matching manifest for linux/arm64/v8 in the manifest list entries

可以通过uname -m命令查看主机(虚拟机)的系统架构

docker可以通过--platform <系统架构>命令获取指定系统架构的镜像

由于我查看本机是arm64架构的,所以加上指定架构 --platform linux/amd64 拉取镜像

docker pull --platform linux/amd64 nacos/nacos-server

如果想拉取指定版本,就在命令后面加上版本号,:Tag

例如: docker pull --platform linux/amd64 nacos/nacos-server:v2.4.1

2.查看本地镜像

在终端输入 docker images 查看本地镜像

docker images

3.删除镜像 

使用 docker rmi 镜像名称/镜像Id 可以删除镜像

docker rmi 镜像名称/镜像ID

四、启动容器

1.启动 Nacos 容器: 

I.方式一【推荐】

在终端执行下面的命令,注意:如果 Nacos 版本在2.0及以上,需要把8848、9848和9849三个端口映射出来,否则访问会404失败。Mac苹果电脑,并且在 Docker 上运行某个应用,启动命令需要加入 --platform linux/amd64 ,否则会有警告,影响后面

docker run --platform linux/amd64  --name nacos --env MODE=standalone -p 8848:8848 -p 9848:9848 -p 9849:9849 -d nacos/nacos-server 

这个命令会启动一个名为 Nacos 的容器,并将其绑定到本地机器的 8848 端口,并设置容器模式为 standalone。

查看 Nacos 运行状态 

docker ps

II.方式二【懒人推荐】

笔者太懒了,直接在用户下写shell脚本命名叫startNacos.sh,运行脚本./startNacos.sh就可以启动了,如果是拉取的指定版本号,尾部也要加上指定版本号。

  1. # 在终端执行
  2. touch ~/startNacos.sh
  3. vi ~/startNacos.sh
  4. # 在startNacos.sh复制粘贴下面的代码,下面的这个#!/bin/sh也要加上
  5. #!/bin/sh
  6. docker run --platform linux/amd64 \
  7. --name nacos --env MODE=standalone \
  8. -p 8848:8848 -p 9848:9848 -p 9849:9849 \
  9. -d nacos/nacos-server
  10. # 在终端继续执行下面的代码,就可以启动了
  11. ./startNacos.sh

不懂 Docker 这串命令的请看这里:

  1. docker run -d --name nacos \ -d 表示运行在后台,--name 指定名称为nacos
  2. --ip 0.0.0.0 \ 自定义分配 IP 地址,可忽略
  3. -p 8848:8848 \ 前者为暴露给外部访问的端口,后者为nacos容器端口
  4. -p 9848:9848 \ 9848是nacos2.0.0版本以上必须要加上端口映射
  5. -p 9849:9849 \ 9849是nacos2.0.0版本以上必须要加上端口映射
  6. --env MODE=standalone \ nacos以单机版启动,默认为cluster(集群)
  7. --env NACOS_AUTH_ENABLE=true \ 如果使用官方镜像,请在启动docker容器时,添加如下环境变量
  8. -v /www/wwwroot/changjing/docker/nacos/conf/:/home/nacos/conf \ nacos 配置文件目录,“:”前为服务器目录,“:”后为nacos容器中的目录
  9. -v /www/wwwroot/changjing/docker/nacos/logs:/home/nacos/logs \ nacos 日志文件目录,“:”前为服务器目录,“:”后为nacos容器中的目录
  10. -v /www/wwwroot/changjing/docker/nacos/data:/home/nacos/data \ nacos 数据文件目录,“:”前为服务器目录,“:”后为nacos容器中的目录
  11. nacos/nacos-server:v2.2.1 指定 docker nacos 版本,这里是2.2.1版本

2.访问 Nacos Web 控制台

启动完 Nacos 容器后,就可以通过 http://localhost:8848/nacos 访问 Nacos Web 控制台了。在控制台上,可以进行服务注册、配置管理和服务发现等操作。

此时 docker desktop 里就有这个容器了 

等你长大了,到时候就长这样,可以看到与其他不同的是 Nacos 那里是有一个amd64的 

3.进入容器和退出容器

  1. # 进入容器
  2. docker exec -it nacos /bin/bash
  3. # 退出容器
  4. exit

但如果读者想用自己的MySQL,而不是Nacos内置的数据库,那么可以继续往下阅读

五、配置 Nacos 数据库存储

默认情况下,Nacos 使用内置的 Derby 数据库进行数据存储。虽然 Derby 是一个轻量级的数据库,但当数据量较大时,它可能会导致性能瓶颈和数据丢失的问题。因此,建议将 Nacos 数据库存储改为 MySQL 或 PostgreSQL 等外部数据库。

1.新建 Nacos 挂载目录

只需要新建conf的挂载即可,其他目录的挂载会自动生成目录(如logs)

mkdir ~/nacos/conf

把 Nacos 容器中的/home/nacos/conf文件夹拷贝

docker cp nacos:/home/nacos/conf ~/nacos

注意:宿主路径填写/nacos,后面不需要写conf,会自动覆盖

我们看下/nacos/conf文件下,nacos完整的配置信息已拷贝过来

2.修改 Nacos 配置文件

在启动 Nacos 容器之前,需要修改配置文件以将 Nacos 数据库存储改为 MySQL。

I.方式一:修改宿主挂载目录的配置文件即可【推荐】

vi ~/nacos/conf/application.properties

如果不知道ip写什么的,就打开终端,输入ifconfig,ip在en0的inet后面。比如:192.x.x.x,或者10.x.x.x,或者172.x.x.x的

如果还需要设置nacos的账号密码,则在配置文件中额外添加以下代码,默认账号密码都是nacos

  1. ### 开启鉴权
  2. nacos.core.auth.enabled=true
  3. # 关闭使用user-agent判断服务端请求并放行鉴权的功能
  4. nacos.core.auth.enable.userAgentAuthWhite=false
  5. # 配置自定义身份识别的keyvalue,这两个属性是auth的白名单,用于标识来自其它服务器的请求,具体实现见 com.alibaba.nacos.core.auth.AuthFilter。
  6. nacos.core.auth.server.identity.key=authKey
  7. nacos.core.auth.server.identity.value=shigzh
  8. # 自定义用于生成JWT令牌的密钥,注意:原始密钥长度不得低于32字符,且一定要进行Base64编码,否则无法启动节点。
  9. nacos.core.auth.plugin.nacos.token.secret.key=bmFjb3NfMjAyNDAxMTBfc2hpZ3poX25hY29zX3Rva2Vu
  10. # 权限缓存开关,开启后权限缓存的更新默认有15秒的延迟,默认 : false
  11. nacos.core.auth.caching.enabled=true

II.方式二:进入 Nacos 容器修改配置

  1. docker exec -it nacos /bin/bash
  2. cd /home/nacos/conf

 在 conf 目录下,可以找到 application.properties 文件,备份该文件后直接修改该文件。

cp application.properties application_bak.properties
vi application.properties

与方式一同样操作,这种方式在后续重启 Nacos 的时候命令不一样。

3.安装 MySQL 数据库

首先,需要在本地机器或其他服务器上安装 MySQL 数据库。可以使用以下命令安装 MySQL:

brew install mysql

4.创建 Nacos 数据库 

安装完成 MySQL 后,需要创建一个新的数据库和用户,并授予其访问权限。可以使用以下命令创建一个名为 nacos 的数据库和用户:

创建SQL脚本在官方的GitHub上,这里附上gitee地址:

distribution/conf/mysql-schema.sql · Gitee 极速下载/Nacos - Gitee.com

  1. mysql -u root -p
  2. CREATE DATABASE nacos DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
  3. CREATE USER 'nacos'@'%' IDENTIFIED BY '123456';
  4. GRANT ALL PRIVILEGES ON nacos.* TO 'nacos'@'%';
  5. FLUSH PRIVILEGES;
  6. EXIT;

这样,就创建了一个名为 nacos 的数据库和一个名为 nacos 的用户,并赋予它们访问权限。

如果MySQL是8以上的则执行 

  1. mysql -u root -p
  2. CREATE DATABASE nacos DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
  3. CREATE USER 'nacos'@'%' IDENTIFIED BY '123456';
  4. GRANT ALL PRIVILEGES ON nacos.* TO 'nacos'@'%' with grant option;
  5. FLUSH PRIVILEGES;
  6. EXIT;

把下面的SQL在Mysql(nacos库下)中执行一次就可以了 

  1. /*
  2. * Copyright 1999-2018 Alibaba Group Holding Ltd.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. /******************************************/
  17. /* 表名称 = config_info */
  18. /******************************************/
  19. CREATE TABLE `config_info` (
  20. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  21. `data_id` varchar(255) NOT NULL COMMENT 'data_id',
  22. `group_id` varchar(128) DEFAULT NULL COMMENT 'group_id',
  23. `content` longtext NOT NULL COMMENT 'content',
  24. `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
  25. `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  26. `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
  27. `src_user` text COMMENT 'source user',
  28. `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',
  29. `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
  30. `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',
  31. `c_desc` varchar(256) DEFAULT NULL COMMENT 'configuration description',
  32. `c_use` varchar(64) DEFAULT NULL COMMENT 'configuration usage',
  33. `effect` varchar(64) DEFAULT NULL COMMENT '配置生效的描述',
  34. `type` varchar(64) DEFAULT NULL COMMENT '配置的类型',
  35. `c_schema` text COMMENT '配置的模式',
  36. `encrypted_data_key` text COMMENT '密钥',
  37. PRIMARY KEY (`id`),
  38. UNIQUE KEY `uk_configinfo_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)
  39. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info';
  40. /******************************************/
  41. /* 表名称 = config_info_aggr */
  42. /******************************************/
  43. CREATE TABLE `config_info_aggr` (
  44. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  45. `data_id` varchar(255) NOT NULL COMMENT 'data_id',
  46. `group_id` varchar(128) NOT NULL COMMENT 'group_id',
  47. `datum_id` varchar(255) NOT NULL COMMENT 'datum_id',
  48. `content` longtext NOT NULL COMMENT '内容',
  49. `gmt_modified` datetime NOT NULL COMMENT '修改时间',
  50. `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
  51. `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',
  52. PRIMARY KEY (`id`),
  53. UNIQUE KEY `uk_configinfoaggr_datagrouptenantdatum` (`data_id`,`group_id`,`tenant_id`,`datum_id`)
  54. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='增加租户字段';
  55. /******************************************/
  56. /* 表名称 = config_info_beta */
  57. /******************************************/
  58. CREATE TABLE `config_info_beta` (
  59. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  60. `data_id` varchar(255) NOT NULL COMMENT 'data_id',
  61. `group_id` varchar(128) NOT NULL COMMENT 'group_id',
  62. `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
  63. `content` longtext NOT NULL COMMENT 'content',
  64. `beta_ips` varchar(1024) DEFAULT NULL COMMENT 'betaIps',
  65. `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
  66. `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  67. `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
  68. `src_user` text COMMENT 'source user',
  69. `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',
  70. `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',
  71. `encrypted_data_key` text COMMENT '密钥',
  72. PRIMARY KEY (`id`),
  73. UNIQUE KEY `uk_configinfobeta_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)
  74. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info_beta';
  75. /******************************************/
  76. /* 表名称 = config_info_tag */
  77. /******************************************/
  78. CREATE TABLE `config_info_tag` (
  79. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  80. `data_id` varchar(255) NOT NULL COMMENT 'data_id',
  81. `group_id` varchar(128) NOT NULL COMMENT 'group_id',
  82. `tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id',
  83. `tag_id` varchar(128) NOT NULL COMMENT 'tag_id',
  84. `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
  85. `content` longtext NOT NULL COMMENT 'content',
  86. `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
  87. `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  88. `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
  89. `src_user` text COMMENT 'source user',
  90. `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',
  91. PRIMARY KEY (`id`),
  92. UNIQUE KEY `uk_configinfotag_datagrouptenanttag` (`data_id`,`group_id`,`tenant_id`,`tag_id`)
  93. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info_tag';
  94. /******************************************/
  95. /* 表名称 = config_tags_relation */
  96. /******************************************/
  97. CREATE TABLE `config_tags_relation` (
  98. `id` bigint(20) NOT NULL COMMENT 'id',
  99. `tag_name` varchar(128) NOT NULL COMMENT 'tag_name',
  100. `tag_type` varchar(64) DEFAULT NULL COMMENT 'tag_type',
  101. `data_id` varchar(255) NOT NULL COMMENT 'data_id',
  102. `group_id` varchar(128) NOT NULL COMMENT 'group_id',
  103. `tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id',
  104. `nid` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'nid, 自增长标识',
  105. PRIMARY KEY (`nid`),
  106. UNIQUE KEY `uk_configtagrelation_configidtag` (`id`,`tag_name`,`tag_type`),
  107. KEY `idx_tenant_id` (`tenant_id`)
  108. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_tag_relation';
  109. /******************************************/
  110. /* 表名称 = group_capacity */
  111. /******************************************/
  112. CREATE TABLE `group_capacity` (
  113. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  114. `group_id` varchar(128) NOT NULL DEFAULT '' COMMENT 'Group ID,空字符表示整个集群',
  115. `quota` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表示使用默认值',
  116. `usage` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '使用量',
  117. `max_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值',
  118. `max_aggr_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '聚合子配置最大个数,,0表示使用默认值',
  119. `max_aggr_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值',
  120. `max_history_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最大变更历史数量',
  121. `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  122. `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
  123. PRIMARY KEY (`id`),
  124. UNIQUE KEY `uk_group_id` (`group_id`)
  125. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='集群、各Group容量信息表';
  126. /******************************************/
  127. /* 表名称 = his_config_info */
  128. /******************************************/
  129. CREATE TABLE `his_config_info` (
  130. `id` bigint(20) unsigned NOT NULL COMMENT 'id',
  131. `nid` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT 'nid, 自增标识',
  132. `data_id` varchar(255) NOT NULL COMMENT 'data_id',
  133. `group_id` varchar(128) NOT NULL COMMENT 'group_id',
  134. `app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',
  135. `content` longtext NOT NULL COMMENT 'content',
  136. `md5` varchar(32) DEFAULT NULL COMMENT 'md5',
  137. `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  138. `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
  139. `src_user` text COMMENT 'source user',
  140. `src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',
  141. `op_type` char(10) DEFAULT NULL COMMENT 'operation type',
  142. `tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',
  143. `encrypted_data_key` text COMMENT '密钥',
  144. PRIMARY KEY (`nid`),
  145. KEY `idx_gmt_create` (`gmt_create`),
  146. KEY `idx_gmt_modified` (`gmt_modified`),
  147. KEY `idx_did` (`data_id`)
  148. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='多租户改造';
  149. /******************************************/
  150. /* 表名称 = tenant_capacity */
  151. /******************************************/
  152. CREATE TABLE `tenant_capacity` (
  153. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  154. `tenant_id` varchar(128) NOT NULL DEFAULT '' COMMENT 'Tenant ID',
  155. `quota` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表示使用默认值',
  156. `usage` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '使用量',
  157. `max_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值',
  158. `max_aggr_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '聚合子配置最大个数',
  159. `max_aggr_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值',
  160. `max_history_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最大变更历史数量',
  161. `gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  162. `gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
  163. PRIMARY KEY (`id`),
  164. UNIQUE KEY `uk_tenant_id` (`tenant_id`)
  165. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='租户容量信息表';
  166. CREATE TABLE `tenant_info` (
  167. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
  168. `kp` varchar(128) NOT NULL COMMENT 'kp',
  169. `tenant_id` varchar(128) default '' COMMENT 'tenant_id',
  170. `tenant_name` varchar(128) default '' COMMENT 'tenant_name',
  171. `tenant_desc` varchar(256) DEFAULT NULL COMMENT 'tenant_desc',
  172. `create_source` varchar(32) DEFAULT NULL COMMENT 'create_source',
  173. `gmt_create` bigint(20) NOT NULL COMMENT '创建时间',
  174. `gmt_modified` bigint(20) NOT NULL COMMENT '修改时间',
  175. PRIMARY KEY (`id`),
  176. UNIQUE KEY `uk_tenant_info_kptenantid` (`kp`,`tenant_id`),
  177. KEY `idx_tenant_id` (`tenant_id`)
  178. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='tenant_info';
  179. CREATE TABLE `users` (
  180. `username` varchar(50) NOT NULL PRIMARY KEY COMMENT 'username',
  181. `password` varchar(500) NOT NULL COMMENT 'password',
  182. `enabled` boolean NOT NULL COMMENT 'enabled'
  183. );
  184. CREATE TABLE `roles` (
  185. `username` varchar(50) NOT NULL COMMENT 'username',
  186. `role` varchar(50) NOT NULL COMMENT 'role',
  187. UNIQUE INDEX `idx_user_role` (`username` ASC, `role` ASC) USING BTREE
  188. );
  189. CREATE TABLE `permissions` (
  190. `role` varchar(50) NOT NULL COMMENT 'role',
  191. `resource` varchar(255) NOT NULL COMMENT 'resource',
  192. `action` varchar(8) NOT NULL COMMENT 'action',
  193. UNIQUE INDEX `uk_role_permission` (`role`,`resource`,`action`) USING BTREE
  194. );
  195. INSERT INTO users (username, password, enabled) VALUES ('nacos', '$2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu', TRUE);
  196. INSERT INTO roles (username, role) VALUES ('nacos', 'ROLE_ADMIN');

5.重新启动 Nacos 容器

修改完配置文件后,需要重新启动 Nacos 容器。可以使用以下命令停止并删除之前的容器:

docker stop nacos && docker rm nacos

然后,根据之前的步骤启动 Nacos 容器,并加上以下环境变量:

请自行将【你的Mac电脑用户名】【前面配置文件中配置jdbc的ip地址】【你的mysql数据库用户名】【你的mysql数据库密码】填入下面的命令再运行,请注意后面必须要有个空格和反斜杠\,最后一行不用添加反斜杠\

  1. docker run --platform linux/amd64 \
  2. --name nacos --env MODE=standalone \
  3. -p 8848:8848 -p 9848:9848 -p 9849:9849 \
  4. --privileged=true --restart=always \
  5. -e SPRING_DATASOURCE_PLATFORM=mysql \
  6. -e MYSQL_SERVICE_HOST=前面配置文件中配置jdbc的ip地址 \
  7. -e MYSQL_SERVICE_PORT=3306 \
  8. -e MYSQL_SERVICE_DB_NAME=nacos \
  9. -e MYSQL_SERVICE_USER=你的mysql数据库用户名 \
  10. -e MYSQL_SERVICE_PASSWORD=你的mysql数据库密码 \
  11. -v /Users/你的Mac电脑用户名/nacos/logs:/home/nacos/logs \
  12. -v /Users/你的Mac电脑用户名/nacos/conf:/home/nacos/conf \
  13. -d nacos/nacos-server

启动完容器后,就可以在 Nacos Web 控制台中使用 MySQL 数据库存储了。

参数详解(根据自己的需要,选择参数)

-p 8848:8848 # 宿主机端口:容器端口
–name nacos # 容器名字
–privileged=true # 使用该参数,container内的root拥有真正的root权限
–network host # 设置属于该容器的网络
–restart=always # 总是重启
-e PREFER_HOST_MODE=hostname # 是否支持 hostname,可选参数为hostname/ip,默认值是当前宿主机的ip
-e MODE=standalone # 使用 standalone模式(单机模式),MODE值有cluster模式/standalone模式两种
-e JVM_XMS=256m # -Xms 为jvm启动时分配的内存[我设置会导致nacos启动异常,无法访问,故没有设置]
-e JVM_XMX=1024m # -Xmx 为jvm运行过程中分配的最大内存[我设置会导致nacos启动异常,无法访问,故没有设置]
-d nacos/nacos-server # 后台启动模式及使用的镜像
-v /Users/effy/nacos/logs:/home/nacos/logs \

-v:挂载宿主机的一个目录, 持久化存储的关键所在,将主机目录挂载到容器对应目录,分别是:配置文件、日志文件
–restart=always:容器自动启动参数,其值可以为[no,on-failure,always]
no为默认值,表示容器退出时,docker不自动重启容器
on-failure表示,若容器的退出状态非0,则docker自动重启容器,还可以指定重启次数,若超过指定次数未能启动容器则放弃
always表示,只要容器退出,则docker将自动重启容器

如果你选择的是方式二修改 Nacos 配置文件,那么则使用下面的命令重新启动 Nacos 容器

  1. docker run --platform linux/amd64 \
  2. --name nacos --env MODE=standalone \
  3. -p 8848:8848 -p 9848:9848 -p 9849:9849 \
  4. -d nacos/nacos-server
  5. --privileged=true \
  6. --restart=always \
  7. -e PREFER_HOST_MODE=hostname \
  8. -e JVM_XMS=256m \
  9. -e JVM_XMX=1024m

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

闽ICP备14008679号