乐趣区

关于mysql:Docker下MySQL的安装

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
  • ustchttps://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 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

先备份:

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 update
apt 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.dMySQL 会主动合并默认的配置文件 /etc/mysql/my.cnf 与自定义的配置文件(这里是/etc/mysql/conf.d/my.cnf)。

再次进入容器查看字符集:

能够看到字符集被批改为了utf8bm4

7 参考

  • Docker Hub MySQL
  • 博客园 -Docker 装置 mysql
  • 博客园 -Docker - V 详解
  • 博客园 -MySQL 查看和批改字符集的办法
退出移动版