设为首页 收藏本站
查看: 559|回复: 0

[经验分享] Mysql数据库的安全性问题释疑

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-12-29 08:45:11 | 显示全部楼层 |阅读模式
 数据库的安全重要性相信大家都知道啦,小编就不在这里啰嗦了。但是,数据库系统的安全性包括很多方面呢。大多情况下,数据库服务器是容许客户机从网络上连接,因此客户机连接的安全对MySQL数据库安全是有很重要的影响。



  下面列举一些大家需要注意的点,供大家参考:



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



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



  可以在命令行上提供密码



  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客户   .



  启动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。或者使用选项文件。



  数据库目录的安全



  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套接字。



  给大家列举了那么多细节希望大家都能学以致用。同时,也希望大家重视数据库的安全。



  不要到了数据崩溃的时候才开始后悔。如果你是小白用户,对数据库还摸索不清也可以多和多备份交流哦。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-39461-1-1.html 上篇帖子: mysql安装后常见故障 下篇帖子: 利用mysql的sum和if做统计 数据库 安全性
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表