网络安全

位置:IT落伍者 >> 网络安全 >> 浏览文章

MySQL数据库安全配置指南


发布日期:2022年05月01日
 
MySQL数据库安全配置指南

前言

MySQL是完全网络化的跨平台关系型数据库系统同时是具有客户机/服务器体系结构的分布式数据库管理系统它具有功能强使用简便管理方便运行速度快安全可靠性强等优点用户可利用许多语言编写访问MySQL数据库的程序特别是与PHP更是黄金组合运用十分广泛

由于MySQL是多平台的数据库它的默认配置要考虑各种情况下都能适用所以在我们自己的使用环境下应该进行进一步的安全加固作为一个MySQL的系统管理员我们有责任维护MySQL数据库系统的数据安全性和完整性

MySQL数据库的安全配置必须从两个方面入手系统内部安全和外部网络安全另外我们还将简单介绍编程时要注意的一些问题以及一些小窍门

系统内部安全

首先简单介绍一下MySQL数据库目录结构MySQL安装好运行了mysql_db_install脚本以后就会建立数据目录和初始化数据库如果我们用MySQL源码包安装而且安装目录是/usr/local/mysql那么数据目录一般会是/usr/local/mysql/var数据库系统由一系列数据库组成每个数据库包含一系列数据库表MySQL是用数据库名在数据目录建立建立一个数据库目录各数据库表分别以数据库表名作为文件名扩展名分别为MYDMYIfrm的三个文件放到数据库目录中

MySQL的授权表给数据库的访问提供了灵活的权限控制但是如果本地用户拥有对库文件的读权限的话攻击者只需把数据库目录打包拷走然后拷到自己本机的数据目录下就能访问窃取的数据库所以MySQL所在的主机的安全性是最首要的问题如果主机不安全被攻击者控制那么MySQL的安全性也无从谈起其次就是数据目录和数据文件的安全性也就是权限设置问题

从MySQL主站一些老的binary发行版来看xx版本中数据目录的属性是这样非常危险任何本地用户都可以读数据目录所以数据库文件很不安全xx版本中数据目录的属性是这种属性也有些危险本地的同组用户既能读也能写所以数据文件也不安全xx版本数据目录的属性是这样就比较好只有启动数据库的用户可以读写数据库文件保证了本地数据文件的安全

如果启动MySQL数据库的用户是mysql那么象如下的目录和文件的是安全的请注意数据目录及下面的属性

shell>ls l /usr/local/mysql

total

drwxrwxrx root root Feb : bin

drwxrwxrx root root Feb : include

drwxrwxrx root root Feb : info

drwxrwxrx root root Feb : lib

drwxrwxrx root root Feb : libexec

drwxrwxrx root root Feb : man

drwxrwxrx root root Feb : mysqltest

drwxrwxrx root root Feb : share

drwxrwxrx root root Feb : sqlbench

drwx mysql mysql Feb : var

shell>ls l /usr/local/mysql/var

total

drwx mysql mysql Feb : mysql

drwx mysql mysql Feb : test

shell>ls l /usr/local/mysql/var/mysql

total

rw mysql mysql Feb : columns_privMYD

rw mysql mysql Feb : columns_privMYI

rw mysql mysql Feb : columns_privfrm

rw mysql mysql Feb : dbMYD

rw mysql mysql Feb : dbMYI

rw mysql mysql Feb : dbfrm

rw mysql mysql Feb : funcMYD

rw mysql mysql Feb : funcMYI

rw mysql mysql Feb : funcfrm

rw mysql mysql Feb : hostMYD

rw mysql mysql Feb : hostMYI

rw mysql mysql Feb : hostfrm

rw mysql mysql Feb : tables_privMYD

rw mysql mysql Feb : tables_privMYI

rw mysql mysql Feb : tables_privfrm

rw mysql mysql Feb : userMYD

rw mysql mysql Feb : userMYI

rw mysql mysql Feb : userfrm

如果这些文件的属主及属性不是这样请用以下两个命令修正之

shell>chown R mysqlmysql /usr/local/mysql/var

shell>chmod R gorwx /usr/local/mysql/var

用root用户启动远程服务一直是安全大忌因为如果服务程序出现问题远程攻击者极有可能获得主机的完全控制权MySQL从版本开始时作了小小的改动默认安装后服务要用mysql用户来启动不允许root用户启动如果非要用root用户来启动必须加上user=root的参数(/safe_mysqld user=root &)因为MySQL中有LOAD DATA INFILE和SELECT INTO OUTFILE的SQL语句如果是root用户启动了MySQL服务器那么数据库用户就拥有了root用户的写权限不过MySQL还是做了一些限制的比如LOAD DATA INFILE只能读全局可读的文件SELECT INTO OUTFILE不能覆盖已经存在的文件

本地的日志文件也不能忽视包括shell的日志和MySQL自己的日志有些用户在本地登陆或备份数据库的时候为了图方便有时会在命令行参数里直接带了数据库的密码

shell>/usr/local/mysql/bin/mysqldump uroot ptest test>testsql

shell>/usr/local/mysql/bin/mysql uroot ptest

这些命令会被shell记录在历史文件里比如bash会写入用户目录的bash_history文件如果这些文件不慎被读那么数据库的密码就会洩漏用户登陆数据库后执行的SQL命令也会被MySQL记录在用户目录的mysql_history文件里如果数据库用户用SQL语句修改了数据库密码也会因mysql_history文件而洩漏所以我们在shell登陆及备份的时候不要在p后直接加密码而是在提示后再输入数据库密码

另外这两个文件我们也应该不让它记录我们的操作以防万一

shell>rm bash_history mysql_history

shell>ln s /dev/null bash_history

shell>ln s /dev/null mysql_history

上门这两条命令把这两个文件链接到/dev/null那么我们的操作就不会被记录到这两个文件里了

外部网络安全

MySQL数据库安装好以后Unix平台的user表是这样的

mysql> use mysql;

Database changed

mysql> select HostUserPasswordSelect_privGrant_priv from user;

educitycn/img_///jpg>

rows in set ( sec)

Windows平台的user表是这样的

mysql> use mysql;

Database changed

mysql> select HostUserPasswordSelect_privGrant_priv from user;

educitycn/img_///jpg>

rows in set ( sec)

我们先来看Unix平台的user表其中redhat只是我试验机的机器名所以实际上Unix平台的MySQL默认只允许本机才能连接数据库但是缺省root用户口令是空所以当务之急是给root用户加上口令给数据库用户加口令有三种方法

)在shell提示符下用mysqladmin命令来改root用户口令:

shell>mysqladmin uroot password test

这样MySQL数据库root用户的口令就被改成test了(test只是举例我们实际使用的口令一定不能使用这种易猜的弱口令)

)用set password修改口令

mysql> set password for root@localhost=password(test);

这时root用户的口令就被改成test了

)直接修改user表的root用户口令

mysql> use mysql;

mysql> update user set password=password(test) where user=root;

mysql> flush privileges;

这样MySQL数据库root用户的口令也被改成test了其中最后一句命令flush privileges的意思是强制刷新内存授权表否则用的还是缓沖中的口令这时非法用户还可以用root用户及空口令登陆直到重启MySQL服务器

我们还看到user为空的匿名用户虽然它在Unix平台下没什么权限但为了安全起见我们应该删除它

mysql> delete from user where user=;

Windows版本MySQL的user表有很大不同我们看到Host字段除了localhost还有是%这里%的意思是允许任意的主机连接MySQL服务器这是非常不安全的给攻击者造成可乘之机我们必须删除Host字段为%的记录

mysql>de

上一篇:数据安全之MySQL安全的二十三条军规

下一篇:酒店.宾馆的网络视频监控系统设计方案