Docker相当于一个小小的Linux系统构建方案,我们可以通过已有的
镜像
很方便的安装程序。该章节将讲述如何通过Docker搭建MySQL容器环境,还是以社区版为示例。
MySQL自从被Oracle收购之后,其fork的分支也不断涌现,其中一些分支的对比可以了解:
- MySQL社区版:可靠性和稳定性不高,不推荐。尤其生产环境不建议使用。
- MySQL企业版:需要支付金额购买。
- percona:兼容了MySQL的官方版本,同时也支持企业级MySQL的线程池操作。
- mariadb:随着不断的更新,已经与官方的版本有了较大的差异。
-
拉取镜像并查看镜像列表
sudo docker pull percona:ps-5.7.30
sudo docker images
-
创建实例并启动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
-
如果启动失败,可以查看启动日志,了解原因。
sudo docker logs 容器名称(也可以是container id)
-
为了方便统一管理以及解决权限问题,可以将外部挂载的文件权限转移给一般用户组,之后修改写权限
sudo chown -R 用户名.组名 文件路径
-
将文件夹的读写权限放开,之后重启容器即可。
sudo docker -R 777 文件路径(/mydata/mysql/)
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
-
设置MySQL容器开机自启动
sudo docker update 容器唯一标识(mysql) --restart=always
done!