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了