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

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

相关推荐
xuhe220 分钟前
[全流程详细教程]Docker部署ClawBot, 使用GLM4.7, 接入TG Bot实现私人助理. 解决Docker Openclaw Permission Denied问题
linux·docker·ai·github·tldr
洛豳枭薰36 分钟前
Innodb一次更新动作
mysql
l1t1 小时前
DeepSeek总结的PostgreSQL的GPT推理SQL移植到DuckDB的性能优化方法
sql·gpt·postgresql
星火s漫天1 小时前
第一篇: 使用Docker部署flask项目(Flask + DB 容器化)
数据库·docker·flask
xcLeigh1 小时前
Python 项目实战:用 Flask 实现 MySQL 数据库增删改查 API
数据库·python·mysql·flask·教程·python3
Fleshy数模2 小时前
MySQL 表创建全攻略:Navicat 图形化与 Xshell 命令行双模式实践
linux·mysql
Nandeska2 小时前
15、基于MySQL的组复制
数据库·mysql
AllData公司负责人3 小时前
AllData数据中台-数据同步平台【Seatunnel-Web】整库同步MySQL同步Doris能力演示
大数据·数据库·mysql·开源
MonkeyKing_sunyuhua3 小时前
docker compose up -d --build 完全使用新代码打包的方法
docker·容器·eureka
山岚的运维笔记3 小时前
SQL Server笔记 -- 第20章:TRY/CATCH
java·数据库·笔记·sql·microsoft·sqlserver