0

0

mysql权限设置对开发环境和生产环境有区别吗_mysql环境安全设计

P粉602998670

P粉602998670

发布时间:2026-03-03 10:23:02

|

303人浏览过

|

来源于php中文网

原创

生产环境mysql必须遵循最小权限原则,禁用root连接、grant option和@'%'通配符,启用ip白名单、强密码策略与账号级连接限制;开发环境应隔离dev_*库并单独授权。

mysql权限设置对开发环境和生产环境有区别吗_mysql环境安全设计

开发环境用 root 权限连 MySQL 很常见,但绝不该在生产环境这么做

生产环境的 MySQL 账号必须遵循最小权限原则:只给业务实际需要的库、表、操作类型。开发环境虽然宽松些,但若共用同一套权限模型(比如用 CREATE USER + GRANT 脚本统一初始化),反而容易把开发误操作带到线上。真实事故里,不少“删库跑路”起点就是开发账号被提权或密码泄露后拥有 DROP DATABASE 权限。

实操建议:

  • 生产环境禁止任何账号拥有 GRANT OPTION,避免权限二次扩散
  • 开发环境可单独建 dev_* 前缀数据库,对应账号只 GRANT ALL PRIVILEGES ON dev_%.* TO 'dev_user'@'%',不碰正式库名
  • CI/CD 流水线中执行 SQL 的账号(如 Flyway 或 Liquibase)应独立于应用连接账号,且仅赋予 SELECT, INSERT, UPDATE, DELETE, CREATE, ALTER, INDEX,去掉 DROPCREATE VIEW

MySQL 8.0 的角色(ROLE)机制对环境隔离很实用

MySQL 5.7 及以前只能靠账号粒度授权,而 8.0+ 支持 CREATE ROLE + GRANT ... TO role_name,再把角色赋给用户。这对区分环境特别友好——比如建一个 app_prod_reader 角色,只含 SELECT 权限,再把该角色赋予所有生产只读服务账号;开发环境则用 app_dev_full 角色,包含 TRUNCATEEVENT 权限(方便清测试数据和调度任务)。

注意点:

  • 角色默认不自动激活,需显式执行 SET ROLE app_prod_reader 或在账号创建时设 DEFAULT ROLE
  • SHOW GRANTS FOR CURRENT_USER 不显示角色继承的权限,得用 SHOW GRANTS FOR CURRENT_USER USING app_prod_reader 查看实际生效权限
  • 角色不能跨实例复用,备份恢复后需重新 CREATE ROLE 并授权

连接来源 IP 白名单在生产环境必须启用,开发环境可适度放宽

生产环境的 MySQL 用户必须绑定明确的客户端网段,比如 'app_service'@'10.20.30.%',而不是通配符 'app_service'@'%'。哪怕内网环境,也防内部横向渗透。开发环境可接受 'dev_user'@'192.168.%' 这类较宽泛范围,但不应开放到公网或 0.0.0.0/0

云网OA
云网OA

采用JSP开发的办公自动化产品、基于B/S结构,运行环境:JDK v1.5、Tomcat v5.5、MySQL v4.1,三者均为以上版本其他相关内容:可视化流程设计: 流程支持串签、会签和分支流程,可以设置流程节点的修改、删除权限,并可指定流程中各个用户在表单中可以填写的域。智能表单所见即所得设计: 智能设计,自动在数据库中生成表格,方便优化程序 公共交流: 集论坛、博客、聊天室于一体文件柜:C

下载

常见疏漏:

  • 忘记清理测试账号的 @'%' 记录,导致上线后暴露攻击面
  • 容器化部署时,应用 Pod IP 动态变化,误用 @'%' 替代合理的 Service CIDR 段
  • 云数据库(如阿里云 RDS)的白名单是实例级配置,和 MySQL 内部账号的 host 是两层控制,两者都要设

密码策略和超时设置在生产环境要更严格

开发环境可以关掉 validate_password 插件图省事,但生产环境必须开启,并设 validate_password.length = 12validate_password.mixed_case_count = 1 等。另外,生产账号应设 PASSWORD EXPIRE INTERVAL 90 DAY,并搭配 FAILED_LOGIN_ATTEMPTS = 5 + PASSWORD_LOCK_TIME = 1 防暴力破解。

容易被忽略的细节:

  • max_connectionswait_timeout 是全局变量,但账号级的 MAX_CONNECTIONS_PER_HOUR 才能限制单个应用异常建连风暴
  • 使用 ALTER USER ... PASSWORD EXPIRE 后,首次登录会强制改密,但某些 ORM(如旧版 Django)不支持交互式改密流程,需提前在应用层兼容
  • MySQL 8.0 默认认证插件是 caching_sha2_password,老客户端(如 MySQL 5.7 客户端或部分 JDBC 驱动)需显式指定 useSSL=false&serverTimezone=UTC&allowPublicKeyRetrieval=true,否则连不上

权限设计真正难的不是语法,而是每次加一条 GRANT 前,得想清楚这个权限在故障时会不会放大影响、在泄露时会不会变成突破口。很多团队卡在“不知道该收多紧”,其实就从禁掉所有 @'%'、删光 GRANT OPTION、给每个服务配独立账号这三件事开始,已经挡住 80% 的基础风险。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1090

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

380

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1988

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

379

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1519

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

438

2024.04.29

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

2

2026.03.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.4万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 842人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号