• Docker中安装mysql


    1、查看镜像

          到 Docker hub中查询需要的镜像:https://hub.docker.com/_/mysql

    2、拉取镜像

          进入root用户,使用 sudo docker pull mysql:5.7 拉取镜像,如果不加版本号例如sudo docker pull mysql,则默认拉取最新版本。

          su root        默认密码是vagrant

          sudo docker pull mysql:5.7

     3、查看是否拉取成功

           sudo docker images

             下载的镜像是mysql ,版本是5.7,镜像id是 xxxxx

     4、创建并启动一个mysql容器

           注意:创建一个容器的时候,一个容器就相当于一个小的linux系统,系统里面安装着mysql系统,因此我们为了方便维护这个容器中的mysql,需要将容器中的mysql文件进行挂载。挂载到虚拟机的linux中。下面的命令中 -v 就是在创建容器的时候,进行对应挂载。以后启动其他容器也是同样需要挂载。

    1. sudo docker run -p 3306:3306 --name mysql \
    2. -v /mydata/mysql/log:/var/log/mysql \
    3. -v /mydata/mysql/data:/var/lib/mysql \
    4. -v /mydata/mysql/conf:/etc/mysql \
    5. -e MYSQL_ROOT_PASSWORD=root \
    6. -d mysql:5.7
    7. 参数说明:
    8. -p 3306:3306:将容器的3306端口映射到主机的3306端口
    9. -v /mydata/mysql/conf:/etc/mysql:将容器中的mysql配置文件夫挂戟到主机
    10. -v /mydata/mysql/log:/var/log/mysql:将容器中的mysql日志文件夹挂载到主机
    11. -v /mydata/mysql/data:/var/lib/mysql:将容器中的mysql数据文件夹挂戟到主机
    12. -e MYSQL_ROOT_PASSWORD=root 初始化 root 用户的密码
    13. -d mysql:5.7 :以后台方式运行,使用哪个镜像启动的mysql容器

     

      5、查看运行的容器

            sudo docker ps       

             证明mysql 容器 已经运行起来了,可以通过mysql界面工具进行操作查看    

    6、配置mysql

    1. vi /mydata/mysql/conf/my.cnf
    2. 输入以下内容后按ESC输入":wq"保存退出
    3. [client]
    4. default-character-set=utf8
    5. [mysql]
    6. default-character-set=utf8
    7. [mysald]
    8. init_connect='SET collation_connection = utf8_unicode ci'
    9. init_connect='SET NAMES utf8'
    10. character-set-server=utf8
    11. collation-server=utf8_unicode_ci
    12. skip-character-set-client-handshake
    13. skip-name-resolve
    14. 注意:解决MySQL连接慢的问题在配置文件中加入如下,并重启 mysql
    15. [mysqld]
    16. skip-name-resolve
    17. 解释:
    18. skip-name-resolve:跳过域名解析

     配置mysql后,需要进行重启mysql

    7、挂载的原理:

            执行 sudo docker exec -it mysql /bin/bash 命令,进入后执行ls,发现也是在linux系统中,说明我们mysql容器本身就是一个小的linux环境。如果要使用这个容器中的端口或者维护这个容器中mysql 的文件,则不方便,因此需要进行挂载到容器外面的linux系统中。挂载在创建容器时候已经执行,可查看容器外的linux系统的目录。

  • 相关阅读:
    Linux下lsof命令使用
    【数据结构】树与森林
    用vue styleguidist 写组件文档
    多线程系列(十三) -一文带你搞懂阻塞队列
    04 随机梯度下降
    【前端设计模式】之外观模式
    LeetCode每日一题(898. Bitwise ORs of Subarrays)
    配电房智能综合监控系统
    话术-思维
    森林防火(资源监管)“空天地人”四位一体监测系统方案
  • 原文地址:https://blog.csdn.net/qq_41946216/article/details/126662910