当前位置:   article > 正文

docker安装mysql,并将配置文件映射到宿主机_docker mysql配置映射

docker mysql配置映射

docker安装mysql

1 启动docker

#查看状态
systemctl status docker

#启动docker
systemctl start docker

#重新加载
systemctl daemon-reload

#重启docker
systemctl restart docker

#查看版本
docker version

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

2 拉取镜像

# 拉取镜像
docker pull mysql
 
# 或者
docker pull mysql:latest
 
# 以上两个命令是一致的,默认拉取的就是 latest 版本的
 
# 我们还可以用下面的命令来查看可用版本:
docker search mysql
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

3 查看镜像

使用以下命令来查看是否已安装了 mysql镜像

docker images
  • 1

在这里插入图片描述

4 创建映射文件

# 创建文件夹
mkdir -p /root/mysql/data
mkdir -p /root/mysql/conf
mkdir -p /root/mysql/log
  • 1
  • 2
  • 3
  • 4

5 运行镜像

1)mysql 的安装镜像

docker run -p 3306:3306 --name mysql --restart=always --privileged=true \
-v /root/mysql/log:/var/log/mysql \
-v /root/mysql/data:/var/lib/mysql \
-v /root/mysql/conf:/etc/mysql \
-v /etc/localtime:/etc/localtime:ro \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

2)命令解析

-p 3306:3306:指定宿主机端口与容器端口映射关系
--name mysql:创建的容器名称
--restart=always:总是跟随docker启动
--privileged=true:获取宿主机root权限
-v /root/mysql/log:/var/log/mysql:映射日志目录,宿主机:容器
-v /root/mysql/data:/var/lib/mysql:映射数据目录,宿主机:容器
-v /root/mysql/conf:/etc/mysql :映射配置目录,宿主机:容器
-v /etc/localtime:/etc/localtime:ro :让容器的时钟与宿主机时钟同步,避免时区的问题,ro是read only的意思,就是只读。
-e MYSQL_ROOT_PASSWORD=123456:指定mysql环境变量,root用户的密码为123456
-d mysql:latest:后台运行mysql容器,版本是latest。
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

6 解决启动报错

  1. 查看容器状态
# 查看所有的docker容器,查看曾经运行过的容器
#docker ps -a

# 查看正在运行的容器
docker ps
  • 1
  • 2
  • 3
  • 4
  • 5

这个时候如果显示的是up状态,那就是启动成功了。如果是restarting,说明是有问题的。我们可以查看日志

在这里插入图片描述
2)查看日志

docker logs -f mysql
  • 1

3)解决错误,解决Container is restarting, wait until the container is running

在/root/mysql/conf 创建 my.cnf

# 在/root/mysql/conf 创建 my.cnf
[client]

default-character-set=utf8mb4

[mysql]

default-character-set=utf8mb4

[mysqld]

# 设置东八区时区
default-time_zone = '+8:00'

# 设置密码验证规则,default_authentication_plugin参数已被废弃

# 改为authentication_policy

#default_authentication_plugin=mysql_native_password
authentication_policy=mysql_native_password

# 限制导入和导出的数据目录
# 为空,不限制导入到处的数据目录;
# 指定目录,必须从该目录导入到处,且MySQL不会自动创建该目录;
# 为NULL,禁止导入与导出功能
#secure_file_priv=/var/lib/mysql
secure_file_priv=

init_connect='SET collation_connection = utf8mb4_0900_ai_ci'

init_connect='SET NAMES utf8mb4'

character-set-server=utf8mb4

collation-server=utf8mb4_0900_ai_ci

skip-character-set-client-handshake

skip-name-resolve
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39

7 进入容器,修改连接权限

1)docker进入mysql服务器

docker exec -it msyql /bin/bash
  • 1

2)修改mysql的访问权限

# 链接数据库
mysql -u root -p

# 提示输入密码,直接按回撤跳过

# 查看数据库
show databases;

# 使用mysql数据库
use mysql;

# 查看用户连接情况
select host, user, plugin,  authentication_string, password_expired from user;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

3)修改密码链接方式

# 允许远程链接修改密码
# ALTER USER root@'%' IDENTIFIED WITH mysql_native_password BY '123456';

# 修改密码链接方式 
ALTER USER root@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';

# 修改访问权限,远程可连接
update user set user.Host='%' where user.User='root';

# 刷新权限
FLUSH PRIVILEGES;

# 退出
exist
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

在这里插入图片描述

8 退出容器

先输入exit退出mysql,再输入exit退出容器。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/710276
推荐阅读
相关标签
  

闽ICP备14008679号