首页 数据库 mysql教程 MySQL数据库安全配置指南(一)[组图]_MySQL

MySQL数据库安全配置指南(一)[组图]_MySQL

Jun 01, 2016 pm 01:53 PM
可靠性 数据库安全

  1、前言

  MySQL是完全网络化的跨平台关系型数据库系统,同时是具有客户机/服务器体系结构的分布式数据库管理系统。它具有功能强、使用简便、管理方便、运行速度快、安全可靠性强等优点,用户可利用许多语言编写访问MySQL数据库的程序,特别是与PHP更是黄金组合,运用十分广泛。

  由于MySQL是多平台的数据库,它的默认配置要考虑各种情况下都能适用,所以在我们自己的使用环境下应该进行进一步的安全加固。作为一个MySQL的系统管理员,我们有责任维护MySQL数据库系统的数据安全性和完整性。

  MySQL数据库的安全配置必须从两个方面入手,系统内部安全和外部网络安全,另外我们还将简单介绍编程时要注意的一些问题以及一些小窍门。

  2、系统内部安全

  首先简单介绍一下MySQL数据库目录结构。MySQL安装好,运行了mysql_db_install脚本以后就会建立数据目录和初始化数据库。如果我们用MySQL源码包安装,而且安装目录是/usr/local/mysql,那么数据目录一般会是/usr/local/mysql/var。数据库系统由一系列数据库组成,每个数据库包含一系列数据库表。MySQL是用数据库名在数据目录建立建立一个数据库目录,各数据库表分别以数据库表名作为文件名,扩展名分别为MYD、MYI、frm的三个文件放到数据库目录中。

  MySQL的授权表给数据库的访问提供了灵活的权限控制,但是如果本地用户拥有对库文件的读权限的话,攻击者只需把数据库目录打包拷走,然后拷到自己本机的数据目录下就能访问窃取的数据库。所以MySQL所在的主机的安全性是最首要的问题,如果主机不安全,被攻击者控制,那么MySQL的安全性也无从谈起。其次就是数据目录和数据文件的安全性,也就是权限设置问题。

  从MySQL主站一些老的binary发行版来看,3.21.xx版本中数据目录的属性是775,这样非常危险,任何本地用户都可以读数据目录,所以数据库文件很不安全。3.22.xx版本中数据目录的属性是770,这种属性也有些危险,本地的同组用户既能读也能写,所以数据文件也不安全。3.23.xx版本数据目录的属性是700,这样就比较好,只有启动数据库的用户可以读写数据库文件,保证了本地数据文件的安全。

  如果启动MySQL数据库的用户是mysql,那么象如下的目录和文件的是安全的,请注意数据目录及下面的属性: 
shell>ls-l/usr/local/mysql
total40
drwxrwxr-x2rootroot4096Feb2720:07bin
drwxrwxr-x3rootroot4096Feb2720:07include
drwxrwxr-x2rootroot4096Feb2720:07info
drwxrwxr-x3rootroot4096Feb2720:07lib
drwxrwxr-x2rootroot4096Feb2720:07libexec
drwxrwxr-x3rootroot4096Feb2720:07man
drwxrwxr-x6rootroot4096Feb2720:07mysql-test
drwxrwxr-x3rootroot4096Feb2720:07share
drwxrwxr-x7rootroot4096Feb2720:07sql-bench
drwx------4mysqlmysql4096Feb2720:07var
shell>ls-l/usr/local/mysql/var
total8
drwx------2mysqlmysql4096Feb2720:08mysql
drwx------2mysqlmysql4096Feb2720:08test
shell>ls-l/usr/local/mysql/var/mysql
total104
-rw-------1mysqlmysql0Feb2720:08columns_priv.MYD
-rw-------1mysqlmysql1024Feb2720:08columns_priv.MYI
-rw-------1mysqlmysql8778Feb2720:08columns_priv.frm
-rw-------1mysqlmysql302Feb2720:08db.MYD
-rw-------1mysqlmysql3072Feb2720:08db.MYI
-rw-------1mysqlmysql8982Feb2720:08db.frm
-rw-------1mysqlmysql0Feb2720:08func.MYD
-rw-------1mysqlmysql1024Feb2720:08func.MYI
-rw-------1mysqlmysql8641Feb2720:08func.frm
-rw-------1mysqlmysql0Feb2720:08host.MYD
-rw-------1mysqlmysql1024Feb2720:08host.MYI
-rw-------1mysqlmysql8958Feb2720:08host.frm
-rw-------1mysqlmysql0Feb2720:08tables_priv.MYD
-rw-------1mysqlmysql1024Feb2720:08tables_priv.MYI
-rw-------1mysqlmysql8877Feb2720:08tables_priv.frm
-rw-------1mysqlmysql428Feb2720:08user.MYD
-rw-------1mysqlmysql2048Feb2720:08user.MYI
-rw-------1mysqlmysql9148Feb2720:08user.frm
如果这些文件的属主及属性不是这样,请用以下两个命令修正之:
shell>chown-Rmysql.mysql/usr/local/mysql/var
shell>chmod-Rgo-rwx/usr/local/mysql/var

  用root用户启动远程服务一直是安全大忌,因为如果服务程序出现问题,远程攻击者极有可能获得主机的完全控制权。MySQL从3.23.15版本开始时作了小小的改动,默认安装后服务要用mysql用户来启动,不允许root用户启动。如果非要用root用户来启动,必须加上--user=root的参数(./safe_mysqld --user=root &)。因为MySQL中有LOAD DATA INFILE和SELECT ... INTO OUTFILE的SQL语句,如果是root用户启动了MySQL服务器,那么,数据库用户就拥有了root用户的写权限。不过MySQL还是做了一些限制的,比如LOAD DATA INFILE只能读全局可读的文件,SELECT ... INTO OUTFILE不能覆盖已经存在的文件。

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Java ActiveMQ 的 20 个最佳实践 Java ActiveMQ 的 20 个最佳实践 Feb 20, 2024 pm 09:48 PM

1.选择合适的客户端传输协议ActiveMQ支持多种客户端传输协议,包括STOMP、AMQP和OpenWire。根据您的应用程序需求选择合适的协议,以优化性能和可靠性。2.配置消息持久性持久性消息即使在服务器重新启动后也能持久化,而非持久性消息则不会。对于关键消息,选择持久性以确保可靠传递。演示代码://设置消息持久性MessageProducerproducer=session.createProducer(destination);producer.setDeliveryMode(Deliv

C++嵌入式系统开发入门:打造高可靠性的嵌入式应用 C++嵌入式系统开发入门:打造高可靠性的嵌入式应用 Nov 27, 2023 am 11:06 AM

嵌入式系统是指在特定的硬件平台上运行的应用程序,通常用于控制、监控和处理各种设备和系统。C++作为一种功能强大的编程语言,在嵌入式系统开发中广泛应用。本文将介绍C++嵌入式系统开发的基本概念和技术,以及如何打造高可靠性的嵌入式应用。一、嵌入式系统开发概述嵌入式系统开发需要对硬件平台有一定的了解,因为嵌入式应用程序需要直接与硬件交互。除了硬件平台之外,嵌入式系

Java数据库连接如何解决安全问题? Java数据库连接如何解决安全问题? Apr 16, 2024 pm 03:12 PM

Java数据库连接安全解决方案:JDBC加密:使用SSL/TLS连接,保护数据传输安全。连接池:复用连接,限制资源消耗,防止过度使用。限制访问权限:只授予应用程序最低必要权限,防止数据泄露。防御SQL注入:使用参数化查询和验证输入,抵御恶意攻击。

如何防范SQL注入攻击? 如何防范SQL注入攻击? May 13, 2023 am 08:15 AM

随着互联网的普及和应用场景的不断拓展,我们在日常生活中使用数据库的次数越来越多。然而,数据库安全问题也越来越受到关注。其中,SQL注入攻击是一种常见且危险的攻击方式。本文将介绍SQL注入攻击的原理、危害以及如何防范SQL注入攻击。一、SQL注入攻击的原理SQL注入攻击一般指黑客通过构造特定的恶意输入,在应用程序中执行恶意SQL语句的行为。这些行为有时候会导致

防止SQL注入攻击:保护Java应用程序数据库的安全策略 防止SQL注入攻击:保护Java应用程序数据库的安全策略 Jun 30, 2023 pm 10:21 PM

数据库安全性:保护Java应用程序免受SQL注入攻击的策略摘要:随着互联网的发展,Java应用程序在我们的生活和工作中扮演着越来越重要的角色。然而,与此同时,数据库的安全性问题也日益凸显。SQL注入攻击是最常见且最具破坏性的数据库安全漏洞之一。本文将介绍一些策略和措施,以保护Java应用程序免受SQL注入攻击的威胁。第一部分:什么是SQL注入攻击?SQL注入

织梦CMS数据库文件删除注意事项 织梦CMS数据库文件删除注意事项 Mar 13, 2024 pm 09:27 PM

标题:织梦CMS数据库文件删除注意事项织梦CMS作为一款流行的网站建设工具,其数据库文件删除是网站维护中经常遇到的问题之一。不正确的数据库文件删除操作可能导致网站数据丢失或网站无法正常运行,因此,在进行数据库文件删除操作时,我们必须格外谨慎。下面将介绍织梦CMS数据库文件删除的注意事项,并提供一些具体代码示例,帮助大家正确进行数据库文件删除操作。注意事项:备

开发可靠的PHP命令行应用 开发可靠的PHP命令行应用 May 24, 2023 am 08:53 AM

随着互联网技术的不断进步和发展,越来越多的Web应用和服务被开发出来。而为了更加高效的管理这些应用和服务,越来越多的开发者开始采用PHP命令行应用来进行管理和操作。但是,开发可靠的PHP命令行应用却是一件非常困难的事情。在本文中,我们将探讨如何开发可靠的PHP命令行应用。1.选择合适的框架选择一个合适的框架是开发可靠的PHP命令行应用的第一步。在

MySQL在金融领域的应用与安全项目经验总结 MySQL在金融领域的应用与安全项目经验总结 Nov 03, 2023 am 09:00 AM

MySQL在金融领域的应用与安全项目经验总结引言:随着科技的发展和金融行业的快速增长,数据库技术在金融领域中的应用变得越来越重要。MySQL作为一款成熟的开源关系型数据库管理系统,被广泛应用于金融机构的数据存储和处理中。本文将总结MySQL在金融领域的应用情况,并分析了在安全项目中的经验与教训。一、MySQL在金融领域的应用情况数据存储和处理金融机构通常需要

See all articles