美文网首页
Docker中MySQL环境的安装运行配置

Docker中MySQL环境的安装运行配置

作者: 临星hfuu | 来源:发表于2021-03-14 17:39 被阅读0次

    1.安装MySQL

    Docker官网 >> | Docker hub >>
    可以从docker hub上找到常用开发环境的镜像库,docker hub是一个镜像托管仓库;
    在docker hub上搜索mysql 就能搜到其镜像库;拷贝其安装语句:

    docker pull mysql    // 默认下载最新版本 latest
    docker pull mysql:5.7.32    // 当然你也可以指定版本号下载对应的版本
    

    在docker hub上搜索到mysql主页其中的tag标签下展示了支持的历史版本号

    2.运行一个mysql容器

    现在开始运行一个mysql的容器,这里主要留意初始参数和启动项参数

    docker run -dt --name=mysql_test -p 3306:3306  -e MYSQL_ROOT_PASSWORD=123456 mysql
    // -d    d 守护模式
    // -p 指定端口号  宿主机端口:映射到的docker机端口
    // -- name 启动的容器名称   (注意name前面两个-)
    // -e  启动mysql必须配备的参数 指定ROOT用户的初始密码
    docker ps  //检查是否启动 会列出所有已启动容器的信息
    docker stop mysql_test / id
    // 可以用名称和容器id停止容器
    

    运行成功后利用docker ps检查一下运行结果。
    可以利用下面的命令执行容器的bash:

    docker  exec -it [容器名称]or[容器id] /bin/bash
    //  -it   i 交互式操作     t 终端
    //  /bin/bash 一般用于启动命令行  以命令的方式交互
    

    尝试登陆进入数据库,以上操作就进入容器所在的环境了,就可以使用容器的命令了,以mysql为例:

    mysql -u root -p123456;
    // mysql 命令  -u root  指定用户名为root
    // -p 指定密码
    // 123456 输入的密码
    // ;sql语句必须以;结束 
    

    3.mySQL的配置

    sudo docker run -p 3306:3306 --name mysql \
    -v /usr/local/docker/mysql/conf:/etc/mysql \
    -v /usr/local/docker/mysql/logs:/var/log/mysql \
    -v /usr/local/docker/mysql/data:/var/lib/mysql \
    -e MYSQL_ROOT_PASSWORD=123456 \
    -d mysql:5.7
    
    1.上面 -v 的操作是指挂载,即:把后面的容器内部目录挂载到前面的宿主机上的外部目录,方便我们在宿主机上查看容器内相关的日志 。前面的目录是我们自己创建,准备好的(根据自己创建的文件夹路径配置)。
    2. \ 是用于拼接上面的命令成一行

    4.run mySQL的另一种方式 docker-compose

    // 安装一下docker-compose   在centOS上用podman 安装 podman-compose
    apt install docker-compose  // centOS 上:  pip3 install docker-compose
    
    1.通过vim编辑器创建docker-compose.yml文件
    // 注意:后面和 - 后面 都必须有一个小空格  在文件中定义一个service
    version: '2.2'
    services: 
        mysql: 
            container_name: "mysql_car"
            network_mode: "host"
            environment: 
                MYSQL_ROOT_PASSWORD: "123456"
                MYSQL_USER: "root"
                MYSQL_PASS: "123456"
            image: "mysql:5.7.32"
            restart: always
            ports: 
                  - 3306:3306
            volumes: 
                  - "/etc/mysql/:/home/beop/docker/mysql/conf/"  
                  - "/var/log/mysql/:/home/beop/docker/mysql/log/" 
                  - "/var/lib/mysql/:/home/beop/docker/mysql/db/"
    

    上面的volumes:
    // 挂载mysql 配置文件到conf文件夹
    // 挂载mysql的logs目录
    //挂载mysql的数据目录
    (在/home/beop 中创建对应的目录文件夹)

    2.安装docker-compose插件
    下载最新版的docker-compose文件
    sudo curl -L https://github.com/docker/compose/releases/download/1.16.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
    

    若是github访问太慢,可以用daocloud下载

    sudo curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
    
    添加可执行权限
    sudo chmod +x /usr/local/bin/docker-compose
    # chmod : change mode
    # +x : 可执行模式
    
    用pip安装
    sudo pip install docker-compose
    

    docker-compose安装使用教程

    docker-ce是docker团队认证,docker团队维护的一个社区版发行包,docker.io是ubuntu团队(我不知道debian是不是也这样)维护的一个包。由于之前ubuntu团队有很长一段时间没有维护docker的版本,导致有一段时间docker.io的版本还停留在远古版本。后来ubuntu版本重新开始维护,版本继续迭代,截止2020-12-27日,版本已经更新到Docker version 19.03.6, build 369ce74a3c。
    两者使用相同的包管理,docker-ce是所有依赖包由docker团队管理,可以保证docker运行的稳定,适合作为纯docker管理的生产环境,即整个系统只有一个docker在跑,剩下所有应用都通过发布docker的容器来部署。
    docker.io的依赖包则是由ubuntu统一管理,更符合包管理的理念,也更规范,可以尽可能的保证系统和多个软件的运行稳定,适合作为多软件协同运行的服务器和个人桌面使用。
    docker是一个被广泛使用的流行软件了,ubuntu再次停止维护的概率不大。所以除了纯docker环境,个人建议直接用docker.io

    相关文章

      网友评论

          本文标题:Docker中MySQL环境的安装运行配置

          本文链接:https://www.haomeiwen.com/subject/klouiktx.html