当前位置: 首页 > news >正文

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 = 4log-bin = OFF
#binlog保存天数 7天
expire_logs_days=7

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

五、启动mysql docker容器

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

docker-compose up -d 

六、验证安装

docker ps | grep mysql

http://www.dtcms.com/a/529352.html

相关文章:

  • 可信网站是否有规定必须做ps网页设计怎么做
  • AtCoder Beginner Contest 425 题解
  • 做瓷砖在什么网站上找素材好网站改标题关键词描述
  • GitHub等平台形成的开源文化正在重塑凯特
  • 惠州网站建设 鑫河南建设资格执业网站
  • Linux 下 Docker 与 ClickHouse 的安装配置及 MySQL 数据同步指南
  • 怎么建立一个个人网站企业如何注册网站
  • JAVA1025 类:继承:interface,接口继承必须实现接口方法;extends单继承 抽象类 属性 static
  • CVE-2025-50154漏洞复现与技术分析报告
  • 时间序列数据异常检测算法(6)——基于深度学习的算法
  • dw中网站建设的基本流程三亚网站建设费用
  • 深圳做网站企业手机大全
  • 基层建设 网站东莞免费网站建站模板
  • memmove函数在嵌入式开发中的应用
  • 祥云平台建站云服务器做网站视屏
  • Google 登录集成教程(Web + Expo 移动端)
  • stm32f103c8t6最小系统板(针对需要进行制作)--原理图绘制+pcb制作
  • 具身智能论文阅读:Robotic Control via Embodied Chain-of-Thought Reasoning
  • 张店学校网站建设哪家好中美俄最新军事新闻
  • 演出票务网站建设wordpress图片中文不显示解决
  • 自己用dw做网站能加声音吗网站建设兴田德润
  • 北京网站建设公司朝阳泰国公共建设网站
  • 虚拟机挂起,重启后主机连接不上虚拟机docker中的mysql?(docker网络状态假死)
  • 2018年网站开发语言wordpress免费图床插件
  • PyTorch 深度学习基础:Dataset 与 DataLoader 详解
  • 2.4寸SPI串口ILI9341芯片彩色LCD驱动
  • 绍兴企业做网站浙江建设信息港电工证查询
  • 【系统分析师】高分论文:论需求分析及其应用(ERP 财务管控项目)
  • 数据结构(9)
  • 怎么做点播网站唐山企业做网站