Docker安装CentOS7及MySQL8.0

Docker安装CentOS7及MySQL8.0

下载centos7镜像

 docker pull daocloud.io/centos:latest

运行centos7容器

docker run -dit --privileged --name=centos7 daocloud.io/centos:latest /usr/sbin/init

进入centos容器交互界面

docker exec -it centos7 /bin/bash

安装wget

yum install -y wget

安装MySQL官方的 Yum Repository

wget -i -c http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
yum -y install mysql57-community-release-el7-10.noarch.rpm

安装MySQL8.0

这里我安装就是8.0了 可以指定版本更吧

yum install -y mysql-server

启动MySQL

systemctl start  mysqld.service

查看MySQL运行状态

[root@07c7d9259a1f /]# systemctl status mysqld.service
● mysqld.service - MySQL 8.0 database server
   Loaded: loaded (/usr/lib/systemd/system/mysqld.service; disabled; vendor preset: disabled)
   Active: active (running) since Mon 2019-10-21 10:19:04 UTC; 12s ago
  Process: 219 ExecStartPost=/usr/libexec/mysql-check-upgrade (code=exited, status=0/SUCCESS)
  Process: 133 ExecStartPre=/usr/libexec/mysql-prepare-db-dir mysqld.service (code=exited, status=0/SUCCESS)
  Process: 95 ExecStartPre=/usr/libexec/mysql-check-socket (code=exited, status=0/SUCCESS)
 Main PID: 173 (mysqld)
   Status: "Server is operational"
    Tasks: 39 (limit: 11869)
   Memory: 732.1M
   CGroup: /docker/07c7d9259a1f125895d069a29c8296f38677f5bedeadaf0572b20e44bd3ccac4/system.slice/mysqld.service
           └─173 /usr/libexec/mysqld --basedir=/usr

Oct 21 10:19:01 07c7d9259a1f systemd[1]: Starting MySQL 8.0 database server...
Oct 21 10:19:04 07c7d9259a1f systemd[1]: Started MySQL 8.0 database server.

查看初始root密码

我的安装是没有root密码的

grep "password" /var/log/mysqld.log

img

修改root密码

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RhsiIWxl-1571654300949)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\1571653689816.png)]

设置允许远程登录

       Mysql默认不允许远程登录,所以需要开启远程访问权限

     可以先查看user表

     select user,authentication_string,host from user;

Docker安装CentOS7及MySQL8.0_第1张图片

默认都是localhost

update user set host = '%' where user = 'root';

Docker安装CentOS7及MySQL8.0_第2张图片

此时root的host是所有都可以了

然后刷新修改,FLUSH PRIVILEGES;

构建新镜像

docker commit -a "dedemao" -m "my mysql" centos7  dedemao/mysql

-a :提交的镜像作者;
-c :使用Dockerfile指令来创建镜像;
-m :提交时的说明文字;
-p :在commit时,将容器暂停。

img

构建新容器

docker run -dit --privileged -p 3310:3306 --name=mysql3310 dedemao/mysql /usr/sbin/init

进入容器:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-o6rGul2E-1571654300957)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\1571654045840.png)]

要是mysql 没有启动则启动mysql

外面链接

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-crR6SuNV-1571654300958)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\1571654120786.png)]

参考文档

https://blog.csdn.net/jason19905/article/details/81366202

https://www.cnblogs.com/goxcheer/p/9420460.html

你可能感兴趣的:(msyql-docker)