docker-compose方式快速安装MySQL

一、检查是否已安装docker与docker-compose

必须要安装docker跟docker-compose

有输出则表示有docker环境,如没有安装 自行安装后再看后续步骤

二、创建MySQL目录结构

创建三个文件夹,一个文件

三、编写 docker-compose.yml

复制代码
version: '3'
services:
  mysql: # 服务名称 建议与容器名称一致
    image: mysql:8.4 # 当前数据库的版本,这个镜像下载下来,必须要,或者
    container_name: mysql # 容器名称
    restart: always # 容器随docker启动自启
    volumes:
      - ./log:/var/log/mysql # 映射日志目录,宿主机:容器
      - ./data:/var/lib/mysql # 映射数据目录,宿主机:容器
      - ./conf.d:/etc/mysql/conf.d # 映射配置目录,宿主机:容器
      - /etc/localtime:/etc/localtime:ro # 让容器的时钟与宿主机时钟同步,避免时间的问题,ro是read only的意思,就是只读。
    ports:
      - 3306:3306 # 指定宿主机端口与容器端口映射关系,宿主机:容器,宿主机ip根据使用情况进行修改
    environment:
      - MYSQL_ROOT_PASSWORD=mima@9527 # root用户密码

四、在 conf.d 文件夹里创建 my.cnf 文件,并填入以下内容

复制代码
###### [client]配置模块 ######
[client]
default-character-set=utf8mb4
socket=/var/lib/mysql/mysql.sock

###### [mysql]配置模块 ######
[mysql]
# 设置MySQL客户端默认字符集
default-character-set=utf8mb4
socket=/var/lib/mysql/mysql.sock

###### [mysqld]配置模块 ######
[mysqld]
port=3306
user=mysql
# 设置sql模式 sql_mode模式引起的分组查询出现*this is incompatible with sql_mode=only_full_group_by,这里最好剔除ONLY_FULL_GROUP_BY
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
#server-id = 1

# MySQL8 的密码认证插件 如果不设置低版本navicat无法连接
default_authentication_plugin=mysql_native_password

# 禁用符号链接以防止各种安全风险
symbolic-links=0

# 允许最大连接数
max_connections=1000

# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8mb4

# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB

# 表名存储在磁盘是小写的,但是比较的时候是不区分大小写
#lower_case_table_names=1
max_allowed_packet=16M 

# 限制Innodb能打开的表的数据,如果库里的表特别多的情况,请增加这个。
# InnoDB使用一个缓冲池来保存索引和原始数据,一般设置物理内存的60% ~ 70%;这里你设置越大,你在存取表里面数据时所需要的磁盘I/O越少
innodb_buffer_pool_size = 10240M
innodb_write_io_threads = 4
# CPU多核处理能力设置,根据读,写比例进行调整
innodb_read_io_threads = 4

log-bin = OFF
#binlog保存天数 7天
expire_logs_days=7

该配置内容囊括了一些基本的MySQL调优配置,可根据服务器情况自行调整

五、启动mysql docker容器

cd到 docker-compose.yml同级目录下 执行

复制代码
docker-compose up -d 

六、验证安装

复制代码
docker ps | grep mysql
相关推荐
呉師傅7 分钟前
【使用技巧】Adobe Photoshop 2024调整缩放与布局125%后出现点菜单项漂移问题的简单处理
运维·服务器·windows·adobe·电脑·photoshop
heartbeat..10 分钟前
JVM 性能调优流程实战:从开发规范到生产应急排查
java·运维·jvm·性能优化·设计规范
小章UPUP23 分钟前
Kubernetes (K8s) 与 Podman 的比较
容器·kubernetes·podman
忆~遂愿27 分钟前
CANN metadef 核心解析:计算图原型定义、算子元数据抽象与异构系统互操作机制
docker·容器
小Tomkk36 分钟前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
赌博羊37 分钟前
ImportError: /lib/x86_64-linux-gnu/libc.so.6: version `GLIBC_2.32‘ not found
linux·运维·gnu
消失的旧时光-19431 小时前
Linux 入门核心命令清单(工程版)
linux·运维·服务器
艾莉丝努力练剑1 小时前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法
小天源1 小时前
Cacti在Debian/Ubuntu中安装及其使用
运维·ubuntu·debian·cacti
说实话起个名字真难啊1 小时前
用docker来安装openclaw
docker·ai·容器