docker安装MySQL5.7

下载镜像

docker pull mysql:5.7

创建实例

docker run -p 3307:3306 --name mysql \
			-v /usr/local/localVolumes/mysql/log:/var/log/mysql \
			-v /usr/local/localVolumes/mysql/data:/var/lib/mysql \
			-v /usr/local/localVolumes/mysql/conf:/etc/mysql \
			-e MYSQL_ROOT_PASSWORD=root \
			-d mysql:5.7

参数说明:

  • -p 3307:3306 将容器的3306端口映射到主机的3307端口
  • -v /usr/local/localVolumes/mysql/log:/var/log/mysql 将日志文件夹挂载到主机
    -v /usr/local/localVolumes/mysql/data:/var/lib/mysql 将数据文件夹挂载到主机
    -v /usr/local/localVolumes/mysql/conf:/etc/mysql 将配置文件夹挂载到主机
  • -e MYSQL_ROOT_PASSWORD=root 初始化root用户密码
  • -d mysql:5.7 指定启动容器的镜像

目录挂载以后,就可以在主机上直接查看或者修改容器内部对应的文件,方便快捷

修改MySQL配置文件

可以直接修改主机上的文件,会自动同步到容器中,因为我们刚才做了目录挂载

vi /usr/local/localVolumes/mysql/conf/my.cnf
[client]
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

注意:解决MySQL连接慢的问题

在配置文件中加入如下,并重启MySQL

[mysqld]
skip-name-resolve

解释:

skip-name-resolve:跳过域名解析

至此,利用docker start mysql就可以启动一个mysql容器了,然后测试连接。理论上应该可以正常访问,可实际上并非如此。

我用datagrip 2020.2连接,驱动版本5.1.47,本机Mac上装的Docker容器

报错如下:

[08S01] Communications link failure

The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.
java.net.ConnectException: Connection refused (Connection refused).

问题排查

第一想到的是可能账户密码不对,然后登入docker容器中直接访问mysql,发现是可以访问的,账号和密码是没问题的。

然后就百度,百度了下,说是时间不对,果然,发现docker中的主机时间和mysql的时间差了8个小时,看来应该是时区设置的不对,应该设置成东8区,即GMT+8

在这里插入图片描述

调整时区方法如下:

  1. 创建容器是添加**-e TZ=Asia/Shanghai**参数即可,如下
docker run -p 3307:3306 --name mysql \
			-v /usr/local/localVolumes/mysql/log:/var/log/mysql \
			-v /usr/local/localVolumes/mysql/data:/var/lib/mysql \
			-v /usr/local/localVolumes/mysql/conf:/etc/mysql \
			-e MYSQL_ROOT_PASSWORD=root \
			-e TZ=Asia/Shanghai \
			-d mysql:5.7
  1. 直接修改MySQL配置文件即可,在[mysqld]下面添加如下配置即可

    default-time-zone='+08:00'
    

好,至此连接成功

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值