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

docker-compose 部署 MySQL 8

目录

  • 前言
  • MySQL 配置文件(my.cnf)
  • docker-compose.yml
  • 安装
  • 卸载

前言

Windows/Linux 系统通过 docker-compose 部署 MySQL8.0。

MySQL 配置文件(my.cnf)

# 服务端参数配置
[mysqld]
user=mysql                     # MySQL启动用户
default-storage-engine=INNODB  # 创建新表时将使用的默认存储引擎
character-set-server=utf8mb4   # 设置mysql服务端默认字符集
collation-server = utf8mb4_general_ci # 数据库字符集对应一些排序等规则,注意要和character-set-server对应pid-file        = /var/lib/mysql/mysqld.pid  # pid文件所在目录
socket          = /var/lib/mysql/mysqld.sock # 用于本地连接的socket套接字
datadir         = /var/lib/mysql             # 数据文件存放的目录
bind-address   = 127.0.0.1                   # MySQL绑定IP
expire_logs_days=7                            # 定义清除过期日志的时间(这里设置为7天)# 设置client连接mysql时的字符集,防止乱码
init_connect='SET NAMES utf8mb4'# 是否对sql语句大小写敏感,1表示不敏感
lower_case_table_names = 1# 执行sql的模式,规定了sql的安全等级, 暂时屏蔽,my.cnf文件中配置报错
#sql_mode = STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION# 事务隔离级别,默认为可重复读,mysql默认可重复读级别(此级别下可能参数很多间隙锁,影响性能)
transaction_isolation = READ-COMMITTED# TIMESTAMP如果没有显示声明NOT NULL,允许NULL值
explicit_defaults_for_timestamp = true#它控制着mysqld进程能使用的最大文件描述(FD)符数量。
#需要注意的是这个变量的值并不一定是你设定的值,mysqld会在系统允许的情况下尽量获取更多的FD数量
open_files_limit    = 65535# 允许最大连接数
max_connections=200#最大错误连接数
max_connect_errors = 600[client]
default-character-set=utf8mb4  # 设置mysql客户端默认字符集

docker-compose.yml

version: '3' # 指定了 Docker Compose 文件的格式版本,版本3是常用版本之一
services:mysql:image: mysql:8.0 # https://hub.docker.com/_/mysql/container_name: mysqlrestart: unless-stopped #  指定了容器的重启策略,除了手动停止容器,其他情况都自动重启容器environment:- TZ=Asia/Shanghai # 指定了容器的环境变量,设置容器的时区为上海时区- LANG=en_US.UTF-8 # 指定了容器的环境变量,设置容器的编码为UTF-8- MYSQL_ROOT_HOST='%'- MYSQL_ROOT_PASSWORD=123456ports:- 3306:3306logging:driver: "json-file"options:max-size: "10m"max-file: "3"volumes:- ./conf/my.cnf:/etc/my.cnf # 指定了容器的数据卷映射关系,将宿主机的nginx.conf文件映射到容器的/etc/nginx/nginx.conf文件- ./data:/var/lib/mysql # 指定了容器的数据卷映射关系,将宿主机的html目录映射到容器的/usr/share/nginx/html目录- ./logs:/var/log/mysql # 指定了容器的数据卷映射关系,将宿主机的logs目录映射到容器的/var/log/nginx目录

安装

docker-compose -f docker-compose.yml -p mysql up -d


使用 Navicat 测试连接
在这里插入图片描述

卸载

docker-compose -f docker-compose.yml -p mysql down
http://www.lryc.cn/news/231066.html

相关文章:

  • Java设计模式-结构型模式-适配器模式
  • CCF编程能力等级认证GESP—C++4级—样题1
  • Git用pull命令后再直接push有问题
  • C语言不可不敲系列:跳水比赛排名问题
  • Python与ArcGIS系列(二)获取地图文档
  • Ansible自动化部署工具-role模式安装filebeat实际案例分析
  • B2B企业如何打造独立站:从策略到实施的全面指南
  • JAVA 中集合取交集
  • Android13 Launcher3 定制
  • 其他word转化为PDF的方式
  • 【Axure】axure rp 导入元件库和使用,主流元件库下载使用
  • ISP 处理流程
  • 【计算思维】少儿编程蓝桥杯青少组计算思维题考试真题及解析C
  • 百望云斩获“新华信用金兰杯”ESG优秀案例 全面赋能企业绿色数字化
  • bclinux aarch64 ceph 14.2.10 对象存储 http网关 CEPH OBJECT GATEWAY Civetweb
  • 2023年亚太杯数学建模思路 - 复盘:人力资源安排的最优化模型
  • 【广州华锐互动】VR居家防火逃生模拟演练增强训练的真实性
  • PaddleClas学习1——使用PPLCNet模型对车辆属性进行识别(python)
  • CSS 实现新拟态(Neumorphism) UI 风格
  • js 深度学习(六)
  • 【机器学习基础】机器学习的模型评估(评估方法及性能度量原理及主要公式)
  • React hooks(一):useState
  • springboot集成swagger3+解决页面无法访问问题
  • mapreduce-maven--30.串联所有单词的字串
  • Hive使用max case when over partition by 实现单个窗口取两个窗口的值(单个开窗函数,实际取两个窗口)
  • 2023年【北京市安全员-B证】试题及解析及北京市安全员-B证证考试
  • 二维码智慧门牌管理系统升级解决方案:流量监控引领服务卓越
  • Linux内核面试题(1)
  • wpr -start generalprofile -start pool -filemode 这句命令具体是什么意思
  • C/CPP基础练习题多维数组,矩阵转置,杨辉三角详解