环境:
Linux 系统: CentOS 7.3
Docker 版本: version: 17.12.0-ce
1. 操作系统切换到 root 用户:
# su root
2. 启动 docker
# systemctl start docker
3. 拉取 mysql8.0 镜像
# docker pull MySQL:8.0
4. 创建并启动容器
-p: 映射本地端口 3306
--restart-always: docker 服务启动时, 自动启动容器, 并且当容器停止时, 尝试重启容器.
--restart 具体参数值详细信息:
no - 容器退出时, 不重启容器;
on-failure - 只有在非 0 状态退出时才从新启动容器;
always - 无论退出状态是如何, 都重启容器;
MYSQL_ROOT_PASSWORD: 设置 root 密码为 root
设置默认数据库编码为 utf8mb4, 默认排序规则为 utf8mb4_unicode_ci
-v : 挂载本地卷
注意: mysql8.0 安装默认编码为 utf8mb4, 所以可以不需要参数 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
- docker run \
- --name MySQL \
- -p 3306:3306 \
- --restart=always \
- -e MYSQL_ROOT_PASSWORD=root \
- -v /var/lib/MySQL/:/var/lib/MySQL/ \
- -d MySQL:8.0 \
- --character-set-server=utf8mb4 \
- --collation-server=utf8mb4_unicode_ci
5. 进入 docker 的 MySQL 容器
# docker exec -it MySQL /bin/bash
6. 登录数据库 (此处的密码为参数 - e MYSQL_ROOT_PASSWORD=root 对应的值, 此处密码为 root)
# MySQL -uroot -proot
7. 使用 MySQL 数据库
MySQL> use MySQL;
8. mysql8.0 的 root 用户的验证方式变了, 通过查询: select host,user,plugin from user;
得知: root 的用户的加密方式为 caching_sha2_passoword, 而 navicat 连接所用的方式为 native_password.MySQL 为远程连接和本地连接提供了不同的密码验证方式.
修改 root 用户插件验证方式:
MySQL> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root';
注意: 先更改 ser 表中用户为 root 的 host 字段, 若为 localhost 则改为 %, 只有改为 %, 该用户才可以远程访问.
此时, 可以使用 MySQL 客户端工具连接数据库.
如果 navicat 提示 "1045 access denied for user'root'@'localhost' ", 则执行:
MySQL> alter user 'root'@'localhost' identified by 'root';
同理: 如果 navicat 提示 "1045 access denied for user'root'@'%' ", 则执行:
MySQL> alter user 'root'@'%' identified by 'root';
刷新权限:
MySQL> flush privileges;
9. 修改 MySQL 数据库编码, 防止中文乱码
(1) 进入 docker 的 MySQL 容器
# docker exec -it MySQL /bin/bash
(2) 容器默认没有安装任何编辑器, 先安装 VIM.
# apt-get update && apt-get install VIM -y
(3) 安装完 VIM 之后, 开始修改 MySQL 数据库编码
# VIM /etc/MySQL/conf.d/MySQL.cnf
增加以下内容, 然后保存, 退出:
- [client]
- default-character-set=utf8
- [MySQL]
- default-character-set=utf8
(4) 重启 MySQL 容器, 查询编码: 此时编码已经修改为 utf8.
MySQL> show variables like'character%';
10. 查看挂载卷位置: 获取容器 / 镜像的元数据.
# docker inspect 容器 ID
其中:
- "Mounts": [
- {
- "Type": "volume",
- "Name": "ebc0e8f50d451650f29d7ac1a696a0130316073173835c1b5c9f7f88c5fb976f",
- "Source": "/var/lib/docker/volumes/ebc0e8f50d451650f29d7ac1a696a0130316073173835c1b5c9f7/_data",
- "Destination": "/var/lib/mysql",
- "Driver": "local",
- "Mode": "","RW": true,"Propagation":""
- }
- ]
Source: 为本地主机挂载卷的路径
来源: http://www.linuxidc.com/Linux/2019-02/157029.htm