一、拉取镜像
docker pull mysql
可以通过指令查询docker中已经安装的镜像
docker images
如图MySQL镜像已经拉取成功
拉取镜像之前可以先查询MySQL的版本
docker search mysql
二、运行镜像并创建容器
docker run -p 3306:3306 --name mysql --restart=always --privileged=true
-v /docker/mysql/log:/var/log/mysql
-v /docker/mysql/data:/var/lib/mysql
-v /etc/localtime:/etc/localtime:ro
-v /docker/mysql/conf:/etc/mysql/conf.d
-e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest
相关命令含义
-p 3306:3306:指定宿主机端口与容器端口映射关系
–name mysql:创建的容器名称
–restart=always:总是跟随docker启动
–privileged=true:获取宿主机root权限
-v :映射日志、数据等
-e :root用户的密码为123456
-d mysql:latest:后台运行mysql容器,版本是latest,使用docker pull mysql 默认版本是 latest ,若下载的是指定版本,-d 指令写好对应版本就好
安装完成后可以查询docker中的所有容器
1、docker ps -a ##查询docker中所有容器
2、docker ps ##查询docker中运行的容器
此时MySQL对应的状态为up即为成功
如果创建失败可以将容器的删除重新创建
docker stop mysql ##一定要先停止容器,否则容器删除失败
docker rm mysql
三、修改MySQL配置
创建配置文件
cd /docker/mysql/conf/
vim my.cnf
添加如下,这里是参考的大佬博文
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
配置完成以后,重启容器
docker restart mysql
四、进入MySQL容器
docker exec -it mysql /bin/bash
mysql -h localhost -u root -p ##登录MySQL 之后输入密码就好
可以查看数据库,设置密码,准备连接数据库
修改密码认证方式
ALTER USER root@'%' IDENTIFIED WITH mysql_native_password BY '123456';
ALTER USER root@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';
FLUSH PRIVILEGES; ##刷新权限
退出数据库和容器的指令:exit
五、DBeaver连接数据库
遇到的问题
拉取镜像失败
error parsing HTTP 408 response body: invalid character '<' looking for beginning of value: "<html>< body><h1>408 Request Time-out</h1>\nYour browser didn't send a complete request in time.\n</body></h tml>\n"
修改如下
主要记录一下过程,参考了很多大佬的博客,如果有哪里不对请指正
dig @114.114.114.114 registry-1.docker.io ##查找可用ip
vim /etc/hosts ##补充可用ip