拉取镜像
docker pull mysql:5.7
启动镜像并挂载容器内一些数据到外部环境
docker -p port1:port2 其中port1是linux服务器的端口,port2是docker容器内部的端口
-v path1:path2 其中path1是linux服务器的路径,port2是dockers容器内部路径
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 mysql:5.7
在外部挂载文件中进行mysql配置
$ cd /mydata/mysql/conf/
$ vi 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镜像
$ docker restart mysql
进入容器内部看下mysql配置是否对应更新
进入docker容器:docker exec -it XX bash 例如:(docker exec -it mysql bash)
退出docker容器:ctrl+d 或者输入 exit
$ docker exec -it mysql /bin/bash
$ cd /etc/mysql
$ cat my.cnf