docker mysql模式sql-mode不生效

场景:

使用docker 搭建lnmp环境,mysql构建如下

yaml 复制代码
services:
  db:
    image: mysql:5.7
    container_name: mysql-5.7
    #表示支持外部访问
    command: --default-authentication-plugin=mysql_native_password
    restart: always
    volumes:
        - ./data/db_data:/var/lib/mysql
        - ./config/custom-my.cnf:/etc/mysql/conf.d/custom-my.cnf

    #映射到宿主机的端口,测试使用,测试完毕,请注释
    ports:
        - 13306:3306
        
    env_file:
      - .env

    networks:
        - lnmp
    environment:
        MYSQL_ROOT_HOST: "%"
        MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD}

custom-my.cnf内容如下:

mysqld

sql_mode = NO_ENGINE_SUBSTITUTION

但是将项目跑起来后,使用SQL语句:SHOW VARIABLES LIKE 'sql_mode'; 结果为:

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

并没有生效

原因:

MySQL 对配置文件权限有严格要求。如果配置文件权限过高(如 777),MySQL 可能会出于安全考虑忽略该文件

解决过程:

首先验证:

  1. 进入容器
powershell 复制代码
docker exec -it mysql-5.7 bash
  1. 检查文件加载顺序,看custom-my.cnf是否在加载文件列表里
powershell 复制代码
mysqld --help --verbose | grep -A 1 "Default options"

可以看到警告:全局可写配置文件"/etc/mysql/conf.d/custom-my.cnf"被忽略

powershell 复制代码
ls -l /etc/mysql/conf.d/custom-my.cnf

修改文件权限:

powershell 复制代码
chmod 644 ./config/custom-my.cnf

或者直接在构建文件增加命令,命令优先级最高

相关推荐
xiaolyuh1232 小时前
MySQL MVCC(多版本并发控制)实现机制深度解析
数据库·mysql
小魏每天都学习2 小时前
【sql-网络拓扑-子网划分-控制流图】
数据库·sql·mysql
June bug2 小时前
【高频SQL基础版】查询
数据库·sql·面试·跳槽
KubeSphere 云原生2 小时前
云原生周刊:对 Docker 镜像的更改持久保存
docker·云原生·容器
Linux蓝魔2 小时前
mysql-redis-kafka-es-ngnix安装调试
linux·服务器·mysql·kafka·es
weixin_449290012 小时前
EverMemOS Docker 运行环境搭建指南
运维·docker·容器
weixin_462446232 小时前
在 Linux / macOS 下使用 Docker 快速部署 PaddlePaddle + 运行 PaddleOCR 表格 PDF 解析示例
linux·macos·docker·paddleocr
春日见2 小时前
C++单例模式 (Singleton Pattern)
java·运维·开发语言·驱动开发·算法·docker·单例模式
A懿轩A2 小时前
【2026 最新】MySQL 与 DataGrip 详细下载安装教程带图展示(Windows版)
数据库·mysql·datagrip