CentOS 安装Docker 并部署配置MySql
先安装Docker
卸载之前Docker
1 $ sudu yum remove docker \ 2 docker-client \ 3 docker-client-latest \ 4 docker-common \ 5 docker-latest \ 6 docker-latest-logrotate \ 7 docker-logrotate \ 8 docker-selinux \ 9 docker-engine-selinux \ 10 docker-engine
-
安装之前需要安装 yum-utils提供的yum-config-manager
1 $ sudo yum install -y yum-utils \ 2 device-mapper-persistent-data \ 3 lvm2
-
安装yum-config-manager
1 $ sudo yum-config-manager \ 2 --add-repo \ 3 https://download.docker.com/linux/centos/docker-ce.repo
-
安装最新版 $ yum install docker-ce
-
安装指定版本
1 $ yum list docker-ce --showduplicates | sort -r 2 docker-ce.x86_64 18.09.0.ce-1.el7.centos docker-ce-stable 3 -- 然后选择列表中指定版本 4 $ sudo yum install docker-ce-<VERSION STRING>
如无特殊要求安装最新版即可
1 sudo mkdir -p /etc/docker 2 sudo tee /etc/docker/daemon.json <<-'EOF' 3 { 4 "registry-mirrors": ["<your accelerate address>"] 5 } 6 EOF 7 sudo systemctl daemon-reload 8 sudo systemctl restart docker
注意:文中的加速器地址<your accelerate address>
,请到容器镜像服务控制台查看。
-
启动Docker (上一步配置阿里云镜像地址后已经重启,不需要再启动)
CentOS 7 Docker 启动命令 sudo systemctl restart docker
并检查是否使用了镜像: $ ps -ef|grep docker
registry-mirros
则成功 -
安装MySQL(最新版本)
查看本地镜像: $ sudo docker images 本地没有镜像,则 $ sudo docker search mysql 选择STARS最多的 $ sudo docker pull mysql
-
安装MySQL(指定版本)
$ sudo docker pull mysql:5.7
-
启动MySQL
$ sudo docker run -p 12345:3306 --name mysql -v /root/mysql/conf:/etc/mysql/conf.d -v /root/mysql/logs:/logs -v /root/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
参数讲解:
-
-p是将docker中mysql端口号3306映射成为12345端口,也可以选择不映射,使用默认的3306
-
--name mysql: 运行服务的取名
-
-v是将主机目录下的文件挂载到容器中路径下(/scy是我本人用户)
-
-e MYSQL_ROOT_PASSWORD:初始化root用户密码
-
-d mysql:5.7 : 后台运行mysql5.7
-
-
至此,安装运行就结束了。
进入容器
docker exec -it mysql /bin/bash
mysql指定的–name
进入mysql
root@e34aba02c0c3:/# mysql -u root -p
查看数据库字符集
1 mysql> SHOW VARIABLES LIKE 'characterset%'; --默认是瑞典latin1 2 mysql> SHOW VARIABLES LIKE 'collation_%'; 3 +----------------------+--------------------+ 4 | Variable_name | Value | 5 +----------------------+--------------------+ 6 | collation_connection | latin1_swedish_ci | 7 | collation_database | utf8mb4_0900_ai_ci | 8 | collation_server | utf8mb4_0900_ai_ci | 9 +----------------------+--------------------+ 10 3 rows in set (0.00 sec)
connection 就是我们通过客户端连接的时候指定的编码。 外部访问数据乱码的问题就出在这个connection连接层上
修改为utf-8
SET NAMES 'utf8';
修改配置文件
mysql 服务器配置文件 /etc/mysql/mysql.conf.d/mysqld.cnf
修改过程中需要安装vi 或者 vim,然而docker镜像内镜像源没有速度,所以更新速度慢
可以通过 docker cp d606:/etc/mysql/mysql.conf.d/mysqld.cnf /root/mysql/mysqld.cnf 命令将文件拷贝出来修改后同样拷贝回去的方式修改
[mysqld] 标签下添加 character_set_server = utf8
[client] 标签下添加 default-character-set=utf8
[mysql] 标签下添加 default-character-set=utf8
上面的配置需要紧跟标签,否则无法启动mysql
配置docker开机自启 systemctl enable docker.service
配置mysql 自动启动 docker update --restart=always d606
至此 通过docker部署并配置MySQL完成
如果本地之前安装过Docker,需要先卸载,如果没有安装过,可以跳过这一步: