不说了 先看图
Docker环境
没有的就网上找一下,我这就说两种linux下的:
yum install -y docker
和apt 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数据库的话先创建个在恢复数据!!
执行完成之后可以去看下数据库
本文结束!!
有问题发出来可以一起讨论下