docker安装mysq8.0

今日美图

不说了 先看图

Docker环境

没有的就网上找一下,我这就说两种linux下的:
yum install -y dockerapt install docker-ce

拉取镜像

docker pull mysql

查看刚刚拉取的mysql镜像

docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
redis               latest              1319b1eaa0b7        3 months ago        104MB
mysql               latest              c8ee894bd2bd        13 months ago       456MB

创建本地Mysql数据文件夹

mkdir /usr/local/mysql

创建容器并运行

注意!!! 非root环境就加上sudo,是root也加上…

sudo docker run --name mysql -p 3306:3306 -v /usr/local/mysql_data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql
docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                               NAMES
ce56818b7e03        mysql               "docker-entrypoint.s…"   2 hours ago         Up 2 hours          0.0.0.0:3306->3306/tcp, 33060/tcp   mysql

有这个就行了

修改密码验证方式 使mysql可以用Navicat连接

进入docker容器

docker exec -it mysql /bin/bash
mysql -uroot -p
root@ce56818b7e03:/# mysql -uroot -p
Enter password: 这里输入密码123456

修改密码验证

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';
FLUSH PRIVILEGES;

一定记着执行这个刷新操作!!
顺便查看下

SELECT Host, User, plugin from user;
+-----------+------------------+-----------------------+
| Host      | User             | plugin                |
+-----------+------------------+-----------------------+
| %         | root             | mysql_native_password |
| localhost | mysql.infoschema | caching_sha2_password |
| localhost | mysql.session    | caching_sha2_password |
| localhost | mysql.sys        | caching_sha2_password |
| localhost | root             | mysql_native_password |
+-----------+------------------+-----------------------+
5 rows in set (0.00 sec)

行了 到这里基本就可以用了 下面的操作我自己的记下

备份和恢复

进入docker容器(这个前面有)

mysqldump --user=root --password="123456" --lock-all-tables 要备份的数据库 > 文件名.sql

会出现个这个 没事,此时文件已经出来了,很快
mysqldump: [Warning] Using a password on the command line interface can be insecure.

怎么将备份好的文件移除docker容器外

docker cp mysql:/test.sql ./
# docker cp 容器名:容器内的文件路径 容器外的路径

恢复之前的备份

先将sql文件拷贝到容器内

docker cp test.sql mysql:/
# docker cp sql文件 容器名:容器内的地址
mysql -uroot --password=123456 test<test.sql
# mysql -uroot --password=123456 数据库名<test.sql
# 记住,没有test数据库的话先创建个在恢复数据!!

执行完成之后可以去看下数据库

本文结束!!
有问题发出来可以一起讨论下

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值