Chinaunix首页 | 论坛 | 博客
  • 博客访问: 14168
  • 博文数量: 3
  • 博客积分: 105
  • 博客等级: 民兵
  • 技术积分: 71
  • 用 户 组: 普通用户
  • 注册时间: 2013-01-09 10:02
文章分类
文章存档

2013年(3)

我的朋友

分类: Mysql/postgreSQL

2013-01-11 09:31:28

  我们应该怎么样防止我们的数据库被黑客入侵呢?以下讲解黑客入侵我们网站的三个点:

  其一:

  不要把file权限给所有的用户。有这权限的任何用户能在拥有mysqld守护进程权限的文件系统那里写一个文件!为了使这更安全一些,用SELECT ... INTO OUTFILE生成的所有文件对每个人是可读的,并且你不能覆盖已经存在的文件。file权限也可以被用来读取任何作为运行服务器的Unix用户可存取的文件。这可能被滥用,例如,通过使用LOAD DATA装载"/etc/passwd"进一个数据库表,然后它能用SELECT被读入。

  如果你不信任你的DNS,你应该在授权表中使用IP数字而不是主机名。原则上讲,--secure选项对mysqld应该使主机名更安全。在任何情况下,你应该非常小心地使用包含通配符的主机名

  其二:

  不要作为Unix的root用户运行MySQL守护进程。mysqld能以任何用户运行,你也可以创造一个新的Unix用户mysql使一切更安全。如果你作为其它Unix用户运行mysqld,你不需要改变在user表中的root用户名,因为MySQL用户名与Unix 用户名没关系。你可以作为其它Unix用户编辑mysql.server启动脚本mysqld。通常这用su命令完成。对于更多的细节,见18.8 怎样作为一个一般用户运行MySQL。

  如果你把一个Unix root用户口令放在mysql.server脚本中,确保这个脚本只能对root是可读的。

  检查那个运行mysqld的Unix用户是唯一的在数据库目录下有读/写权限的用户。

  其三:

  不要把process权限给所有用户。mysqladmin processlist的输出显示出当前执行的查询正文,如果另外的用户发出一个UPDATE user SET password=PASSWORD( ot_secure)查询,被允许执行那个命令的任何用户可能看得到。mysqld为有process权限的用户保留一个额外的连接, 以便一个MySQL root用户能登录并检查,即使所有的正常连接在使用。

  (广州北大青鸟[url][/url]提供:java软件培训、网络策划、网站开发等培训)

阅读(541) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~