MySQL简单安全的十个设置方法

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

Mysql的默认安装参数是mysql性能最好的配置方法,但会造成数据部安全,且服务器也面临被入侵的风险,也有可能会在短时间内,出现一些性能的问题


这边文章从不同的角度去配置mysql的参数,提高安全的方法,你不能去限制别人而已攻击你的mysql db server,但你可以让他攻击和破解浪费更多的时间

一:用户和密码设置


刚安装好的mysql是没有密码的,只要能登陆到server主机的都可以无限制的访问和操作mysql 数据库,所以设置密码,是管理mysql数据库的第一步


Mysqladmin -u root  password 密码


因为mysql中的root是超级用户,很多攻击者都是想要获取root的密码,根据这点可以更改root的用户名,降低风险


mysql> update user set user='biao' where user='root';


Query OK, 1 row affected (0.22 sec)


Rows matched: 1  Changed: 1  Warnings: 0


也就是说将root的用户名更改为biao,密码和host都是不变的,之后如果再使用root账户登录,就是会提示你被拒绝的


二:增加用户和权限的设置


如果需要给开发或者维护人员添加账号,对权限进行处理,能赋予只读的就赋予只读的权限,或者对特定数据库名给写的权限,以及对登录IP也可以进行限制


GRANT ALL ON *.* TO 'root'@'%'; 这样是对所有的主机都可以访问,只要root的密码是正确的


也可以是域名


GRANT ALL ON *.* TO 'root'@'aaa.bbb.com';会解析域名的主机,主机可以访问mysql db


也可以是网段


GRANT ALL ON *.* TO 'root'@192.168.1.%';表示192.168.1.1~254IP地址都可以访问mysql db


也可以通过linuxiptables 定义访问策略


三:删掉mysql的测试库


[root@test02 ~]# mysql -D  test


不需要验证即可登录到库


mysql> drop database test;


Query OK, 1 row affected (0.13 sec)


Test库不需要任何验证都可以登录,不安全,且是测试库,可以删掉


四:禁用LOCAL INFILE


禁用”LOAD DATA LOCAL INFILE”命令,这有助于防止非授权用户访问本地文件。在PHP应用程序中发现有新的SQL注入漏洞时,这样做尤其重要。


此外,在某些情况下,LOCAL INFILE命令可被用于访问操作系统上的其它文件(如/etc/passwd),应使用下现的命令:


mysql> LOAD DATA LOCAL INFILE '/etc/passwd' INTO TABLE table1


更简单的方法是:


mysql> SELECT load_file("/etc/passwd")


为禁用LOCAL INFILE命令,应当在MySQL配置文件的[mysqld]部分增加下面的参数:


set-variable=local-infile=0


五:移除匿名账户和不用的账户


有些mysql中,数据库的用户名为空,对应host主机的任何人都可以连接到数据库,使用命令检查:


mysql> select user,host from mysql.user where user='';


+------+-----------+


| user | host      |


+------+-----------+


|      | localhost |


|      | test02    |


+------+-----------+


2 rows in set (0.00 sec)


删除这些存在安全隐患的用户名


mysql> delete from mysql.user where user='';


Query OK, 2 rows affected (0.00 sec)


如果需要给相应的主机赋予权限,使用grant语句就可以


六:系统权限的管理


在安装和配置mysql的时候,mysql的主要的配置目录/data/mysql 数据存储目录,/usr/local/mysqlmysql的程序安装目录,一般都是将二者的属主和属组 赋予给 mysql用户和mysql组,再设置权限的时候:chmod -R 774 即可,注意:mysql用户要设置密码


七:mysql的命令历史


在用户访问的mysql控制台中,所有的历史命令都被记录在~/.mysql_history,如果攻击者访问这个文件,就可以获取到mysql的结构信息


Cat  ~/.mysql_history


为了移除和禁用这个文件,可以将日志发送到/dev/null


$export mysql_histfile=/dev/null


八:安全补丁


经常关注mysql官网的相关信息,进行补丁的查看和修复


九:mysql启用日志


用来记录mysql实例对某种条件作出响应时写入的文件,如错误日志文件、二进制日志文件、慢查询日志文件、查询日志文件


错误文件:通过 show variables like log_error' 查看日志的放置路径


Mysql中经常用到的是二进制日志和redo log,二者简单的区别在于:


二进制日志文件会记录所有与mysql相关的日志记录,包括innodbmyisambdb等其他存储引擎日志,而innodbredo log只存储有关的本身事务日志。


二进制日志文件,不管日志的记录格式是statement或者ROW或者mixed,其记录的都是一个事务的具体操作。而innodbredo log记录的关于每个页的更改的物理情况


日志的写入时间:二进制日志写入是在事务提交前进行记录的,而事务进行的过程中,不断有重做日志条目被写入到redo log


启用二进制日志:


log-bin=mysql-bin 一般是放在了mysqldatadir


十:mysql的数据备份


Mysql的备份方式有:mysqldump,直接copy文件,以及在线备份工具:xtrabackup


Mysqldump和直接copy文件对 myisam的存储引擎比较方便,


借用工具:xtrabackup 可以在线备份innodb的数据文件


简单的描述下二者的操作原理


Mysqldump 采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,建议加上--opt参数,快速的导入和导出



对于InnoDBXtraBackup基于InnoDBcrash-recovery功能进行备份。



crash-recovery是这样的:InnoDB维护了一个redo log,又称为 transaction log,也叫事务日志,它包含了InnoDB数据的所有改动情况。InnoDB启动的时候先去检查datafiletransaction log,然后应用所有已提交的事务并回滚所有未提交的事务。


XtraBackup在备份的时候并不锁定表,而是一页一页地复制InnoDB的数据,与此同时,XtraBackup还有另外一个线程监视着transactions log,一旦log发生变化,就把变化过的log pages复制走(因为transactions log文件大小有限,写满之后,就会从头再开始写,新数据可能会覆盖到旧的数据,所以一旦变化就要立刻复制走)。在全部数据文件复制完成之后,停止复制logfile






      本文转自天真花语  51CTO博客,原文链接:http://blog.51cto.com/caibird/1338905,如需转载请自行联系原作者



相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
存储 关系型数据库 MySQL
环比、环比增长率、同比、同比增长率 ,占比,Mysql 8.0 实例(最简单的方法之一)(sample database classicmodels _No.2 )
环比、环比增长率、同比、同比增长率 ,占比,Mysql 8.0 实例(最简单的方法之一)(sample database classicmodels _No.2 )
113 1
|
2月前
|
存储 关系型数据库 MySQL
提高MySQL查询性能的方法有很多
提高MySQL查询性能的方法有很多
166 7
|
28天前
|
关系型数据库 MySQL
Mysql 中日期比较大小的方法有哪些?
在 MySQL 中,可以通过多种方法比较日期的大小,包括使用比较运算符、NOW() 函数、DATEDIFF 函数和 DATE 函数。这些方法可以帮助你筛选出特定日期范围内的记录,确保日期格式一致以避免错误。
|
1月前
|
关系型数据库 MySQL Linux
Linux系统如何设置自启动服务在MySQL数据库启动后执行?
【10月更文挑战第25天】Linux系统如何设置自启动服务在MySQL数据库启动后执行?
74 3
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
87 2
|
2月前
|
关系型数据库 MySQL 数据库连接
MySQL 表整行数据唯一性设置
MySQL 表整行数据唯一性设置
55 2
|
2月前
|
关系型数据库 MySQL 数据库
使用Docker部署的MySQL数据库如何设置忽略表名大小写?
【10月更文挑战第1天】使用Docker部署的MySQL数据库如何设置忽略表名大小写?
195 1
|
2月前
|
druid 关系型数据库 MySQL
开发指南048-mysql设置
如果链接的是mysql设置,需要做如下配置
|
2月前
|
SQL 关系型数据库 MySQL
MySQL设置表自增步长
MySQL设置表自增步长
98 0
|
2月前
|
存储 关系型数据库 MySQL
MySQL 字符字段长度设置详解:语法、注意事项和示例
MySQL 字符字段长度设置详解:语法、注意事项和示例
221 0