当前位置: 首页 > article >正文

基于docker的Mysql版本升级

引言

随着版本的迭代和漏洞的提出,Mysql作为一款软件避免不了打补丁的命运。

由于docker版本的升级教程较少,以下基于docker版本的MySQL升级说明。

以下操作均在本地虚拟机中操作验证。

使用runlike查看启动脚本

镜像与镜像的差距就在启动命令的区别。启动命令可以根据 docker inspect 容器名 推导出的参数推到出来一部分,也只是一部分。

python工具runlike就是基于此远离开发的,以下举例说明使用方法,

## 对于历史镜像使用runlike看启动命令,基于python
pip3 install runlike
## 查看历史镜像,以kibana为例说明runlike的使用
docker ps --all
runlike -p kibana
docker run --name=kibana \
        --hostname=45b31f642a7d \
        --user=kibana \
        --volume=/usr/local/elk7.14.2/kibana/config/kibana.yml:/usr/share/kibana/config/kibana.yml \
        --volume=/usr/local/elk7.14.2/kibana/data:/usr/share/kibana/data \
        --volume=/usr/local/elk7.14.2/kibana/plugins:/usr/share/kibana/plugins \
        --network=elastic \
        --workdir=/usr/share/kibana \
        -p 5601:5601 \
        --restart=always \
        --log-opt max-size=100m \
        --log-opt max-file=2 \
        --runtime=runc \
        --detach=true \
        -t \
        kibana:7.14.2 \
        /usr/local/bin/kibana-docker

安装低版本的MySQL

# 拉取镜像
docker pull mysql:8.0.27
## 使用runlike查看MySQL的启动命令
runlike -p mysql-yulin
docker run --name=mysql-yulin \
        --env=MYSQL_ROOT_PASSWORD=123456 \
        --volume=/home/centos/yulin/mysql/data:/var/lib/mysql \
        --volume=/home/centos/yulin/mysql/conf:/etc/mysql/conf.d \
        --privileged \
        -p 20020:3306 \
        --expose=33060 \
        --restart=always \
        --runtime=runc \
        --detach=true \
        mysql:8.0.27 \
        --character-set-server=utf8mb4
## 通过volume创建对应的目录
mkdir -p /home/centos/yulin/mysql/data
mkdir -p /home/centos/yulin/mysql/conf
## 检查网络&创建网络
sudo docker inspect wvp20_default
# 网络信息
[
    {
        "Name": "wvp20_default",
        "Created": "2023-10-23T09:12:47.774395505+08:00",
        "Scope": "local",
        "Driver": "bridge",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": null,
            "Config": [
                {
                    "Subnet": "172.27.0.0/16",
                    "Gateway": "172.27.0.1"
                }
            ]
        },
        "Internal": false,
        "Attachable": true,
        "Ingress": false,
        "ConfigFrom": {
            "Network": ""
        },
        "ConfigOnly": false,
    }
] 
# 创建网络,此处镜像没有使用新建网络,仅做演示
docker network create -d bridge wvp20_default
## 创建mysql配置
vi /home/centos/yulin/mysql/conf/mysql.cnf
## 启动容器
docker run --name=mysql-yulin \
        --env=MYSQL_ROOT_PASSWORD=123456 \
        --volume=/home/centos/yulin/mysql/data:/var/lib/mysql \
        --volume=/home/centos/yulin/mysql/conf:/etc/mysql/conf.d \
        --privileged \
        -p 20020:3306 \
        --expose=33060 \
        --restart=always \
        --runtime=runc \
        --detach=true \
        mysql:8.0.27 \
        --character-set-server=utf8mb4
## 查看运行状况
docker ps

升级低版本的MySQL

# 拉取镜像
docker pull mysql:8.0.34
## 停止之前的容器
docker stop mysql-yulin
## 启动容器
docker run --name=mysql-yulin2 \
        --env=MYSQL_ROOT_PASSWORD=123456 \
        --volume=/home/centos/yulin/mysql/data:/var/lib/mysql \
        --volume=/home/centos/yulin/mysql/conf:/etc/mysql/conf.d \
        --privileged \
        -p 20020:3306 \
        --expose=33060 \
        --restart=always \
        --runtime=runc \
        --detach=true \
        mysql:8.0.34 \
        --character-set-server=utf8mb4
## 查看运行状况
docker ps

说明

以上MySQL镜像基于8.0.27升级到8.0.34,是Orcale官方镜像。不同镜像版本可能升级过程不一致。

请在虚拟机中操作验证,禁止线上生产主机操作。


http://www.kler.cn/a/106119.html

相关文章:

  • uniapp 跨域前端代理
  • 无人机动力系统测试-实测数据与CFD模拟仿真数据关联对比分析
  • Typescript中的keyof类型操作符详解
  • 另外一种缓冲式图片组件的用法
  • 基于视觉智能的时间序列基础模型
  • 了解 Solon MVC 的参数注入规则
  • 行情分析——加密货币市场大盘走势(10.27)
  • 行业追踪,2023-10-26
  • 设计模式—创建型模式之单例模式
  • 分布式日志和链路追踪
  • 【Linux】MAC帧协议 + ARP协议
  • Painter:使用视觉提示来引导网络推理
  • 图的应用4.0-----关键路径(AOE网)
  • 国际腾讯云直播推流配置教程!
  • Elasticsearch(十五)搜索---搜索匹配功能⑥--基于地理位置查询
  • C语言数据结构---时间复杂度、空间复杂度
  • 搭建自己的搜索引擎——oh-my-search使用
  • Linux内存管理(五十九):内存检测工具 kfence(2)
  • c语言进制的转换10进制转换16进制
  • npm i 报错或者卡顿 range manifest for 解决
  • 如何在spark中使用scikit-learn和tensorflow等第三方python包
  • ASO优化之关于Google Play中的搜索引擎优化
  • SQL server数据库单用户模式如何退出
  • c++ 并发与多线程(12)线程安全的单例模式-2
  • Spring | Spring Cache 缓存框架
  • 将CSDN或Confluence文章转为微信公众号格式