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

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

相关推荐
百结21417 小时前
Mysql数据库操作
数据库·mysql·oracle
ego.iblacat18 小时前
MySQL 服务基础
数据库·mysql
攒了一袋星辰20 小时前
高并发强一致性顺序号生成系统 -- SequenceGenerator
java·数据库·mysql
顶点多余21 小时前
使用C/C++语言链接Mysql详解
数据库·c++·mysql
小王不爱笑1321 天前
MyBatis 执行流程源码级深度解析:从 Mapper 接口到 SQL 执行的全链路逻辑
数据库·sql·mybatis
Seven971 天前
MySQL语句执行深度剖析:从连接到执行的全过程
mysql
洛阳泰山1 天前
MaxKB4j Docker Compose 部署指南
java·docker·llm·springboot·rag·maxkb4j
山峰哥1 天前
SQL优化实战:从索引策略到执行计划的极致突破
数据库·sql·性能优化·编辑器·深度优先
总要冲动一次1 天前
离线安装 percona-xtrabackup-24
linux·数据库·mysql·centos
buhuimaren_1 天前
MySQL数据库初体验
数据库·mysql