Centos Docker安装MySQL

一、拉取镜像

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

在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值