zoukankan      html  css  js  c++  java
  • 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 参考

  • 相关阅读:
    vue2 作用域插槽slot-scope详解
    vue2 inheritAttrs、attrs和attrs和listeners使用
    vue 渲染后更新数据
    php 两次encodeURI,解决浏览器跳转请求页乱码报错找不到页面的bug
    nginx 和 tp兼容pathinfo和rewrite两种url访问方式
    TFTP
    FTP服务相关实现
    FTP相关内容
    Redis高级
    Redis的相关命令
  • 原文地址:https://www.cnblogs.com/6b7b5fc3/p/13833990.html
Copyright © 2011-2022 走看看