知识大全 MySQL数据库安全配置指南

Posted 数据库

篇首语:宁给好汉拉马,不给懒汉作爷。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 MySQL数据库安全配置指南相关的知识,希望对你有一定的参考价值。

MySQL数据库安全配置指南  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

   前言    MySQL是完全网络化的跨平台关系型数据库系统 同时是具有客户机/服务器体系结构的分布式数据库管理系统 它具有功能强 使用简便 管理方便 运行速度快 安全可靠性强等优点 用户可利用许多语言编写访问MySQL数据库的程序 特别是与PHP更是黄金组合 运用十分广泛     由于MySQL是多平台的数据库 它的默认配置要考虑各种情况下都能适用 所以在我们自己的使用环境下应该进行进一步的安全加固 作为一个MySQL的系统管理员 我们有责任维护MySQL数据库系统的数据安全性和完整性     MySQL数据库的安全配置必须从两个方面入手 系统内部安全和外部网络安全 另外我们还将简单介绍编程时要注意的一些问题以及一些小窍门      系统内部安全    首先简单介绍一下MySQL数据库目录结构 MySQL安装好 运行了mysql_db_install脚本以后就会建立数据目录和初始化数据库 如果我们用MySQL源码包安装 而且安装目录是/usr/local/mysql 那么数据目录一般会是/usr/local/mysql/var 数据库系统由一系列数据库组成 每个数据库包含一系列数据库表 MySQL是用数据库名在数据目录建立建立一个数据库目录 各数据库表分别以数据库表名作为文件名 扩展名分别为MYD MYI frm的三个文件放到数据库目录中     MySQL的授权表给数据库的访问提供了灵活的权限控制 但是如果本地用户拥有对库文件的读权限的话 攻击者只需把数据库目录打包拷走 然后拷到自己本机的数据目录下就能访问窃取的数据库 所以MySQL所在的主机的安全性是最首要的问题 如果主机不安全 被攻击者控制 那么MySQL的安全性也无从谈起 其次就是数据目录和数据文件的安全性 也就是权限设置问题     从MySQL主站一些老的binary发行版来看 xx版本中数据目录的属性是 这样非常危险 任何本地用户都可以读数据目录 所以数据库文件很不安全 xx版本中数据目录的属性是 这种属性也有些危险 本地的同组用户既能读也能写 所以数据文件也不安全 xx版本数据目录的属性是 这样就比较好 只有启动数据库的用户可以读写数据库文件 保证了本地数据文件的安全     如果启动MySQL数据库的用户是mysql 那么象如下的目录和文件的是安全的 请注意数据目录及下面的属性     shell>ls l /usr/local/mysql    total     drwxrwxr x root root Feb : bin    drwxrwxr x root root Feb : include    drwxrwxr x root root Feb : info    drwxrwxr x root root Feb : lib    drwxrwxr x root root Feb : libexec    drwxrwxr x root root Feb : man    drwxrwxr x root root Feb : mysql test    drwxrwxr x root root Feb : share    drwxrwxr x root root Feb : sql bench    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_priv MYD     rw mysql mysql Feb : columns_priv MYI     rw mysql mysql Feb : columns_priv frm     rw mysql mysql Feb : db MYD     rw mysql mysql Feb : db MYI     rw mysql mysql Feb : db frm     rw mysql mysql Feb : func MYD     rw mysql mysql Feb : func MYI     rw mysql mysql Feb : func frm     rw mysql mysql Feb : host MYD     rw mysql mysql Feb : host MYI     rw mysql mysql Feb : host frm     rw mysql mysql Feb : tables_priv MYD     rw mysql mysql Feb : tables_priv MYI     rw mysql mysql Feb : tables_priv frm     rw mysql mysql Feb : user MYD     rw mysql mysql Feb : user MYI     rw mysql mysql Feb : user frm    如果这些文件的属主及属性不是这样 请用以下两个命令修正之     shell>chown R mysql mysql /usr/local/mysql/var    shell>chmod R go rwx /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>test sql    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 Host User Password Select_priv Grant_priv from user;   educity cn/img_ / / / jpg>  图      rows in set ( sec)    Windows平台的user表是这样的     mysql> use mysql;    Database changed    mysql> select Host User Password Select_priv Grant_priv from user;   educity cn/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 cha138/Article/program/MySQL/201311/29418

相关参考

知识大全 jboss配置 mysql数据库连接池

jboss配置 mysql数据库连接池实例 :配置:   JDK    JBoss  &n

知识大全 Tomcat下配置MySQL数据库连接池

Tomcat下配置MySQL数据库连接池  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  在$CA

知识大全 MYSQL的master/slave数据同步配置

MYSQL的master/slave数据同步配置  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  

知识大全 Tomcat5配置Mysql JDBC数据库连接池

Tomcat5配置MysqlJDBC数据库连接池  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  

知识大全 浅析Tomcat5配置Mysql JDBC数据库连接池

浅析Tomcat5配置MysqlJDBC数据库连接池  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

知识大全 tomcat连接池的配置与使用数据库mysql

    关于tomcat连接池的配置我在自己开始的时候碰到过许多的问题至少失败过六次今天终于成功了对于这个问题的产生与由来我也给大伙说说  

知识大全 保障网站数据库的安全MySQL数据库备份

保障网站数据库的安全MySQL数据库备份  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  在数据库

知识大全 MySQL数据库中的安全解决方案

MySQL数据库中的安全解决方案  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  随着网络的普及基

知识大全 数据安全之MySQL安全的二十三条军规

数据安全之MySQL安全的二十三条军规  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  使用MyS

知识大全 linux系统下mysql中文乱码解决

  改默认编码  /etc/initd/mysqlstart(stop)为启动和停止服务器  /etc/mysql/主要配置文件所在位置f  /var/lib/mysql/放置的是数据库表文件夹这里的