docker 安装mysql

本文详细介绍了如何使用Docker安装MySQL 8.0版本,并配置相关参数以实现持久化存储和远程访问。包括镜像下载、目录挂载、配置文件编辑、容器启动及时间设置等步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

docker 安装mysql
1:docker下载镜像
#可下载指定版本

docker pull mysql:8.0

2:创建挂载目录

mkdir -p /data/mysql/conf
mkdir -p /data/mysql/data
mkdir -p /data/mysql/logs

3:创建my.cnf文件,放在 /data/mysql/conf 目录中,注意配置文件中的端口号

vi /data/mysql/conf/my.cnf
[client]
# 设置mysql客户端连接服务端时默认使用的端口
port = 3306
default-character-set = utf8mb4
 
[mysql]
# 设置mysql客户端默认字符集
default-character-set = utf8mb4
 
[mysqld]
# bind-address = 0.0.0.0
# port = 3306
 
max_connections=10000
 
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
 
# 设置时区和字符集
# default-time-zone='+8:00'
character-set-client-handshake=FALSE
init_connect='SET NAMES utf8mb4 COLLATE utf8mb4_unicode_ci'
 
gtid-mode=ON
enforce-gtid-consistency = ON

4:启动镜像

docker run  
--restart=always  
--name mysql8.0  
-v /data/mysql/cnf:/etc/mysql  
-v /data/mysql/data:/var/lib/mysql  
-v /data/mysql/log:/var/log  
-v /data/mysql/mysql-files:/var/lib/mysql-files 
-p 3308:3306  
-e MYSQL_ROOT_PASSWORD='root'   
-d mysql:8.0
--lower_case_table_names=1

–restart=unless-stopped,在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器
-p 3306:3306:映射容器服务的 3306 端口到宿主机的 3306 端口,外部主机可以直接通过 宿主机ip:3306 访问到 MySQL 的服务。
-v /mydata/mysql/log:/var/log/mysql:将日志文件夹挂载到主机
-v /mydata/mysql/data:/var/lib/mysql\:将mysql产生的数据挂载到主机
-v /mydata/mysql/conf:/etc/mysql\:将配置文件夹挂载到主机
-v /mydata/mysql/mysql-files:/var/lib/mysql-files \ 【mysql8.0需指定 /var/lib/mysql-files的外部目录】
-e 环境参数,MYSQL_ROOT_PASSWORD设置root用户的密码
-d 后台运行
–lower_case_table_names=1:忽略大小写【linux下mysql默认区分大小写,mysql8及以上版本需在创建mysql时设置,否则无效】

5: 解决时间显示问题

[root@tseng ~]# docker exec -it mysql8.0 bash
root@a498923c0bd3:/# date
Tue Aug  3 06:44:32 UTC 2021
root@a498923c0bd3:/# cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
root@a498923c0bd3:/# exit
[root@tseng /]# docker restart mysql8.0        -- 重启镜像
[root@tseng /]# docker exec -it mysql8.0 bash    
root@a498923c0bd3:/# date
Tue Aug  3 14:45:35 CST 2021

Navicat链接:
上述虽然安装好了MySQL,但是使用远程的Navicat连接时提示错误,不能正确连接mysql,此时需要修改按照下面说的步骤修改一下MySQL的密码模式以及主机等内容才可以。
1:进入容器内部

docker exec -it mysql8 /bin/bash

2:连接mysql

mysql -u root -p

3:使用mysql库

use mysql;

4:修改访问主机以及密码等,设置为所有主机可访问

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '新密码';

5:刷新

flush privileges;

然后就可以链接Navicat了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值