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

2021-03-14  本文已影响0人  临星hfuu

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

上一篇下一篇

猜你喜欢

热点阅读