docker 安装mysql
  seOBTolnBkGK 2023年11月02日 45 0

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了

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月08日 0

暂无评论

推荐阅读
  xaeiTka4h8LY   2024年05月31日   34   0   0 MySQL索引
  xaeiTka4h8LY   2024年05月31日   46   0   0 MySQLSQL
  xaeiTka4h8LY   2024年05月31日   30   0   0 字段MySQL
  xaeiTka4h8LY   2024年05月31日   40   0   0 MySQL数据库
  xaeiTka4h8LY   2024年05月31日   33   0   0 Dockerredis
  xaeiTka4h8LY   2024年05月17日   46   0   0 MySQLgithub
  xaeiTka4h8LY   2024年05月17日   38   0   0 MySQL数据库
seOBTolnBkGK