1. 前提是Docker已经安装好了
没有安装的可以看这篇文章-->CentOS 7安装Docker
2.拉取mysql镜像
docker pull mysql:5.7
docker images
-
可以看到我们拉取的镜像
- 宿主机创建几个文件夹用于容器文件挂载
mkdir -p /home/service/mysql/data
mkdir -p /home/service/mysql/conf/my.cnf
在my.cnf追加如下数据
[mysqld]
user=mysql
character-set-server=utf8
default_authentication_plugin=mysql_native_password
default-time_zone = '+8:00'
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
- 然后运行命令启动mysql
docker run -p 3306:3306 --name mysql \
-v /home/service/mysql/data:/var/lib/mysql \
-v /home/service/mysql/conf/my.cnf:/etc/my.cnf \
-e MYSQL_ROOT_PASSWORD=123456\
-e TZ=Asia/Shanghai \
-d mysql
docker run -p 3306:3306 --name mysql -v /home/service/mysql/logs:/logs -v /home/service/mysql/data:/mysql_data -e MYSQL_ROOT_PASSWORD=123456 -d mysql
命令讲解
-p
3306:3306:将容器的3306端口映射到主机的3306端口
-e
MYSQL_ROOT_PASSWORD=123456:初始化root用户的密码
-e
TZ=Asia/Shanghai 修改容器默认时区为上海
-v
=/mysqltest/config/my.cnf:/etc/my.cnf:映射配置文件
-v
=/mysqltest/data:/var/lib/mysql:映射数据目录
注意:不同mysql版本可能配置文件目录和路径不一样,mysql5.7的容器路径为 /etc/mysql/mysql.conf.d/mysqld.cnf。
- 进入容器
docker exec -it mysql bash
- 登陆mysql
mysql -uroot -p
- 创建mysql用户
CREATE USER 'admin'@'%' IDENTIFIED BY '123456';
GRANT ALL ON *.* TO 'admin'@'%';
flush privileges;
- 然后就可以使用admin用户登陆了,因为mysql8与mysql5.7授权有一些不一样,mysql必须先创建用户才能授权,不然会出错。
3、修改时区
docker exec -it mysql /bin/bash
cd /etc/mysql/mysql.conf.d
apt-get update
apt-get install vim
vim mysqld.cnf
加入如下一行
default-time_zone = '+8:00'
或者直接追加写入
echo "default-time_zone = '+8:00'" >> mysqld.cnf
- 修改时区
在我们备份数据库的时候,有用到时间因素,但是 Docker 容器中默认为 +0 时区,而我们是 +8 时区,我们将宿主机的时区文件映射过去就行。
-v /etc/localtime:/etc/localtime:ro
退出容器重启容器
docker restart mysql
查看时区命令
show variables like '%time_zone%';