Mysql数据库的安全性问题释疑

  数据库系统的安全性包括很多方面。由于很多情况下,数据库服务器容许客户机从网络上连接,因此客户机连接的安全对MySQL数据库安全有很重要的影响。

  不在客户机的命令行上提供密码

  使用mysql、mysqladmin等客户机用一个用户身份与MySQL服务器连接时,需要为连接提供密码。

  1、可以在命令行上提供密码

  shell>mysql –u root –pmypass

  注意,-p选项与密码之间不可有空格,否则会提示你输入密码,并报错。

  你也可以使用长格式

  shell>mysql –user=root –password=mypass

  现在你可以考察这样做的后果:

  在Unix上,$ps –aux | grep mysql

  在win9x上,你可以按住Ctrl+Alt+Del键,NT上你可以打开任务管理器。

  你发现了什么,你发现密码清清楚楚的显示在你的面前。所以,你无论何时也不要这么做。

  所以你需要让客户机提示你的密码:

  shell>mysql –u root –p

  你也可以使用选项文件提供密码,但是注意为了安全,不能在选项文件中存储密码。你可以只提供password选项,让客户机提示你输入密码。

  使用SSH加密客户机连接

  这是一个关于怎样用SSH 得到一个安全的连接远程MySQL服务器的注意事项(David Carlson)。

  在你的windows机器上安装SSH客户 - 我使用了一个来自http://www.doc.ic.ac.uk/~ci2/ssh/的免费SSH客户。其他有用的链接:

  http://www.npaci.edu/Security/npaci_security_software.html

  http://www.npaci.edu/Security/samples/ssh32_windows/index.html.

  启动SSH。设置主机名字 = 你的MySql服务器名或IP地址,设置userid=你的用户名登录到你的服务器。

  点击“local forwords”。设定 local port: 3306, host: localhost, remote port: 3306

  保存一切,否则下次你将必须再做一遍。

  用SSH登录到你的服务器。

  启动一些ODBC应用程序(例如Access)。

  创造一个新文件并且用ODBC驱动程序链接到mySQL,就像你通常做的一样,除了对服务器用用户“localhost”。

  搞定。它对一个直接的因特网连接工作得很好。

  不要使用Unix的root用户运行MySQL守护进程

  不要作为Unix的root用户运行MySQL守护进程。mysqld能以任何用户运行,你也可以创造一个新的Unix用户mysql使一切更安全。如果你作为其它Unix用户运行mysqld,你不需要改变在user表中的root用户名,因为MySQL用户名与Unix 用户名没关系。

  你可以作为其它Unix用户编辑mysql.server启动脚本mysqld。或者使用选项文件。有关如何用非root用户启动MySQL服务器的细节,请见第二章。

  数据库目录的安全

  MySQL服务器提供了一个通过mysql数据库中的授权表,实现了一个十分灵活的权限系统,保证了从网络访问数据的安全性。但是,如果服务器主机上的其它用户拥有对服务器目录的直接访问权,那么你的服务器的数据仍旧是不安全的。

  一般你可能用一个非特权的Unix用户执行守护程序。检查那个运行mysqld的Unix用户是唯一的在数据库目录下有读/写权限的用户。

  可能的安全漏洞

  显然,你不会让服务器主机上的其它用户拥有对数据库目录文件的写访问权,但是,仅仅是读访问权也非常危险。

  由于象GRANT和SET PASSWORD这样的查询都被记录到日志中去了,常规和更新日志文件包含了有关密码的敏感查询文本。如果一个攻具有对这些日志的读访问权,那么他只要在日志文件中查找GRANT或PASSWORD这样的敏感单词,就很容易找到密码的明文。

  对于表文件的读访问也是很危险的,窃取文件并使MySQL以及以纯文本的形式显示表的内容是微不足道的事。可以按下列步骤进行:

  1、安装一个新的MySQL分发,可以是在另一台主机上,也可以就在当前的服务器主机上安装,使用与正式服务器不同的端口、套接字和数据文件。

  2、将窃取的表的相应文件拷贝到新服务数据库目录中的test目录下

  3、然后就可以启动作案服务器,可以随意访问所窃取表的内容。

  在Unix设置合适的数据库目录权限

  如果要消除这些安全漏洞,就要安排数据库目录及其中所有文件和目录的所有权,是的只有启动服务器的专用帐户才可以访问它们。操作步骤如下:

  1、切换到root用户

  $su

  2、设置数据库目录及其中所有文件目录的所有权为运行该服务器的帐号所有,在本书中一直将这个帐号假定为mysql,把所有的组设为root组

  %chown –R mysql:root DATADIR

  3、修改数据库目录及其中所有文件目录的权限为只有所有者可以读写

  %chmod –R go-rwx DATADIR

  在NT系统中设置合适的数据库目录权限

  在NT系统中的数据库目录的安全性可能比较简单:

  读者可能想到,把所有目录文件改为只有某个帐户administrator例如可读写。但是,这样会有一个问题,就是这能在 administrator帐户中用手动启动独立的服务器,如果让mysql系统服务自动启动的方法也不可行,解决方法是让数据库目录也可被 administrators组用户读写,这样MySQL服务器就可以用系统服务的方法自动启动了,也可以在任何帐户中用net start mysql启动。

  另外一个问题是,如果你在非administrators组用户中或者从网络都无法建立数据库连接,因为没有数据库目录的读的权利,如果要正常使用,还需要 写的权利。解决方法是让SYSTEM组用户能够队数据库目录读写。

  由于许可证和费用的原因,通常建议你在Linux服务器上使用MySQL,在Windows平台之用来测试或者数据录入工作。但是,如果你要在Windows上使用的话,可以注意本小节的一些内容。

  影响安全的mysqld选项

  下列mysqld选项影响安全:

  --secure

  由gethostbyname()系统调用返回的IP数字被检查,确保他们解析回到原来的主机名。这对某些外人通过模仿其它主机获得存取权限变得更难。这个选项也增加一些聪明的主机名检查。在MySQL3.21里,选择缺省是关掉的,因为它有时它花很长时间执行反向解析。MySQL 3.22缓存主机名并缺省地启用了这个选项。

  --skip-grant-tables

  这个选项导致服务器根本不使用权限系统。这给每个人以完全存取所有的数据库的权力!(通过执行mysqladmin reload,你能告诉一个正在运行的服务器再次开始使用授权表。)

  --skip-name-resolve

  主机名不被解析。所有在授权表的Host的列值必须是IP数字或localhost。

  --skip-networking

  在网络上不允许TCP/IP连接。所有到mysqld的连接必须经由Unix套接字进行。这个选项对使用MIT-pthreads的系统是不合适的,因为MIT-pthreads包不支持Unix套接字。

时间: 2025-01-29 21:45:53

Mysql数据库的安全性问题释疑的相关文章

为你的MySQL数据库加铸23道安全门

使用mysql,安全问题不能不注意.以下是mysql提示的23个注意事项: 1.如果客户端和服务器端的连接需要跨越并通过不可信任的网络,那么就需要使用ssh隧道来加密该连接的通信. 2.用set password语句来修改用户的密码,三个步骤,先"mysql -u root"登陆数据库系统,然后"mysql> update mysql.user set password=password('newpwd')",最后执行"flush privilege

MySQL数据库分区管理 细节决定成败

在MySQL数据库中,表的不同部分在不同的位置被存储为单独的表.分区主要就是用来解决表在不同的位置存储的问题.在其他数据库中,也会存在这种情况.他们将这种类型的数据表称之为分区表.分区的管理,对于MySQL数据库来说至关重要.其直接跟数据库的性能与安全性息息相关.对于分区的管理,笔者只有两个字:细节. 细节一:确定所使用的版本是否支持分区 在MySQL中,并不是所有的数据库版本都支持分区管理.为此数据库管理员首先要做的就是,确认自己所采用的版本是否支持这个功能.如果支持的话,则可以在后续设计与维

MySQL数据库的23个特别注意的安全事项

使用MySQL数据库,安全问题很不容忽视,要想安全使用MySQL数据库,就要认真理解下面讲解的关于使用MySQL数据库要特别注意的23个安全事项: 1.如果客户端和服务器端的连接需要跨越并通过不可信任的网络,那么就需要使用SSH隧道来加密该连接的通信. 2.用set password语句来修改用户的密码,三个步骤,先"mysql -u root"登陆数据库系统,然后"mysql> update mysql.user set password=password('newp

mysql数据库你需要特别注意的23个事项

使用MySQL,安全问题不能不注意.以下是MySQL提示的23个注意事项: 1.如果客户端和服务器端的连接需要跨越并通过不可信任的网络,那么就需要使用SSH隧道来加密该连接的通信. 2.用set password语句来修改用户的密码,三个步骤,先"mysql -u root"登陆数据库系统,然后"mysql> update mysql.user set password=password('newpwd')",最后执行"flush privilege

23个使用MySQL数据库的注意事项

使用MySQL,安全问题不能不注意.以下是MySQL提示的23个注意事项: 1.如果客户端和服务器端的连接需要跨越并通过不可信任的网络,那么就需要使用SSH隧道来加密该连接的通信. 2.用set password语句来修改用户的密码,三个步骤,先"mysql -u root"登陆数据库系统,然后"mysql> update mysql.user set password=password('newpwd')",最后执行"flush privilege

mysql数据库优化(未完....待续....)

mysql|数据|数据库|优化 ########################################文件名:mysqloptimize,php                           ##主题: mysql数据库的优化                  ##作者: _Shakespeare(网络骑士)                    ##最后修改时间: 2002--09--20                      ##e-mail: shakespareshm

MySQL数据库学习笔记(一)

mysql|笔记|数据|数据库         我一直从事Informix和Oracle数据库开发,有一天发现网络上有一种小巧别致的数据库,被广泛使用,从MySQL的网站http://www.mysql.com/我下载了它的数据库软件,使用过后觉得真的挺好,这是我的一点学习笔记希望对各位初学者有点帮助. 1.       MySQL数据库介绍 MySQL 是瑞典的MySQL AB公司开发的一个可用于各种流行操作系统平台的关系数据库系统,它具有客户机/服务器体系结构的分布式数据库管理系统.MySQ

新的MySQL安装的安全性

mysql|安全|安全性     本章将讨论MySQL管理员为保持MySQL正常运行所需要完成的职责.这些职责包括确保服务器尽可能保持高性能地运行.设置用户账号以便客户机能够访问服务器.维护日志文件,以及执行数据库备份.为了得到更高的性能,管理员还可以运行多个服务器或修改服务器的操作参数.最后,由于MySQL正处于高速发展的状态,所以管理员必须能确定何对MySQL进行升级.其他重要的管理问题将在第12章"安全性"和第13章"数据库维护和修复"介绍.    有几个对M

安全网络访问mysql数据库服务器

mysql|安全|访问|服务器|数据|数据库|网络     MySQL安全性系统是灵活的.它允许以许多不同的方法设置用户访问权限.通常,可通过GRANT 和REVOKE 语句来进行,这些语句对控制客户机访问的授权表进行修改.但是,您拥有的可能是不支持这些语句的旧版本MySQL(这些语句在MySQL3.22.11以前的版本中没有使用),或者可能发觉用户的权限好像不是按希望地在工作.对于这样的情况,了解MySQL授权表的结构以及服务器怎样使用它们来决定访问许可权是有帮助的.您了解到这样一个程度,就可