参考 https://www.jianshu.com/p/26bf28b48e47
一部到位:docker create --name percona-master01 -v /data/mysql/master01/data:/var/lib/mysql -v /data/mysql/master01/conf:/etc/my.cnf.d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root percona:5.7.30
拉取镜像
docker pull percona:5.7.30
创建映射目录
mkdir /data/mysql/master01
cd /data/mysql/master01
mkdir conf data log
chmod 777 * -R
conf下vi my.cnf
--------------------------------------
[mysqld]
#开启日志
log-bin=mysql-bin
#服务id标识不能重复,作为主从同步使用
server-id=2
#数据同步的3中模式
binlog_format=MIXED
init_connect='SET collation_connection=utf8_unicode_ci'
init_connect='SET NAMES utf8'
character-set-server=utf8
collation-server=utf8_unicode_ci
skip-character-set-client-handshake
skip-name-resolve
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
------------------------------------
创建容器
docker create --name percona-master01 -v /home/mysql/master01/data:/var/lib/mysql -v /home/mysql/master01/conf:/etc/my.cnf.d -v /home/mysql/master01/log:/var/log/mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root percona:5.7.30
注意: -p 3307:3306 ,后面的是容器端口
然后
docker ps -a
#启动
docker start percona-master01 && docker logs -f percona-master01
ctrl+c
用工具去链接 启动成功了
重启 docker restart (CONTAINER ID)0311b3ca21d8
停止 docker stop (CONTAINER ID)0311b3ca21d8
启动 docker start 0311b3ca21d8
-
拉取镜像并查看镜像列表
sudo docker pull percona:ps-5.7.30
sudo docker images
image-20200805140051369.png
-
创建实例并启动MySQL
sudo docker run -p 3306:3306 --name mysql \ -v /mydata/mysql/log:/var/log/mysql \ -v /mydata/mysql/data:/var/lib/mysql \ -v /mydata/mysql/conf:/etc/mysql \ -e MYSQL_ROOT_PASSWORD=root \ -d percona:ps-5.7.30
- -p 3306:3306:将容器的3306号端口映射到主机的3306号端口
- -v /mydata/mysql/log:/var/log/mysql:将容器的日志文件挂载到主机
- -v /mydata/mysql/data:/var/lib/mysql:将容器的数据文件挂载到主机
- -v /mydata/mysql/conf:/etc/mysql:将容器的配置文件挂载到主机
- -e MYSQL_ROOT_PASSWORD=root:初始化root用户的密码
- -d percona:ps-5.7.30:指定以什么镜像启动容器
-
查看实例容器是否已经启动
sudo docker ps -a
image-20200805143148746.png
-
如果启动失败,可以查看启动日志,了解原因。
sudo docker logs 容器名称(也可以是container id)
image-20200805143333184.png
image-20200805145032999.png
-
为了方便统一管理以及解决权限问题,可以将外部挂载的文件权限转移给一般用户组,之后修改写权限
sudo chown -R 用户名.组名 文件路径
image-20200805143658756.png
-
将文件夹的读写权限放开,之后重启容器即可。
sudo docker -R 777 文件路径(/mydata/mysql/)
image-20200805145123472.png
sudo docker restart 容器名称(也可以是container id)
-
配置mysql,只需要修改外部挂载的文件,其作用可以影响到容器内部的映射文件。
vi 容器配置文件的外部挂载路径(/mydata/mysql/conf/my.cnf)
# /mydata/mysql/conf/my.cnf [client] default-character-set=utf8 [mysql] default-character-set=utf8 [mysqld] init_connect='SET collation_connection=utf8_unicode_ci' init_connect='SET NAMES utf8' character-set-server=utf8 collation-server=utf8_unicode_ci skip-character-set-client-handshake skip-name-resolve
-
重启mysql容器。
sudo docker restart 容器唯一标识(mysql)
-
可以进入容器内部查证配置文件是否作用到了容器中。
sudo docker exec -it 容器唯一标识(mysql) /bin/bash
image-20200805145933179.png
-
设置MySQL容器开机自启动
sudo docker update 容器唯一标识(mysql) --restart=always
-
done!