docker安装mysql8.0.16(dokcer系列二)


docker安装配置及常用命令(dokcer系列一)
docker安装redis并配置远程访问和密码(dokcer系列三)
docker安装gitlab并调优性能(docker系列四)
docker安装jenkins(docker系列五)
docker安装nacos并配置mysql数据库(docker系列六)
内网穿透加nginx转发实现本地服务远程访问(docker系列终)

拉取mysql镜像

查看docker hub上mysql版本
docker search mysql
在这里插入图片描述

拉取mysql8.0.16版本镜像
docker pull mysql:8.0.16

查看镜像
docker images

创建文件挂载目录

个人比较习惯将容器内重要文件挂载到宿主机方便查看修改
进入
cd /opt/

创建mysql挂载目录
sudo mkdir mysql_docker

进入创建的目录
cd mysql_docker/

创建并启动mysql容器

docker run --name mysql -m 512M --memory-swap=1024M -v $PWD/conf:/etc/mysql/conf.d -v $PWD/logs:/logs -v $PWD/data:/var/lib/mysql -d -p 3306:3306 --restart always -e MYSQL_ROOT_PASSWORD=123456 mysql:8.0.16

命令解释如下:

命令功能
docker run创建并启动容器
–name指定一个容器名称
-m指定容器内存大小
–memory-swap指定虚拟内存大小
-v将容器内部文件挂载到宿主机目录
$PWD输出当前所在目录名称,等同于/opt/mysql_docker
-e指定mysql的root用户初始密码
-d后台运行容器,并返回容器ID
-p指定端口
–restart always随docker启动
-e MYSQL_ROOT_PASSWORD=设置初始化密码,如果不设置启动容器会报错
mysql:8.0.16需要启动的镜像(名称+版本)
符号左边为宿主机,右边为容器空间

查看启动镜像是否启动成功
docker ps

开启mysql远程访问

进入mysql容器空间
docker exec -it mysql bash

登陆mysql
mysql -uroot -p
密码是创建容器时指定的密码

修改root用户模式并设置远程访问密码(%代表所有主机,可指定ip)
镜像里面 root用户已经有远程连接权限在里面,所以不需要去设置,只是模式不一样才导致无法连接
ALTER USER ‘root’@‘%’ IDENTIFIED WITH mysql_native_password BY ‘123456’;

其他用户开放权限方式
GRANT ALL PRIVILEGES ON . TO ‘root’@‘%’ IDENTIFIED BY ‘123456’;

grant表重新加载权限数据
flush privileges;

mysql容器控制命令

启动mysql容器
docker start mysql

重启mysql容器
docker restart mysql

停止mysql容器
docker stop mysql

删除mysql容器
docker rm mysql

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值