Docker之Nacos的持久化和集群部署

2023-10-26

注1:小插曲
                  由于虚拟机分配的内存为1G,开到第四个容器时,由于内存不够导致容器启动失败,重新设置4G内存后启动成功


ok,正式进入主题!

一、Docker mysql:5.7的持久化存储及远程连接

1、拉取相关镜像【目前网络模式为:bridge】

 ①mysql镜像(docker mysql:5.7的持久化存储及远程连接)

docker pull mysql/mysql-server:5.7

注:后面的mysql标签是版本号,可选择,有:5.5/5.6/5.7/8.0

 2、在宿主机中相关目录,用于挂载容器的相关数据

mkdir -p /data/mysql/{conf,data}

建立目录用来放置mysql数据的

3、添加my.cnf文件就相当于安装客户端mysql时需要添加的my.ini文件

添加到mysql中的conf目录下(conf就是前面我们自己创建的)

4、创建mysql5.7容器(同时启动) 

docker run -p 3306:3306 \
      --name mysql \
      -v /data/mysql/conf/my.cnf:/etc/my.cnf \
      -v /data/mysql/data:/var/lib/mysql \
      --privileged=true \
      --restart=always \
      -e MYSQL_ROOT_PASSWORD=123456 \
      -d mysql/mysql-server:5.7  

 以上参数的解析如下:

-p 3306:3306:宿主机端口:容器端口
    --name mysql:容器名字
    -v:挂载宿主机的一个目录, 持久化存储的关键所在,将主机目录挂载到容器对应目录,分别是:配置文件、日志文件、数据文件
    -v /data/mysql/conf:/etc/mysql/conf.d
    -v /data/mysql/logs:/logs
    -v /data/mysql/data:/var/lib/mysq
    --privileged=true:使用该参数,container内的root拥有真正的root权限, 否则,container内的root只是外部的一个普通用户权限
    --restart=always:容器自动启动参数,其值可以为[no,on-failure,always]
                      no为默认值,表示容器退出时,docker不自动重启容器
                      on-failure表示,若容器的退出状态非0,则docker自动重启容器,还可以指定重启次数,若超过指定次数未能启动容器则放弃
                      always表示,只要容器退出,则docker将自动重启容器
    -e MYSQL_ROOT_PASSWORD=123456:设置root的密码
    -d mysql/mysql-server:5.7:后台启动模式及使用的镜像

注意:

最好把没用的容器都清除掉,以防出现问题

清除所有容器:

docker rm -f $(docker ps -aq)

 以及查看相关端口号是否被占用:

lsof -i:查看的端口号

 查看某个端口的运行状态:

systemctl status mysqld

 关闭某个端口号的运行状态:

systemctl stop mysqld

5、修改mysql运行Navicat远程连接

①进入mysql5.7容器

docker exec -it mysql /bin/bash

②登录mysql服务器,之后输入

mysql -u root -p;

mysql密码:123456

③给用户授权

grant all privileges on *.* to root@'%' identified by '123456' with grant option;  

查看数据库字符集:

 show variables like'character%';

这三步操作步骤展示:

 ⑥.创建数据库nacos_config,并进行初始化

 运行脚本

 


二、 nacos-docker镜像安装nacos并配置数据库(nacos单机版)【外网单节点部署】

OK,现在如果想用外网访问内部容器的可以使用桥接网络模式进行访问:
步骤:【目前网络模式为:bridge】

1.拉取镜像

docker  pull nacos/nacos-server:1.1.4

拉取成功!

2.配置数据库(之前已完成)

3.创建nacos容器

docker run -d \
       -e PREFER_HOST_MODE=ip \
       -e MODE=standalone \
       -e SPRING_DATASOURCE_PLATFORM=mysql \
       -e MYSQL_MASTER_SERVICE_HOST=172.17.0.2 \
       -e MYSQL_MASTER_SERVICE_PORT=3306 \
       -e MYSQL_MASTER_SERVICE_USER=root \
       -e MYSQL_MASTER_SERVICE_PASSWORD=123456 \
       -e MYSQL_MASTER_SERVICE_DB_NAME=nacos_config \
       -e MYSQL_SLAVE_SERVICE_HOST=172.17.0.2 \
       -p 8848:8848 \
       --name nacos \
       --restart=always \
       nacos/nacos-server:1.1.4

 

参数解析:

docker run -d \                                                                              #后台支行模式
       -e PREFER_HOST_MODE=hostname \                                         #是否支持hostname,可选项:hostname/ip,默认值ip
       -e MODE=standalone \                                                                #cluster模式/standalone模式,可选项:cluster/standalone,默认值cluster
       -e SPRING_DATASOURCE_PLATFORM=mysql \                         #standalone支持 mysql,可选项:mysql/empty,默认值empty
       -e MYSQL_MASTER_SERVICE_HOST=172.17.0.2 \                      #mysql主节点数据库IP,这有个坑:因为网络模式为bridge重启系统后IP会变导致nacos的再次启动失败
       -e MYSQL_MASTER_SERVICE_PORT=3306 \                               #mysql主节点端口
       -e MYSQL_MASTER_SERVICE_USER=root \                                 #数据库用户名
       -e MYSQL_MASTER_SERVICE_PASSWORD=123456 \                 #数据库密码
       -e MYSQL_MASTER_SERVICE_DB_NAME=nacos_config \           #mysql主节点数据库名
       -e MYSQL_SLAVE_SERVICE_HOST=172.17.0.2 \                          #mysql从节点数据库IP
       -p 8848:8848 \                                                                              #主机端口映射
       --name nacos \                                                                             #容器名
       --restart=always \                                                                         #容器自动启动
       nacos/nacos-server:1.1.4                                                              #镜像名

注意:

注1:由于没有配置mysql的主、从集群、本以为MYSQL_SLAVE_SERVICE_HOST可以不用配置,但通过查看nacos容器内的config/application.properties文件,
               会发现这此值未设置默认值,所以会导致启动报错,容器启动不起来,这里可以与主数据库一致。还有一个解决方案就是
               ##删除从库的配置,将配置数据库数量改为1也行,后面例子就是这样做的 
               //-e MYSQL_SLAVE_SERVICE_HOST=172.17.0.2 \
               -e MYSQL_DATABASE_NUM=1 \

       注2:相关命令
                #停止并删除所有容器
                docker stop nacos && docker rm nacos
                #docker logs-查看docker容器日志
                docker logs -f -t --tail=100 nacos

4.访问nacos

   ip:8848/nacos
   http://192.168.3.128:8848/nacos

登录进来 

查看容器的运行情况:

docker logs -f -t --tail=100 nacos

启动成功则显示success:

 这一步完成呢就代表着nacos搭建完成了,可以简单的测试一下。

5.测试

①进入控制器,并添加测试数据,新建配置test.yml并添加数据

username:zs

②查看数据库是否更新

数据库配置没有问题的话可以在表config_info中看到刚才新增的配置信息

③在Linux控制台输入一下命令获得配置

curl -X GET "http://192.168.3.128:8848/nacos/v1/cs/configs?dataId=test.yml&group=DEFAULT_GROUP"

即可获得配置信息。

这样就拿到刚才我们所编辑的内容啦! 


 但是这样是非常不安全的,nacos中的ip地址端口以及相关配置信息都会被外网所访问,所以我们会进入下一个环节,改为内网集群部署:

三、内网集群部署

优点:具备安全性和稳定性。

还是老规矩为了接下来的演示,我将所有容器都删除,避免出现问题。

删除所有容器:

docker rm -f $(docker ps -aq)

既然容器删了,那么数据库也就连接不了了。

步骤:【目前网络模式为:自定义网络mynet】

1.使用自定义网络mynet启动mysql容器

docker run \
         --name mysql \
         --net mynet \
         --ip 192.168.0.11 \
         -v /data/mysql/conf/my.cnf:/etc/my.cnf \
         -v /data/mysql/data:/var/lib/mysql \
         --privileged=true \
         --restart=always \
         -e MYSQL_ROOT_PASSWORD=123456 \
         -d mysql/mysql-server:5.7

 

①检查是否启动成功:

docker ps

②守护进程方式进入容器

docker exec -it mysql /bin/bash

③输入数据库账户和密码

mysql -u root -p

ex123456

继续输入 :

show databases;

这里我们可以看到在创建前面那个容器的时候创建的nacos_config文件,然后删除容器了,重新创建容器时,同样也会有这个文件,那么是什么原因呢?

答:是因为挂载,在使用桥接模式挂载容器的时候,也就是创建第一个容器的时候,我们在容器中创建了该文件,那么既然挂载了,所有宿主机也会实时更新,创建同样的文件;即使把容器删除,宿主机中的文件是不会变动的,而这时候我们又重新创建了一个容器使用自定义网络模式挂载宿主机,那么容器就会自动创建该文件。

2.创建nacos集群    

创建集群节点1:

docker run -d \
           --net mynet \
           --ip 192.168.0.21 \
           -e PREFER_HOST_MODE=ip \
           -e MODE=cluster \
           -e NACOS_SERVERS="192.168.0.22:8848 192.168.0.23:8848" \
           -e SPRING_DATASOURCE_PLATFORM=mysql \
           -e MYSQL_MASTER_SERVICE_HOST=192.168.0.11 \
           -e MYSQL_MASTER_SERVICE_PORT=3306 \
           -e MYSQL_MASTER_SERVICE_USER=root \
           -e MYSQL_MASTER_SERVICE_PASSWORD=123456 \
           -e MYSQL_MASTER_SERVICE_DB_NAME=nacos_config \
           -e MYSQL_DATABASE_NUM=1 \
           -e NACOS_SERVER_PORT=8848 \
           --name nacos01 \
           --restart=always \
           nacos/nacos-server:1.1.4

创建集群节点2:


         docker run -d \
           --net mynet \
           --ip 192.168.0.22 \
           -e PREFER_HOST_MODE=ip \
           -e MODE=cluster \
           -e NACOS_SERVERS="192.168.0.21:8848 192.168.0.23:8848" \
           -e SPRING_DATASOURCE_PLATFORM=mysql \
           -e MYSQL_MASTER_SERVICE_HOST=192.168.0.11 \
           -e MYSQL_MASTER_SERVICE_PORT=3306 \
           -e MYSQL_MASTER_SERVICE_USER=root \
           -e MYSQL_MASTER_SERVICE_PASSWORD=123456 \
           -e MYSQL_MASTER_SERVICE_DB_NAME=nacos_config \
           -e MYSQL_DATABASE_NUM=1 \
           -e NACOS_SERVER_PORT=8848 \
           --name nacos02 \
           --restart=always \
           nacos/nacos-server:1.1.4    

创建集群节点3:

         docker run -d \
           --net mynet \
           --ip 192.168.0.23 \
           -e PREFER_HOST_MODE=ip \
           -e MODE=cluster \
           -e NACOS_SERVERS="192.168.0.21:8848 192.168.0.22:8848" \
           -e SPRING_DATASOURCE_PLATFORM=mysql \
           -e MYSQL_MASTER_SERVICE_HOST=192.168.0.11 \
           -e MYSQL_MASTER_SERVICE_PORT=3306 \
           -e MYSQL_MASTER_SERVICE_USER=root \
           -e MYSQL_MASTER_SERVICE_PASSWORD=123456 \
           -e MYSQL_MASTER_SERVICE_DB_NAME=nacos_config \
           -e MYSQL_DATABASE_NUM=1 \
           -e NACOS_SERVER_PORT=8848 \
           --name nacos03 \
           --restart=always \
           nacos/nacos-server:1.1.4 

 

3.测试

容器创建完之后,不代表就启动了,输入以下命令可以查看是否跑完:

查看docker容器日志:

docker logs -f -t --tail=100 nacos

直到出现success才是启动完毕! 

也可以通过访问任何一节点进行查看:

curl http://192.168.0.21:8848/nacos/index.html
curl http://192.168.0.22:8848/nacos/index.html   
curl http://192.168.0.23:8848/nacos/index.html

如果出现拒绝访问则代表启动失败,可以删除重新创建了,若出现以下效果则代表启动成功:

 同样的当我们在linux控制台输入以下内容,是可以看到text.yml文件中的内容的,只不过外网访问不到了:

curl -X GET "http://192.168.0.23:8848/nacos/v1/cs/configs?dataId=test.yml&group=DEFAULT_GROUP"


所以这时候如何才能使外网能够访问我们内部呢,这里就需要使用到Nginx动态代理nacos集群啦!

四、Nginx动态代理Nacos集群

1.创建nginx容器

docker run \
       --name mynginx \
       -d -p 80:80 \
       -v /data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
       -v /data/nginx/log:/var/log/nginx \
       -v /data/nginx/html:/usr/share/nginx/html \
       nginx:latest

 

2.添加至自定义网络mynet并测试

docker network connect mynet mynginx

3.修改nginx配置文件nginx.conf

首先要进入nginx的目录中去,找到原有的配置文件进行备份 

然后将已经修改好的配置文件添加进去

 

 添加成功!

已经编辑好的nginx.conf文件中的内容:

 由于修改了容器中的配置文件,所以需要重启容器:

docker restart mynginx

4.测试访问节点

浏览器输入:192.168.3.128/nacos/

 访问成功!地址栏不会出现端口号以及nacas的相关配置信息。

在nginx.conf文件中,一共配置了三个节点,即使其中的一个节点挂了失效了,会重新找到其他的节点,依然能够访问成功!


本篇内容分享到此结束,我们下期再见! 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Docker之Nacos的持久化和集群部署 的相关文章

  • Emacs 读取大文件 ~14GB [关闭]

    Closed 这个问题是无关 help closed questions 目前不接受答案 最近我在我的系统上下载了 emacs 来编辑大文件 正如它声称的那样 当尝试打开大文件时 emacs 给我带来了缓冲区大小超出的问题 有办法增加吗 我
  • Linux IPC:共享内存回收

    我有两个进程 生产者和消费者 通过使用生成的共享内存段进行通信 old https stackoverflow com questions 21311080 linux shared memory shmget vs mmap接口而不是 m
  • 无法删除 docker 镜像,守护进程的错误响应

    我对 ubuntu 还很陌生 所以可能缺少一些简单的东西 我正在尝试删除我的 docker 镜像 sudo docker rmi
  • 将默认 Python 版本从 2.4 更改为 2.6

    我想使用一些需要 Python 的新软件2 6 我们目前都有2 4 and 2 6安装在我们专用的 CentOS 服务器上 如下所示 which python usr local bin python which python2 6 usr
  • DLL:在 Linux for Windows 上使用 MinGW 编译 C 时无法识别文件格式

    我在 Linux 特别是 Ubuntu 上使用 MinGW 来编译 Windows 的 C 程序 我正在使用一个名为 SFML 的库 它的绑定名为 CSFML 我使用 L 和 l 来定位库 但是当我编译时出现此错误 win32 dll cs
  • 用 C、C++ 检测 Windows 或 Linux [重复]

    这个问题在这里已经有答案了 我正在编写一个跨平台程序 我希望这个程序能够在 Windows 和 Linux 下运行 因此我为这两个平台准备了两个不同的代码段 如果操作系统是Windows 我希望第一个代码段运行 如果是Linux 那么我希望
  • Android 上原生的自修改代码

    我正在尝试在 Android 上制作一些自修改本机代码并在模拟器中运行它 我的示例基于 android ndk 中的 Hello JNI 示例 它看起来像这样 define NOPE LENGTH 4 typedef void FUNC v
  • 如何从“struct linux_binprm”获取argv

    我想使用 bprm check security lsm 挂钩来检查是否允许运行具有特定参数的进程 在文档中 我看到 argv 应该在 bprm 类型为 struct linux binprm 中可用 但我没有找到任何从结构中提取 argv
  • Python3:导入错误:/lib/x86_64-linux-gnu/libQt5Core.so.5:找不到版本“Qt_5.15”

    我使用 Qt Designer 在 Qt 上创建了一个窗口 当我启动该应用程序时 我收到 ImportError 感觉我的系统中没有安装该库 但预览可以在 Qt Designer 中使用 设计文件完整代码 coding utf 8 Form
  • printf 上的分段错误 - NASM 64 位 Linux

    我尝试使用输入四个浮点数scanf 将它们存储到堆栈中 然后使用vmovupd将它们复制到寄存器以供使用 我的问题是 当我尝试输出这 4 个数字时 程序段错误位于printf 我认为这是堆栈的问题 但我尝试多次弹出 一次多条指令 但无济于事
  • Bash:循环直到命令退出状态等于 0

    我在本地计算机上安装了 netcat 并在端口 25565 上运行了一个服务 使用以下命令 nc 127 0 0 1 25565 lt dev null echo Netcat 检查端口是否打开 如果打开则返回 0 如果关闭则返回 1 我正
  • Chrome 无法播放 MP4

    我每天都会从我的安全摄像头系统中收到几封发送到我的 Gmail 帐户的电子邮件 此类邮件包含来自摄像机的 MP4 格式的视频剪辑 每个大约 20 秒 的链接 奇怪的是 在基于 Mageia 的 PC 上单击此类链接后 剪辑将打开并在新的单独
  • 使用 tar.gz 下载在 Ubuntu 13.10 上安装 nltk 3.0

    我想在 Ubuntu 13 10 上安装 nltk 3 0 我已经运行 Ubuntu 几个星期了 我第一次使用 Linux 我刚刚下载了 python 3 4 0 3 3 也在 Ubuntu 上 因为它是随操作系统一起安装的 Python
  • 如何在Mac中从命令行启动docker

    我在 mac 上安装了 docker 桌面 因此 为了启动 docker 我打开应用程序并找到 docker 然后我可以在顶部栏看到一个泊坞窗图标 稍后我可以从命令行运行 docker 命令 我的问题是如何从命令行启动 docker 本身
  • GNU 日期和自定义格式

    我有一些特定日期格式的字符串 我想使用 GNU date 命令 coreutils 8 20 来处理它们 我可以使用 FORMAT 字符串获取要输出的日期 但不能理解使用相同字符串输入的字符串 我很确定我错过了一些明显的东西 是什么赋予了
  • Java内存不足错误(本机内存),达到进程大小限制(32位linux)

    我正在测试 Web 应用程序的性能 并收到 内存不足错误 本机内存 我测试了好几次 每次都是 无法为 Chunk new 分配 83886088 字节 并死掉 我每分钟打印一次内存大小 发现进程死亡前VmSize为2924700 kB 我认
  • 适用于 Windows 的 Docker 桌面

    我正在尝试在我的 Windows 10 Pro 64 位计算机上运行 Docker 桌面 其构建规范和设置详细信息如下 版本 Windows 10 专业版 64 位 版本 1903 操作系统版本 18362 657 CPU 英特尔 i7 H
  • pyinstaller 是否有像 gcc -static 这样的参数?

    我有一个类似的问题 有没有办法将 Python 程序编译为二进制并将其与 Scratch Dockerfile 一起使用 https stackoverflow com questions 62581924 is there a way t
  • “yes”这个程序有什么重要用途吗?

    当我第一次遇到yes nix 中的程序我想不出它有什么重要用途 这个程序是如何使用的 yes旨在自动化需要在采取行动之前确认的交互式程序 yes rm ri foo 大致相当于 rm rf foo 不同之处在于 f失败时也会继续
  • 在 Linux 上获取机器 ID 的最佳方法?

    获取唯一机器 ID 的最佳实践方法是什么GNU Linux for i386建筑学 除了这个还有什么好的办法吗mac地址 根据您的内核 DMI 信息可能可以通过 sysfs 获得 尝试一下 cat sys class dmi id boar

随机推荐

  • 十分钟带你走进Hive世界(每走一步都是为了离你更近些)

    该文章已更新到语雀中 后台回复 语雀 可获取进击吧大数据整个职业生涯持续更新的所有资料 该文基于Hive专题 从SQL聊Hive底层执行原理进一步的深入学习Hive 相信大多数童鞋对于Hive底层的执行流程只是局限于理论层面 那么本篇将带大
  • Windows平台Unity3d下如何同时播放多路RTSP或RTMP流

    好多开发者在做AR VR或者教育类产品时 苦于如何在windows平台构建一个稳定且低延迟的RTSP或者RTMP播放器 如果基于Unity3d完全重新开发一个播放器 代价大 而且周期长 不适合快速出产品 我们认为当前最好的方式就是集成现有N
  • 【计算机网络】 TCP——四次挥手

    文章目录 流程 考点 流程 主动方打算关闭连接 此时会发送一个TCP首部FIN标志位被置为1的报文 也即FIN报文 之后主动方进入FIN WAIT 1状态 被动方收到该报文后 就向主动方发送ACK应答报文 接着被动方进入CLOSE WAIT
  • Qt 6.4.2在Windows上安装过程及简单验证

    Qt是一个跨平台的C 开发库 用来开发图形用户界面 Graphical User Interface GUI 它支持Windows Linux macOS Android iOS QNX等平台 一个框架 一套代码库 任意平台部署 Qt有开源
  • Centos 8上安装Docker配置国内镜像源

    一 使用背景 在阿里云上安装docker后 如果采用国外的源地址 pull的时候 速度慢到让人崩溃 二 国内常用加速地址 Docker中国官方加速地址 https registry docker cn com 网易163镜像加速 http
  • 使用 Waffle 进行测试的基本流程及使用方法-文章来自问我社区

    前言 Waffle 是一款适配 ehter js 的智能合约测试库 本样例演示了使用 Waffle 进行测试的基本流程及使用方法 Waffle 详细使用方法可以参考 Waffle 官网 对于不熟悉 Waffle 测试框架的开发者 可以根据本
  • 腾讯Cos对象储存api用法教程中英图文讲解

    Chinar blog www chinar xin 腾讯云 Cos api sdk详解 本文提供全流程 中文翻译 Chinar 的初衷是将一种简单的生活方式带给世人 使有限时间 具备无限可能 Chinar 心分享 心创新 助力快速理解 C
  • Egg简介

    Egg 前言 Egg js 为企业级框架和应用而生 基于Koa开发封装 性能优异 内置多进程管理 具有高扩展性 且提供了基于Egg定制上层框架的能力 帮助开发团队降低了开发维护成本 约定先于配置 相较于express更加灵活可配 Koa K
  • gateway网关的使用

    今天与大家分享gateway网关的使用 1 gateway简介 1 1 是什么 SpringCloud Gateway 作为 Spring Cloud 生态系统中的网关 目标是替代 Zuul 在Spring Cloud 2 0以上版本中 没
  • 动手实验:使用 jstat 摸清线上系统的JVM运行状况

    添加VX ruyuan0220 回复 CSDN 领取更多精品学习资料 目录 功能强大的jstat jstat gc PID 其他的jstat命令 到底该如何使用jstat工具 新生代对象增长的速率 Young GC的触发频率和每次耗时 每次
  • 关于\n,\\\n,\\\\\n在java中的split()正则中的理解

    关于 n n n在java中的split 正则中的理解 在做一个题的时候 要把一串字符串dir n tsubdir1 n tsubdir2 n t tfile ext按 n分割 粘贴到idea idea识别自动转义成 也是一个坑 dir n
  • C/C++中调用SQLITE3

    C C 中调用SQLITE3 2011 08 04 17 31 09 分类 LINUX C C 中调用SQLITE3的基本步骤 Sqlite 是一个面向嵌入式系统的数据库 编译完成只有200K 同时支持2T的数据记录 对于嵌入式设备是一个很
  • 操作系统与Linux篇之卷首语

    2023年7月23日 周日晚上 通过纯粹地看操作系统相关书籍来学习操作系统实在是太枯燥和抽象了 我看不到实现的细节 我看不到实际的操作系统代码 这让我学得很难受 所以我决定结合开源的Linux来学习操作系统 我发现这样做不仅学起来更加有趣
  • Expecting property name enclosed in double quotes解决篇

    作者 关注了 Github Github 掘金 进去看看 爱好 Americano More Ice QQ学习交流群 new 811792998 问题 json decoder JSONDecodeError Expecting prope
  • spring boot: 输出json

    spring boot 输出json 注意 关闭java的Terminate后 在重新启动 否则报错 app java启动配置 package com muyang boot1 import org springframework boot
  • curl 命令的学习笔记

    curl 命令的学习笔记 curl 官网 https curl haxx se curl 全称 CommmandLine URL 或 CommandLine Uniform Resource Locator 是用于从服务器传输传输数据或向服
  • 【ARM】Linux内核驱动之定时器

    作者主页 凉开水白菜 作者简介 共同学习 互相监督 热于分享 多加讨论 一起进步 专栏资料 https gitee com stylle linux code 点赞 收藏 再看 养成习惯 订阅的粉丝可通过PC端文末加我微信 可对文章的内容进
  • set -e -x 等等的作用

    set指令能设置所使用shell的执行方式 可依照不同的需求来做设置 a 标示已修改的变量 以供输出至环境变量 b 使被中止的后台程序立刻回报执行状态 C 转向所产生的文件无法覆盖已存在的文件 d Shell预设会用杂凑表记忆使用过的指令
  • VUE 输入框实现光标插入,设置光标位置并删除光标内容

    最近做项目遇到这样一个需求 可以往输入框指定光标出插入内容 并且当删除插入的内容时会先将插入的内容进行光标选中给用户进行提示 当再次删除时才删除内容 而这个需求的核心就在 setSelectionRange 设置光标位置 这个dom api
  • Docker之Nacos的持久化和集群部署

    注1 小插曲 由于虚拟机分配的内存为1G 开到第四个容器时 由于内存不够导致容器启动失败 重新设置4G内存后启动成功 ok 正式进入主题 一 Docker mysql 5 7的持久化存储及远程连接 1 拉取相关镜像 目前网络模式为 brid