Linux环境更新数据库

为了便于可能潜在的后续更新,本次停用了原先在宿主机运行的Mysql服务,更新了原先在docker运行的mysql,当前mysql版本 8.3.0
账号:root 密码:root 端口3306:3306
以下是连接及更新docker下mysql的操作流程:

提前用docker下载好最新版本的数据库,命名为mysql_latest.tar,放入远程服务器中的目录中;
一、登录mysql
mysql -u root -h 127.0.0.1 -p
输入密码 root
二、更新docker mysql
1.备份原有数据 

找一个文件夹 比如 mysql cd进去,进入到该目录下,然后执行
mysqldump -h 127.0.0.1 -u root -p 表名 < 表名.sql  // 备份原有数据库中的数据表
mysqldump -h 127.0.0.1 -u root -p 表名 < 表名.sql // 备份原有数据库中的数据表
2.停止旧的mysql docker
docker ps //查看正在运行的docker镜像
docker stop "上一步查询到的 container id" //停止旧的镜像
docker run --name mysql --restart=always \
    -v /home/dianli/docker/mysql/conf/my.cnf:/etc/mysql/my.cnf \
    -v /home/dianli/dcoker/mysql/data:/var/lib/mysql \
    -p 3306:3306 \
    -e MYSQL_ROOT_PASSWORD="root" \
    -e TZ=Asia/Shanghai \
    -d mysql:8.0 --lower-case-table-names=1  启动脚本
启动时可能会报错,提示该名称已经存在,然后抛出一个长串编码,该编码为镜像id。

导入新的docker镜像 
docker load -i mysql_latest.tar

docker ps

docker run --name mysql --restart=always \
    -v /home/dianli/docker/mysql/conf/my.cnf:/etc/mysql/my.cnf \
    -v /home/dianli/dcoker/mysql/data:/var/lib/mysql \
    -p 3306:3306 \
    -e MYSQL_ROOT_PASSWORD="root" \
    -e TZ=Asia/Shanghai \
    -d 容器id --lower-case-table-names=1

docker remove 镜像id 删除旧的镜像,然后再次执行上面的run命令,mysql即可启动成功
启动后使用 mysql -u root -h 127.0.0.1 -p 进入mysql 使用select version();查看mysql版本
版本输出正确就是更新成功了。

使用show databases;查看原来的数据库是否存在。
分别输入
    use 表名;
    show tables; 
    use 表名;
    show tables;
查看原来的表是否还在

如果发现虚拟机中的环境与最新版本的数据库不兼容:
版本回退:
1.docker images
2. docker stop 最新的这个
mysql:latest 换成  > 8.3的imageid
4.执行docker run XXXX的命令
5. 删除容器
6. 重复 4
7. docker ps

sudo iptables -A INPUT -i lo -j ACCEPT
sudo iptables -A OUTPUT -o lo -j ACCEPT
sudo iptables -A INPUT -p tcp -s 127.0.0.1 --dport 3306 -j ACCEPT
sudo iptables -A INPUT -p tcp --dport 3306 -j DROP

重启redis
docker run --privileged -p 6379:6379 --name redis-cqw -v /data/redis/conf/redis.conf:/etc/redis/redis.conf -v /data/redis/data:/data -d redis redis-server /etc/redis/redis.conf --appendonly yes

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值