|
数据库安全防护几点介绍
+ \, j# p' }9 o; \2 Z% _7 u6 c
5 m( A8 R5 A- `/ F7 I0 ]+ K5 @2 R企业最有价值的资产通常是其数据库中的客户或产品信息。因此,在这些企业中,数据库管理的一个重要部分就是保护这些数据免受外部攻击,及修复软/硬件故障。$ x# N+ A, P+ u/ I" \$ d, X
# L8 H, _- j/ ~+ o( j
% F' h/ g( I) {! h) E8 q1 g6 d
5 d4 O5 W1 |9 f) \3 i/ U在大多数情况下,软硬件故障通过数据备份机制来处理。多数数据库都自带有内置的工具自动完成整个过程,所以这方面的工作相对轻松,也不会出错。但麻烦却来自另一面:阻止外来黑客入侵窃取或破坏数据库中的信息。不幸的是,一般没有自动工具解决这一问题;而且,这需要管理员手工设置障碍来阻止黑客,确保公司数据的安全。3 G& k0 y! ^' U5 t
9 s% J2 A2 ~& }4 j* O
9 ], |6 z/ I$ ?1 E, b( f' ]. z+ ?$ h- U* i2 H) g5 ?9 \
不对数据库进行保护的常见原因是由于这一工作“麻烦”而“复杂”。这确实是事实,但如果你应用MySQL,就可以使用一些方便的功能来显著减少面临的风险。下面列出了以下几个功能:" v0 U* N/ h2 `+ d8 o
7 }0 H0 V" w; N0 J! S. ^' j9 |" e' f
, W* Y9 V( E# B# P3 E2 q. U# i: a! d X0 U0 M# }
删除授权表中的通配符6 |& v# Y5 r) v/ S4 O
, e5 g0 h! V# |
- G8 {6 U+ m9 R8 C
, F5 j0 A5 v8 J KMySQL访问控制系统通过一系列所谓的授权表运行,从而对数据库、表格或栏目级别的用户访问权利进行定义。但这些表格允许管理员为一名用户设定一揽子许可,或一组应用通配符的表格。这样做会有潜在的危险,因为黑客可能会利用一个受限的账户来访问系统的其他部分。由于这一原因,在设置用户特权时要谨慎,始终保证用户只能访问他们所需的内容。在给个别用户设定超级特权时要尤其小心,因为这种级别允许普通用户修改服务器的基本配置,并访问整个数据库。
$ g0 a! U. g4 ^0 e7 N( H: b6 d0 \% C3 X: U- B
: p9 }( e; W3 G1 x, w
, j H! w2 R6 v k, ~
建议:对每个用户账户应用显示特权命令,以审查授权表,了解应用通配符许可是否恰当。( K V8 Z1 u5 i
& R6 x( B) Y! |* O6 j g& O. V0 K5 R! y! `
5 p$ P/ W) q3 j7 d2 i1 ]/ {; o1 I6 {要求使用安全密码
* i/ v7 A- l9 b5 Q% Q3 g( @( h" j5 o# T0 Z( s
7 `* Z4 t$ j; ~0 K; J* d9 h& U6 w" O8 u2 t( S
用户账号的安全与用来保护它们的密码密切相关。因此,在安装MySQL时第一件事就应该设置MySQL根账号的密码(默认为空)。修复这一漏洞后,接下来就应要求每个用户账号使用一个密码,且不要使用生日、用户名或字典中的单词这些容易识别的启发式密码。
) o: P* m. I# b, W8 s
V. U3 b' i; G& q! D9 y" f9 r! {# e" P1 C; a
1 `: i4 L6 d. P ]( m5 i
建议:应用MySQL-安全-授权选项避免使用旧的,不大安全的MySQL密码格式。& k1 m, z8 d0 h4 b& C
3 @/ g7 m# {; P, k0 `! l- p5 Q
$ \9 ]6 V$ f3 F- E) j, P& m3 p1 l3 n; W( T7 H! \
检查配置文件许可
3 f! H; T/ q& X+ r8 V* W+ P6 o/ h |3 m# M/ s' T3 N
- H: c% k5 g! i; }, ~
. @4 Z" [! @" F6 X/ M( V" A一般来说,要使服务器连接更为快速方便,单个用户和服务器管理员必须把他们的用户账号密码存储在单用户MySQL选项文件中。但是,这种密码是以纯文本形式存储在文件中的,很容易就可以查阅。因此,必须保证这样的单用户配置文件不被系统中的其他用户查阅,且将它存储在非公共的位置。理想情况下,你希望单用户配置文件保存在用户的根目录,许可为0600。* v# T3 D s% ^2 q2 [: w8 \# @! b. |; y
$ M3 _7 g+ f* j1 @+ B1 d5 _
# O4 P c2 z% ?) C$ F0 }+ z1 Y! H: R+ R/ j1 R! `
加密客户与服务器之间数据传送' d, p1 Q% d8 f- G5 V" j- o
8 x6 l% g0 n! [* D! q) L& B8 G" F" r' X# ~* I8 n( x6 u
1 z* ?7 d) Q' O: v6 w. v
MySQL(及其它)客户与服务器构架的一个重要问题就是通过网络传送数据时的安全问题。如果客户与服务器间的交互以纯文本形式发生,黑客就可能“嗅出”被传送的数据包,从而获得机密信息。你可以通过激活MySQL配置中的SSL,或应用一个OpenSSH这样的安全应用来为传送的数据建立一个安全的加密“通道”,以关闭这一漏洞。以这种形式加密客户与服务器连接可使未授权用户极难查阅往来的数据。
0 T9 W6 q$ Q% }) J9 r. `0 @1 |5 n, t5 ? N: o2 Y" J& B
8 ~/ [- ~' r. P( d% ], e
/ j3 S9 k+ g/ p/ Q2 A- ~. l( c
禁止远程访问- m0 p0 a! i7 |/ H
$ u j2 k0 h4 P& _4 \% J
: }, |( b1 e, j: ^- ^8 m/ M- Q& H6 ^( d! u+ I8 _: i9 b4 z2 m
如果用户不需要远程访问服务器,你可以迫使所有MySQL连接通过UNIX插槽文件来完成,从而大大减少网络受攻击的风险。这一过程可通过跳过网络选项启动服务器来完成。这样可以阻止TCP/IP网络连接到MySQL上,保证没有用户可以远程连接系统。, h% |! C l, v) ]2 G; }
1 h4 |' U, o# }, u) _9 W8 W8 Z; A, p
4 v4 L( ~) q/ }; Q8 w. T
2 i3 y' M* o# a% D建议:可以在MySQL服务器配置中添加捆绑地址127.0.0.1指令来增强这一功能,迫使MySQL捆绑当地机器的IP地址来保证只有同一系统中的用户可以连接到MySQL。
4 y% e: H2 S a* B7 p/ _! O$ ]7 h6 l# P
" ], o* k2 }1 @- x6 N
/ Q5 N; P1 W) y( s; t9 U* c
积极监控MySQL访问记录5 L* C( d- N# y! ~4 \
8 d2 Q' d; U. z: d- G6 ~
5 A) p4 z+ S. ]0 f
5 {/ v5 ^. k! r/ m5 mMySQL中带有很多不同的日志文件,它们记录客户连接,查询和服务器错误。其中,最重要的是一般查询日志,它用时间标签记录每名客户的连接和中断时间,并记录客户执行的每个查询。如果你怀疑发生了不寻常的行为,如网络入侵,那么监控这个日志以了解行为的来源是个好方法。2 Q6 H: b, U3 M o/ W! ]6 J8 q
# V7 @, _2 q" c' y
9 }7 ? o, s3 }$ z" \9 q, V" o
W4 w9 v, z5 v5 o, N* s保护你的MySQL数据库是一个日常工作。因此,即使完成了上述步骤,也还需要你利用更多的时间去了解更多的安全建议,积极监控并更新你的系统安全。
4 q e6 d9 R, r; q0 T) u# j# J( i* F
1 ?9 k0 `4 ^. F W( Y' |- b& D: }: {6 E v7 g( e
( ^ T% v6 n2 A: T9 b
原文连接:http://www.szw86.com/thread-8236-1-1.html |
|