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

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

可以看到字符集被修改为了utf8bm4。
7 参考
Docker下MySQL的安装的更多相关文章
- Linux(Ubuntu)下MySQL的安装与配置
转自:http://www.2cto.com/database/201401/273423.html 在Linux下MySQL的安装,我一直觉得挺麻烦的,因为之前安装时就是由于复杂的配置导致有点晕.今 ...
- .Neter玩转Linux系列之六:Linux下MySQL的安装、配置、使用
一.Linux安装MySQL (1)下载安装包:https://dev.mysql.com/downloads/mysql/ (2)解压并安装 命令:tar zxvf 文件名 解压完成之后,重名一下文 ...
- Linux(centos)下mysql编译安装教程
Linux下mysql编译安装教程 #查看linux发行版本 cat /etc/issue #查看linux内核版本号 uname -r 本文測试环境centOS6.6 一.Linux下编译安装MyS ...
- Windows下MySQL的安装和删除
Windows下MySQL的安装和删除 安装Mysql 1 下载mysql 地址 2 安装教程 2.1配置环境变量 变量名:MYSQL_HOME 变量值:D:\software\programming ...
- docker下MySQL的主从复制
MySql的主从复制 sudo docker pull MySQL:5.7 拉取MySQL的镜像文件(版本号为 5.7) sudo docker run -p 3339:3306 --name mas ...
- docker 下mysql 和postgresql 数据库的搭建以及数据文件的迁移和备份
service docker start - docker 启动 service docker stop - docker 关闭 1.docker 镜像创建—使用的默认镜像有数据卷 docker pu ...
- mac下mysql的安装
由于最近需要布置mantis用来进行bug追踪,在此记录其过程. 由于PHP apache环境在Mac OS上是自带的,所以不需要另处下安装包,只需要简单配置一下即可. 首先打开终端输入命令: sud ...
- linux 下mysql的安装,并设置必要的密码
首先,我使用的是redhat linux ,版本号为: [root@localhost init.d]# cat /proc/version Linux version - (bhcompile@po ...
- Linux下mysql的安装和使用(C语言)
1 mysql的安装 我使用的ubuntu在线安装,非常简单,命令为: sudo apt-get install mysql-client mysql-server 2 mysql命令集合 网络太多了 ...
随机推荐
- JVM系列(四):java方法的查找过程实现
经过前面几章的简单介绍,我们已经大致了解了jvm的启动框架和执行流程了.不过,这些都是些无关痛痒的问题,几行文字描述一下即可. 所以,今天我们从另一个角度来讲解jvm的一些东西,以便可以更多一点认知. ...
- 1004 Counting Leaves ——PAT甲级真题
1004 Counting Leaves A family hierarchy is usually presented by a pedigree tree. Your job is to coun ...
- vue-axios插件、django-cors插件、及vue如何使用第三方前端样式库:element/jQuery/bootstrap
目录 一.vue的ajax插件:axios 1.安装axios 2.axios参数 二.CORS跨域问题(同源策略) 1.Django解决CORS跨域问题方法 三.前端请求携带参数及Django后台如 ...
- WPF -- DataTemplate与ControlTemplate结合使用
如深入浅出WPF中的描述,DataTemplate为数据的外衣,ControlTemplate为控件的外衣.ControlTemplate控制控件的样式,DataTemplate控制数据显示的样式,D ...
- hive中更改表impala中不能生效
hive中的更新或者新建表impala 不能实时更新 Impala是基于Hive的大数据实时分析查询引擎,直接使用Hive的元数据库Metadata,意味着impala元数据都存储在Hive的meta ...
- 鸿蒙的js开发部模式18:鸿蒙的文件上传到python服务器端
1.首先鸿蒙的js文件上传,设置目录路径为: 构建路径在工程主目录下: 该目录的说明见下面描述: 视图构建如下: 界面代码: <div class="container"&g ...
- ss_port_change - 一键修改ss配置与Centos7的Firewall策略脚本
ss_port_change 修改ss配置与Centos7的Firewall策略脚本 注意是否需要修改config路径与ss服务的名 脚本的敏感字用了*代替 项目地址 Github 脚本 #!/bin ...
- BERT 服务化 bert-as-service
bert-as-service 用 BERT 作为句子编码器, 并通过 ZeroMQ 服务托管, 只需两行代码就可以将句子映射成固定长度的向量表示; 准备 windows10 + python3.5 ...
- Kafka SASL ACL配置踩坑总结
源起:工程现阶段中间件采用的是kafka.满足了大数据的高吞吐,项目间的解耦合,也增强了工程的容错率与扩展性.但是在安全这一块还有漏洞,kafka集群中,只要网站内的任何人知道kafka集群的ip与t ...
- WPF 基础 - x 名称空间详解
名称 种类(默认Attribute) 备注 x:Array 标记拓展 可作为 ListBox.ItemsSource 的值 x:Class 指定与 .cs 中哪个类合并,所指示的类型在声明时使用 pa ...