基于docker创建mysql容器

基础环境

Server: Docker Engine - Community
 Engine:
  Version:          20.10.9

选择镜像

  • 好用、可靠

不好用:DOCKER OFFICIAL IMAGE mysql

基于docker创建mysql容器_第1张图片

好用: VERIFIED PUBLISHER bitnami/mysql

部署容器

配置优先

不区分大小写

启动容器前进行配置

**注意:**如果是配置填写格式有问题,容器是启动不了的

  • 创建自定义配置文件
  • 挂载路径:/your_host_path/my_custom.cnf:/opt/bitnami/mysql/conf/bitnami/my_custom.cnf
[mysqld]
lower_case_table_names=1

lower_case_table_names=0 表名存储为给定的大小和比较是区分大小写的
lower_case_table_names = 1 表名存储在磁盘是小写的,但是比较的时候是不区分大小写
lower_case_table_names=2 表名存储为给定的大小写但是比较的时候是小写的
unix,linux下lower_case_table_names默认值为 0 .Windows下默认值是 1 .Mac OS X下默认值是 2

链接:【MySQL】lower_case_table_names参数详解 - 简书 (jianshu.com)

# 进入mysql命令行 执行以下任一语句查看:
show variables like 'lower_case_table_names';
select @@lower_case_table_names;

关闭only_full_group_by(可选)

**注意:**如果是配置填写格式有问题,容器是启动不了的

  • 报错日志
# which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
  • 调整配置后,重启生效

注意:如果是在数据库中进行调整,重启之后就恢复原样,因为 ONLY_FULL_GROUP_BY 更加符合 SQL 标准,所以不建议关掉。

[mysqld]
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

创建桥接网络

docker network create app-tier --driver bridge

方式一:基于命令启动容器

  • 指定容器名称
  • 加载自定义配置文件:my_custom.cnf
  • 设置环境变量,指定数据库root初始化密码
  • 为容器绑定已经创建的网络类型
  • 建立本地路径与容器路径之间的映射
  • 建立本地端口与容器端口之间的映射
  • 指定镜像名称
  • 后台运行
  • 默认支持远程主机连接,密码插件是:caching_sha2_password
docker run -d --name dev-mysql  -v /opt/docker/mysql/home:/home -v /opt/docker/mysql/home/my_custom.cnf:/opt/bitnami/mysql/conf/bitnami/my_custom.cnf:ro  -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 --network app-tier bitnami/mysql:8.0.25

运行连接数据库的容器

执行SQL,还是走容器靠谱

  • 退出时自动删除容器(已踩坑就是它)
docker run -it --rm --network app-tier -v /opt/docker/mysql/home:/home bitnami/mysql:8.0.25  mysql -hdev-mysql -uroot -p123456
  • 继续执行一个初始化SQL(可选)
source /home/your_sql.sql
  • 非容器的初始化SQL方法(可选)
mysql -uroot -p123456 --default-character-set=utf8 < init.sql

坑:以下方式不行

一、进入dev-mysql容器后,使用如下命令登录会失败或者成功,现象这是这样,暂不知道为什么

docker exec -it dev-mysql bash 
mysql -h172.24.0.2 -uroot -p123456

或者 
docker exec -it <CONTAINER_ID>  mysql -uroot -p123456

开启远程访问

Docker MySQLAccess denied for user ‘’@’172.17.0.1’(using password: YES) - Many Minds - Medium

MySQL8.0允许外部访问_lemon_cake的博客-CSDN博客_mysql8 远程连接

Docker部署Mysql8.0报错 Access denied for user ‘root‘@‘localhost‘ (using password: YES)_萧道子的博客-CSDN博客

update user set host='%' where user ='root';
#设置密码
#PASSWORD EXPIRE NEVER 密码永不过期
#将默认的插件【caching_sha2_password】修改成【mysql_native_password 】加密插件
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456' PASSWORD EXPIRE NEVER;
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;

验证命令

select user,host,plugin from user;
select version();

Docker Compose

Compose file versions and upgrading | Docker Documentation

兼容性矩阵

Compose 文件格式有多个版本 – 1、2、2.x 和 3.x

此表显示了哪些 Compose 文件版本支持特定的 Docker 版本。

Compose file format Docker Engine release
Compose specification 19.03.0+
3.8 19.03.0+
3.7 18.06.0+
3.6 18.02.0+
3.5 17.12.0+
3.4 17.09.0+
3.3 17.06.0+
3.2 17.04.0+
3.1 1.13.1+
3.0 1.13.0+
2.4 17.12.0+
2.3 17.06.0+
2.2 1.13.0+
2.1 1.12.0+
2.0 1.10.0+

v2 和 v3 声明

注意: 指定要使用的 Compose 文件版本时,请确保同时指定主要版本号和次要版本号。如果没有给出次要版本,则默认使用 0 而不是最新的次要版本。因此,将不支持后续版本中添加的功能。例如:

version: "2"

相当于:

version: "2.0"

方式二:基于yaml文件,启动容器

创建mysql数据存储目录

注意:由于这是一个非根容器,因此安装的文件和目录必须具有 UID 1001 的适当权限。若权限不对,无法正常运行容器,会卡死

NOTE: As this is a non-root container, the mounted files and directories must have the proper permissions for the UID 1001.

mkdir -p /opt/docker/mysql/data
#赋权
chown 1001:1001 /opt/docker/mysql/data

编写yaml配置文件

version: '3'
services:  
    mysql-service:
        image: bitnami/mysql:8.0.25
        hostname: mysql
        container_name: dev-mysql
        volumes:
            -  /opt/docker/mysql/data:/bitnami/mysql/data
            -  /opt/docker/mysql/home:/home
            - /opt/docker/mysql/home/my_custom.cnf:/opt/bitnami/mysql/conf/bitnami/my_custom.cnf:ro
        ports:
            - 3306:3306
        environment:
            MYSQL_ROOT_PASSWORD: '123456'
        networks:
            - app-tier
networks:
   app-tier:
       driver: bridge

启动容器

# --force-recreate  Recreate containers even if their configuration and image haven't changed.
# 即使容器的配置和图像没有改变,也可以重新创建容器。
docker-compose up --force-recreate

其它

  • 理解 docker 容器中的 uid 和 gid - sparkdev - 博客园 (cnblogs.com)
  • 大白话 Docker (新手入门必读) | Server优质外文翻译 | Server 运维论坛 (learnku.com)
  • 什么是 Docker - Docker — 从入门到实践 (gitbook.io)

你可能感兴趣的:(技术文档,docker,mysql,数据库)