1 概述
本文讲述了如何利用Docker
去装置MySQL
,以及MySQL
自定义配置文件的相干设置。
2 装置Docker
首先装置Docker
并开启服务:
systemctl start docker
如果没有增加国内源的话倡议增加一下,新增/批改/etc/docker/daemon.json
,增加如下内容:
{ "registry-mirrors": ["http://hub-mirror.c.163.com"]}
这里用的是网易的源,其余源如下:
Docker
中国区官网镜像:https://registry.docker-cn.com
ustc
:https://docker.mirrors.ustc.edu.cn
- 中科大:
https://docker.mirrors.ustc.edu.cn
- 阿里云:每个人不同,须要到阿里云容器服务创立,具体请查看文档
3 拉取MySQL
镜像
docker pull mysql:latest
权限不够请加sudo
,另外这一步须要一点工夫,请急躁期待。
拉取实现后能够查看镜像:
docker images
4 运行容器
docker run -itd -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 --name mysql-latest mysql
参数阐明:
-i
:以交互模式运行,通常配合-t
-t
:为容器重新分配一个伪输出终端,通常配合-i
-d
:后盾运行容器-p
:端口映射,格局为主机端口:容器端口
-e
:设置环境变量,这里设置的是root
明码--name
:设置容器别名
运行之后会返回一个容器ID
。
5 测试
先查看运行状态:
docker ps
接着连贯到容器的伪终端上:
docker exec -it mysql-latest /bin/bash
其中mysql-latest
是执行运行命令时创立的别名,同时应用mysql
测试连贯:
mysql -u root -p
输出环境变量传递的root
明码后就能够连贯上MySQL
了:
也能够在IDEA
中增加MySQL
数据源并测试连贯:
6 配置文件
一般来说仅仅装置完MySQL
是不够的,还须要自定义一些配置文件,自定义配置文件有两种办法,一种是进入容器并批改外面的my.cnf
,另一种是容器启动的时候应用-v
参数挂载配置文件的目录。
6.1 容器内批改
首先进入容器:
docker exec -it mysql-latest /bin/bash
请把mysql-latest
批改为对应的容器别名,进入后能够通过
mysql --help | grep my.cnf
查看配置文件的地位:
这几个文件存在读取程序,能够应用
mysqld --verbose --help --pid-file=/var/run/mysqld/mysqld.pid | grep -A 1 "Default options"
查看:
这里批改的是/etc/mysql/my.cnf
,然而。。。
没有vim
?关系不大先用vi
将就一下:
过后就人傻了竟然vi
都没有,行,关系不大,装置就行了:
这都什么玩意。。。包都搜不到。。。
查看了一下零碎的版本,是Debian 10
:
于是就找了对应的源:
deb http://mirrors.aliyun.com/debian/ buster main non-free contribdeb-src http://mirrors.aliyun.com/debian/ buster main non-free contribdeb http://mirrors.aliyun.com/debian-security buster/updates maindeb-src http://mirrors.aliyun.com/debian-security buster/updates maindeb http://mirrors.aliyun.com/debian/ buster-updates main non-free contribdeb-src http://mirrors.aliyun.com/debian/ buster-updates main non-free contribdeb http://mirrors.aliyun.com/debian/ buster-backports main non-free contribdeb-src http://mirrors.aliyun.com/debian/ buster-backports main non-free contrib
先备份:
cp /etc/apt/sources.list /etc/apt/sources.list.bak
而后批改增加即可:
vim /etc/apt/sources.list
然而没有这个命令。。。
没方法了手动echo
增加:
echo deb http://mirrors.aliyun.com/debian/ buster main non-free contrib deb-src http://mirrors.aliyun.com/debian/ buster main non-free contrib deb http://mirrors.aliyun.com/debian-security buster/updates main deb-src http://mirrors.aliyun.com/debian-security buster/updates main deb http://mirrors.aliyun.com/debian/ buster-updates main non-free contrib deb-src http://mirrors.aliyun.com/debian/ buster-updates main non-free contrib deb http://mirrors.aliyun.com/debian/ buster-backports main non-free contrib deb-src http://mirrors.aliyun.com/debian/ buster-backports main non-free contrib > sources.list
而后更新:
apt updateapt upgrade
装置vim
:
apt install vim
接着批改配置文件即可:
vim /etc/mysql/my.cnf
上面是示例罕用参数:
[mysqld]character-set-server=utf8mb4[client]default-character-set=utf8mb4[mysql]default-character-set=utf8mb4
6.2 运行容器时挂载
先查看一下原来容器的字符集:
show variables like '%character%';
未修改之前的字符集如图,上面应用-v
参数挂载配置文件目录并对字符集进行批改,首先先把原来的容器进行掉,免得端口占用:
docker stop mysql-latest
接着在宿主机目录/etc/mysql
下创立一个配置文件my.cnf
:
vim /etc/mysql/my.cnf# 增加如下内容[mysqld]character-set-server=utf8mb4[client]default-character-set=utf8mb4[mysql]default-character-set=utf8mb4
从新创立并运行容器,并同时挂载目录:
docker run -itd -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /etc/mysql:/etc/mysql/conf.d --name mysql mysql
其中-v
参数是挂载宿主机的一个目录,把宿主机的一个目录挂载到容器上,留神须要批改--name
,不容许反复。
依据官网文档(链接戳这里),默认的配置文件地位为/etc/mysql/my.cnf
,自定义的配置文件地位能够为/etc/mysql/conf.d
或/etc/mysql/mysql.conf.d
,因而将宿主机的/etc/mysql
挂载到容器的/etc/mysql/conf.d
,MySQL
会主动合并默认的配置文件/etc/mysql/my.cnf
与自定义的配置文件(这里是/etc/mysql/conf.d/my.cnf
)。
再次进入容器查看字符集:
能够看到字符集被批改为了utf8bm4
。
7 参考
- Docker Hub MySQL
- 博客园-Docker装置mysql
- 博客园-Docker -V详解
- 博客园-MySQL查看和批改字符集的办法