DevOps系列-Docker安装Mysql
最近两年推进公司研发使用Docker,在使用Docker做实验,特别方便,记录以下Docker安装MySql的步骤。
一、Docker hub 上查看要下载的mysql镜像名称
打开docker hub 网站
在上方搜索栏里输入mysql
回到虚拟机界面,执行下面命令来拉取mysql镜像
不指定版本号,默认下载最新版本:
docker pull mysql
指定版本号:
docker pull mysql:5.7
二、查看镜像
docker images
三、运行镜像
docker run -p 3306:3306 --name mysql --restart=always --privileged=true \ -v D:\Docker Space\mysql\log:/var/log/mysql \ -v D:\Docker Space\mysql\data:/var/lib/mysql \ -v D:\Docker Space\mysql\conf:/etc/mysql \ -e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest
命令说明:
-p 3306:3306:指定宿主机端口与容器端口映射关系 --name mysql:创建的容器名称 --restart=always:总是跟随docker启动 --privileged=true:获取宿主机root权限 -v /usr/local/mysql/log:/var/log/mysql:映射日志目录,宿主机:容器 -v /usr/local/mysql/data:/var/lib/mysql:映射数据目录,宿主机:容器 -v /usr/local/mysql/conf:/etc/mysql:映射配置目录,宿主机:容器 -v /etc/localtime:/etc/localtime:ro:让容器的时钟与宿主机时钟同步,避免时区的问题,ro是read only的意思,就是只读。 -e MYSQL_ROOT_PASSWORD=123456:指定mysql环境变量,root用户的密码为123456 -d mysql:latest:后台运行mysql容器,版本是latest。
四、查看正在运行的容器
# 查看正在运行的容器 docker ps # 查看所有的docker容器 docker ps -a
显示的是up状态,说明启动成功了。如果是restarting,说明是有问题的。我们可以查看日志:
docker logs -f mysql
五、查看容器内部
docker exec -it mysql /bin/bash
六、修改mysql配置
cd /usr/local/mysql ll cd conf vi my.cnf
my.cnf 文件中 修改如下内容:
[client] default-character-set=utf8mb4 [mysql] default-character-set=utf8mb4 [mysqld] # 设置东八区时区 default-time_zone = '+8:00' # 设置密码验证规则,default_authentication_plugin参数已被废弃 # 改为authentication_policy #default_authentication_plugin=mysql_native_password authentication_policy=mysql_native_password # 限制导入和导出的数据目录 # 为空,不限制导入到处的数据目录; # 指定目录,必须从该目录导入到处,且MySQL不会自动创建该目录; # 为NULL,禁止导入与导出功能 #secure_file_priv=/var/lib/mysql secure_file_priv= init_connect='SET collation_connection = utf8mb4_0900_ai_ci' init_connect='SET NAMES utf8mb4' character-set-server=utf8mb4 collation-server=utf8mb4_0900_ai_ci skip-character-set-client-handshake skip-name-resolve
七、重启Mysql
docker restart mysql
八、连接测试
_0900_ai_ci
skip-character-set-client-handshake
skip-name-resolve
#### 七、重启Mysql ```shell docker restart mysql
八、连接测试