Heim >Datenbank >MySQL-Tutorial >MySQL数据库的实际配置技巧简介

MySQL数据库的实际配置技巧简介

WBOY
WBOYOriginal
2016-06-07 16:09:34982Durchsuche

以下的文章主要介绍的是MySQL数据库的实际配置技巧,我们大家都知道用root的相关用户启动的远程服务,其一直是个安全大忌,主要原因是如果相关的服务程序出现一些问题,远程攻击者极有可能获得主机的完全控制权。 MySQL(和PHP搭配之最佳组合)从3.23.15版 本

以下的文章主要介绍的是MySQL数据库的实际配置技巧,我们大家都知道用root的相关用户启动的远程服务,其一直是个安全大忌,主要原因是如果相关的服务程序出现一些问题,远程攻击者极有可能获得主机的完全控制权。

MySQL(和PHP搭配之最佳组合)从3.23.15版

本开始时作了小小的改动,默认安装后服务要用MySQL(和PHP搭配之最佳组合)用户来启动,不允许root用户启动。如果非要用root用户来启动,必须加上--user=root

的参数(./safe_MySQL(和PHP搭配之最佳组合)d --user=root &)。因为MySQL(和PHP搭配之最佳组合)中有LOAD DATA INFILE和SELECT ... INTO OUTFILE的SQL语句,如果是root用户启动了

MySQL(和PHP搭配之最佳组合)服务器,那么,MySQL数据库用户就拥有了root用户的写权限。不过MySQL(和PHP搭配之最佳组合)还是做了一些限制的,比如LOAD DATA INFILE只能读全局可读的文件

,SELECT ... INTO OUTFILE不能覆盖已经存在的文件。

本地的日志文件也不能忽视,包括shell的日志和MySQL(和PHP搭配之最佳组合)自己的日志。有些用户在本地登陆或备份MySQL数据库的时候为了图方便,有时会在命令行参

数里直接带了数据库的密码,如:

shell>/usr/local/MySQL(和PHP搭配之最佳组合)/bin/MySQL(和PHP搭配之最佳组合)dump -uroot -ptest test>test.sql

shell>/usr/local/MySQL(和PHP搭配之最佳组合)/bin/MySQL(和PHP搭配之最佳组合) -uroot -ptest

这些命令会被shell记录在历史文件里,比如bash会写入用户目录的.bash_history文件,如果这些文件不慎被读,那么数据库的密码就会泄漏

。用户登陆数据库后执行的SQL命令也会被MySQL(和PHP搭配之最佳组合)记录在用户目录的.MySQL(和PHP搭配之最佳组合)_history文件里。如果MySQL数据库用户用SQL语句修改了数据库密码,也会

因.MySQL(和PHP搭配之最佳组合)_history文件而泄漏。所以我们在shell登陆及备份的时候不要在-p后直接加密码,而是在提示后再输入MySQL数据库密码。

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

shell>rm .bash_history .MySQL(和PHP搭配之最佳组合)_history

shell>ln -s /dev/null .bash_history

shell>ln -s /dev/null .MySQL(和PHP搭配之最佳组合)_history

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

编程需要注意的一些问题

不管是用哪种程序语言写连接MySQL(和PHP搭配之最佳组合)MySQL数据库的程序,有一条准则是永远不要相信用户提交的数据!

对于数字字段,我们要使用查询语句:SELECT * FROM table WHERE ID='234',不要使用SELECT * FROM table WHERE ID=234这样的查询语句

。MySQL(和PHP搭配之最佳组合)会自动把字串转换为数字字符并且去除非数字字符。如果用户提交的数据经过了MySQL(和PHP搭配之最佳组合)_escape_string处理,这样我们就可以完全杜绝

各种编程语言该注意的问题:

1)所有Web程序:

a)尝试在Web表单输入单引号和双引号来测试可能出现的错误,并找出原因所在。

b)修改URL参数带的%22 ('"'), %23 ('#'), 和 %27 (''')。

c)对于数字字段的变量,我们的应用程序必须进行严格的检查,否则是非常危险的。

d)检查用户提交的数据是否超过字段的长度。

e)不要给自己程序连接MySQL数据库的用户过多的访问权限。

2)PHP:

a)检查用户提交的数据在查询之前是否经过addslashes处理,在PHP 4.0.3以后提供了基于MySQL(和PHP搭配之最佳组合) C API的函数MySQL(和PHP搭配之最佳组合)_escape_string()。

3)MySQL(和PHP搭配之最佳组合) C API:

a)检查查询字串是否用了MySQL(和PHP搭配之最佳组合)_escape_string() API调用。

4)MySQL(和PHP搭配之最佳组合)++:

a)检查查询字串是否用了escape和quote处理。

5)Perl DBI:

a)检查查询字串是否用了quote()方法。

6)Java JDBC:

a)检查查询字串是否用了PreparedStatement对象。

一些小窍门

1)如果不慎忘记了MySQL(和PHP搭配之最佳组合)的root密码,我们可以在启动MySQL(和PHP搭配之最佳组合)服务器时加上参数--skip-grant-tables来跳过授权表的验证 (./safe_MySQL(和PHP搭配之最佳组合)d

--skip-grant-tables &),这样我们就可以直接登陆MySQL(和PHP搭配之最佳组合)服务器,然后再修改root用户的口令,重启MySQL(和PHP搭配之最佳组合)就可以用新口令登陆了。

2)启动MySQL(和PHP搭配之最佳组合)服务器时加上--skip-show-database使一般数据库用户不能浏览其它MySQL数据库。

3)启动MySQL(和PHP搭配之最佳组合)服务器时加上--chroot=path参数,让MySQL(和PHP搭配之最佳组合)d守护进程运行在chroot环境中。这样SQL语句LOAD DATA INFILE和SELECT ... INTO

OUTFILE就限定在chroot_path下读写文件了。这里有一点要注意,MySQL(和PHP搭配之最佳组合)启动后会建立一个MySQL(和PHP搭配之最佳组合).sock文件,默认是在/tmp目录下。使用了

chroot后,MySQL(和PHP搭配之最佳组合)会在chroot_path/tmp去建立MySQL(和PHP搭配之最佳组合).sock文件,如果没有chroot_path/tmp目录或启动MySQL(和PHP搭配之最佳组合)的用户没有这个目录写权限就不能

建立MySQL(和PHP搭配之最佳组合).sock文件,MySQL(和PHP搭配之最佳组合)会启动失败。比如我们加了--chroot=/usr/local/MySQL(和PHP搭配之最佳组合)/启动参数,那么最好建立一个启动MySQL(和PHP搭配之最佳组合)的用户能写的

/usr/local/MySQL(和PHP搭配之最佳组合)/tmp目录,当然我们也可以用--socket=path来指定MySQL(和PHP搭配之最佳组合).sock文件的路径,但这个path一定要在chroot_path里面。

4)启动MySQL(和PHP搭配之最佳组合)服务器时加上--log-slow-queries[=file]参数,这样MySQL(和PHP搭配之最佳组合)d会把SQL命令执行时间超过long_query_time的写入file文件。如果没

有指定=file,MySQL(和PHP搭配之最佳组合)d默认会写到数据目录下的hostname-slow.log。如果只指定了filename,没有指定路径,那么MySQL(和PHP搭配之最佳组合)d也会把filename写到

数据目录下。我们通过这个日志文件可以找出执行时间超长的查询语句,然后尽可能的优化它减轻MySQL(和PHP搭配之最佳组合)服务器的负担。

5)如果我们只需本机使用MySQL(和PHP搭配之最佳组合)服务,那么我们还可以加上--skip-networking启动参数使MySQL(和PHP搭配之最佳组合)不监听任何TCP/IP连接,增加安全性

以上的相关内容就是对MySQL数据库配置技巧的介绍,望你能有所收获。


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn