Docker安装mysql Percona

参考 https://www.jianshu.com/p/26bf28b48e47

一部到位:docker create --name percona-master01 -v /data/mysql/master01/data:/var/lib/mysql -v /data/mysql/master01/conf:/etc/my.cnf.d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root percona:5.7.30

拉取镜像
docker pull percona:5.7.30

创建映射目录
mkdir /data/mysql/master01
cd /data/mysql/master01 
mkdir conf data log
chmod 777 * -R

conf下vi  my.cnf
--------------------------------------
[mysqld]
#开启日志
log-bin=mysql-bin
#服务id标识不能重复,作为主从同步使用
server-id=2
#数据同步的3中模式
binlog_format=MIXED

init_connect='SET collation_connection=utf8_unicode_ci'
init_connect='SET NAMES utf8'
character-set-server=utf8
collation-server=utf8_unicode_ci
skip-character-set-client-handshake
skip-name-resolve

[client]
default-character-set=utf8

[mysql]
default-character-set=utf8
------------------------------------

创建容器
docker create --name percona-master01 -v /home/mysql/master01/data:/var/lib/mysql -v /home/mysql/master01/conf:/etc/my.cnf.d  -v /home/mysql/master01/log:/var/log/mysql  -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root percona:5.7.30

注意: -p 3307:3306 ,后面的是容器端口

然后
docker ps -a


#启动 
docker start percona-master01 && docker logs -f percona-master01

ctrl+c
用工具去链接 启动成功了

重启 docker restart (CONTAINER ID)0311b3ca21d8
停止 docker stop (CONTAINER ID)0311b3ca21d8
启动 docker start 0311b3ca21d8
  1. 拉取镜像并查看镜像列表

    sudo docker pull percona:ps-5.7.30
    
    sudo docker images
    

    image-20200805140051369.png

  2. 创建实例并启动MySQL

    sudo docker run -p 3306:3306 --name mysql \
    -v /mydata/mysql/log:/var/log/mysql \
    -v /mydata/mysql/data:/var/lib/mysql \
    -v /mydata/mysql/conf:/etc/mysql \
    -e MYSQL_ROOT_PASSWORD=root \
    -d percona:ps-5.7.30
    
    • -p 3306:3306:将容器的3306号端口映射到主机的3306号端口
    • -v /mydata/mysql/log:/var/log/mysql:将容器的日志文件挂载到主机
    • -v /mydata/mysql/data:/var/lib/mysql:将容器的数据文件挂载到主机
    • -v /mydata/mysql/conf:/etc/mysql:将容器的配置文件挂载到主机
    • -e MYSQL_ROOT_PASSWORD=root:初始化root用户的密码
    • -d percona:ps-5.7.30:指定以什么镜像启动容器
  3. 查看实例容器是否已经启动

    sudo docker ps -a
    

    image-20200805143148746.png

  4. 如果启动失败,可以查看启动日志,了解原因。

    sudo docker logs 容器名称(也可以是container id)
    

    image-20200805143333184.png

    image-20200805145032999.png

  5. 为了方便统一管理以及解决权限问题,可以将外部挂载的文件权限转移给一般用户组,之后修改写权限

    sudo chown -R 用户名.组名 文件路径
    

    image-20200805143658756.png

  6. 将文件夹的读写权限放开,之后重启容器即可。

    sudo docker -R 777 文件路径(/mydata/mysql/)
    

    image-20200805145123472.png

    sudo docker restart 容器名称(也可以是container id)
    
  7. 配置mysql,只需要修改外部挂载的文件,其作用可以影响到容器内部的映射文件。

    vi 容器配置文件的外部挂载路径(/mydata/mysql/conf/my.cnf)
    
    # /mydata/mysql/conf/my.cnf
    [client]
    default-character-set=utf8
    
    [mysql]
    default-character-set=utf8
    
    [mysqld]
    init_connect='SET collation_connection=utf8_unicode_ci'
    init_connect='SET NAMES utf8'
    character-set-server=utf8
    collation-server=utf8_unicode_ci
    skip-character-set-client-handshake
    skip-name-resolve
    
  8. 重启mysql容器。

    sudo docker restart 容器唯一标识(mysql)
    
  9. 可以进入容器内部查证配置文件是否作用到了容器中。

    sudo docker exec -it 容器唯一标识(mysql) /bin/bash
    

    image-20200805145933179.png

  10. 设置MySQL容器开机自启动

    sudo docker update 容器唯一标识(mysql) --restart=always
    
  11. done!

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值