MySQL安全加固方法分享

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 数据库作为数据存储的载体,在程序开发中承担着至关重要的作用。近些年,随着各种安全事故的发生,数据安全性逐渐得到重视。等保评测或各类系统安全评测中也都有增加数据库安全相关要求,本篇文章将以 MySQL 为例,分享几点数据库安全加固方法。

1.数据安全重要性


数据安全性是指保护数据免受未经许可而故意或偶然的传送、泄露、破坏、修改,是标志程序和数据等信息的安全程度的重要指标。即保护数据不被破坏或泄露,不准非法修改,防止不合法的访问。


从理论上看,数据安全是信息系统建设的基石,数据是信息系统保护的首要目标。数据失去保护,信息系统也就失去了应有的意义。数据因为其价值的巨大和变现的便捷性,已成为黑客直接攻击的首要目标。近期,也发生过很多数据库系统中勒索病毒或被挖矿的案例。


数据安全有三个特性,分别是保密性、完整性、可用性:


  • 保密性:指对数据进行加密,只有授权者方可使用,并保证数据在流通环节不被窃取。包括网络传输保密和数据存储保密。
  • 完整性:指数据未经授权不得进行修改,确保数据在存储和传输过程中不被篡改、破坏、盗用、丢失。
  • 可用性:指经授权的合法用户必须得到系统和网络提供的正常服务。不可因为保护数据泄露而拒合法使用者于千里之外。


国家对于数据安全也很重视,2021 年 6 月 10 日,第十三届全国人民代表大会常务委员会第二十九次会议通过《中华人民共和国数据安全法》,自 2021 年 9 月 1 日起施行。自此之后,数据安全问题也做到了有法可依。


2.安全加固方法


那么我们应该怎么来做数据库安全加固呢?从数据安全的三个特性出发,或许可以找到新的思路,即要保证数据的保密性、完整性、可用性。一切对这三个特性有利的方法都可作为安全加固的方法。


笔者认为,安全是多个环节层层防护、共同配合的结果。数据安全加固并不只是数据库单一层面的问题,还需考虑操作系统、底层存储、程序端等多个层面。下面笔者将从这几个层面来分享几点数据库安全加固的方法,当然,笔者并不是安全相关专业人事,几点建议仅供参考。


操作系统层面(主机层):


  • 做好系统用户身份鉴别,不使用弱密码并定期更换。
  • 启用登录失败处理功能,限制 ip 重复登录。
  • 做好访问控制,制定安全策略,控制用户对资源的访问。
  • 配置防火墙策略,做好安全审计并保留审计日志记录。


存储层:


  • 有存储冗余策略。
  • 选择合适的磁盘阵列技术。
  • 定期检查存储,避免磁盘坏道。


数据库层:


  • 以独立的系统用户运行 mysql 服务。
  • 及时发现新的安全风险,打补丁或升级版本。
  • 配置数据库账号密码策略,不使用弱密码。
  • 数据库账号权限尽可能小,做好权限分离。
  • 禁止数据库外网访问,限制数据库账号 ip 登录。
  • 竭力完善数据库高可用架构,最好能做到多活。
  • 有完整的周期性备份策略,备份文件可在异地保留一份。
  • 增加数据库审计,对数据库流量或日志审计,设定告警通知机制。


程序层:


  • 敏感数据进行加密存储和传输。
  • 做好代码安全检测,防止恶意传参及 SQL 注入。
  • 应用系统不使用常见的管理员账号及密码。


总结:


人类已进入大数据时代,数据的重要性无需赘言,特别是金融、政府、医疗等系统。本篇文章从几个层面出发,分享了几点数据库安全加固建议,希望大家能够对数据安全性有些基本的认识,数据安全要重视起来了。


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
8天前
|
关系型数据库 MySQL 数据库连接
关于MySQL-ODBC的zip包安装方法
关于MySQL-ODBC的zip包安装方法
|
8天前
|
关系型数据库 MySQL
解决MySQL无法插入中文的方法
解决MySQL无法插入中文的方法
31 0
|
8天前
|
设计模式 NoSQL Java
常用的设计模式以及操作Redis、MySQL数据库、各种MQ、数据类型转换的方法
常用的设计模式以及操作Redis、MySQL数据库、各种MQ、数据类型转换的方法
|
8天前
|
SQL 关系型数据库 MySQL
【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性
【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性
116 1
|
8天前
|
SQL 关系型数据库 MySQL
MYSQL分页limit速度太慢优化方法
MYSQL分页limit速度太慢优化方法
34 0
|
8天前
|
关系型数据库 MySQL 测试技术
mysql中删除数据的几种方法
在MySQL数据库中,删除数据是一个常见的操作,它允许从表中移除不再需要的数据。在执行删除操作时,需要谨慎,以免误删重要数据。
65 3
|
7天前
|
SQL 关系型数据库 MySQL
MYSQL根据查询结果删除sql 去除重复id 新增对比前一条与后一条数据 去重3种方法​ 窗口函数
MYSQL根据查询结果删除sql 去除重复id 新增对比前一条与后一条数据 去重3种方法​ 窗口函数
|
8天前
|
关系型数据库 MySQL Linux
linux CentOS 7.4下 mysql5.7.20 密码改简单的方法
linux CentOS 7.4下 mysql5.7.20 密码改简单的方法
26 0
|
6天前
|
Prometheus Cloud Native 关系型数据库
实时计算 Flink版产品使用合集之binlog被清理掉的问题,并且binlog有备份,有什么方法来恢复到RDS
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
22 2
|
8天前
|
存储 关系型数据库 MySQL
Mysql大数据批量插入方法
Mysql大数据批量插入方法
26 0