返回顶部
首页 > 资讯 > 数据库 >怎么强化MySQL的安全
  • 285
分享到

怎么强化MySQL的安全

2024-04-02 19:04:59 285人浏览 薄情痞子
摘要

这篇文章主要介绍“怎么强化Mysql的安全”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么强化mysql的安全”文章能帮助大家解决问题。第一步:设置强密码对于所有

这篇文章主要介绍“怎么强化Mysql安全”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么强化mysql的安全”文章能帮助大家解决问题。

第一步:设置强密码

对于所有数据库用户来说,使用强密码很重要。鉴于大多数人不会经常手动登录数据库,请使用密码管理器或命令行工具 pwgen 为你的数据库帐户创建一个随机的 20 个字符的密码。即使你使用额外的 Mysql 访问控制来限制特定帐户可以登录的位置(例如将帐户严格限制为 localhost),这依然很重要。

设置密码的最重要的 MySQL 帐户是 root 用户。默认情况下,在许多系统中,该用户没有密码。特别是,基于 Red Hat 的系统在安装 MySQL 时不会设置密码;虽然基于 Debian 的系统会在交互式安装期间提示您输入密码,但非交互式安装(就像您可能使用配置管理器执行的那样)会跳过它。此外,你仍然可以在交互式安装期间跳过设置密码。

你可能认为让 root 用户不输入密码并不是什么大的安全风险。毕竟,用户设置为 “root@localhost”,你可能认为这意味着你必须先 root 计算机,然后才能成为该用户。不幸的是,这意味着任何可以从 localhost 触发 MySQL 客户端的用户都可以使用以下命令以 MySQL root 用户身份登录:

*$ mysql — user root*

因此,如果你不为 root 用户设置密码,那么任何能够在您的 MySQL 机器上获得本地 shell 的人现在都可以完全控制你的数据库。

要修复此漏洞,请使用 mysqladmin 命令为 root 用户设置密码:

$ sudo mysqladmin passWord

不幸的是,MySQL 以 root 用户身份运行后台任务。一旦你设置了密码,这些任务就会中断,除非采取额外的步骤将密码硬编码到 /root/.my.cnf 文件中:

[mysqladmin]
user = rootpassword = yourpassword

但是,这意味着你必须将密码以纯文本形式存储在主机上。但是你至少可以使用 Unix 文件权限将对该文件的访问限制为仅 root 用户:

sudo chown root:root /root/.my.cnf
sudo chmod 0600 /root/.my.cnf

第二步:删除匿名用户

匿名帐户是既没有用户名也没有密码的 MySQL 帐户。你不希望攻击者在没有密码的情况下对你的数据库进行任何形式的访问,因此请在此命令的输出中查找使用空白用户名记录的任何 MySQL 用户:

> SELECT Host, User FROM mysql.user;
+ — — — — — — — — — — — — + — — — -+
| Host | User |
+ — — — — — — — — — — — — + — — — -+
| 127.0.0.1 | root |
| ::1 | root |
| localhost | |
| localhost | root |
+ — — — — — — — — — — — — + — — — -+
4 rows in set (0.00 sec)

在这些根用户中间有一个匿名用户( localhost ),它在 User 列中为空。你可以使用下面命令清除特定的匿名用户:

> drop user ""@"localhost";
> flush privileges;

如果你发现任何其他匿名用户,请确保将其删除。

第三步:遵循最小特权原则

最小特权原则是一项安全原则,可以总结如下:

只为账户提供执行作业所需的访问权限,而不提供更多权限。

此原则可以通过多种方式应用于 MySQL。首先当使用 GRANT 命令向特定用户添加数据库权限时,请确保仅限制该用户需要访问数据库的权限:

> grant all privileges on mydb.* to someuser@"localhost" identified by 'astrongpassword';
> flush privileges;

如果该用户只需要访问一个特定的表(例如,users 表),用mydb.users  或者任何你的表的名字替换 mydb.*(授予对所有表的权限)。

许多人会授予用户对数据库的完全访问权限;但是如果你的数据库用户仅仅只需要读取数据而不需要更改数据,则需要额外的步骤授予对数据库的只读访问权限:

> grant select privileges on mydb.* to someuser@"localhost" identified by 'astrongpassword';
> flush privileges;

最后,许多数据库用户不会从 localhost 访问数据库,通常管理员会创建他们,像这样:

> grant all privileges on mydb.* to someuser@"%"  identified by 'astrongpassword';
> flush privileges;

这将允许 「someuser」从任何网络访问数据库。但是,如果你有一组定义明确的内部 IP,或者 - 甚至更好 - 已经设置了 VLANS ,以便你所有应用程序服务器与其它主机位于不同的子网中,那么就可以利用这个优势来限制 「someuser」,使得该账户只能从特定网络访问数据库:

> grant all privileges on mydb.* to someuser@10.0.1.0/255.255.255.0 identified by 'astrongpassword';
> flush privileges;

第四步:启用 TLS

设置强密码仅只有攻击者可以在网络上读取你的密码或者其他敏感数据的情况下才能达到此目的。因此,使用 TLS 保护你的所有网络流量比以往任何时候都更加重要。

MySQL 也不例外。

幸运的是,在 MySQL 中启用 TLS 比较简单。一旦你有了你的主机的有效证书,只需要在你的主 my.cnf 文件的 [mysqld]部分添加以下几行 :

[mysqld]
ssl-ca=/path/to/ca.crt
ssl-cert=/path/to/server.crt
ssl-key=/path/to/server.key

为了额外的安全性,还可以添加 ssl-cipher 配置选项,其中包含一个被认可的密码列表,而不是只接受默认的密码列表,这可能包括较弱的 TLS 密码。我推荐使用  Mozilla Security/Server Side TLS page 所推荐的现代或者中级密码套件。

一旦服务器端设置了 TLS ,你可以限制客户端必须采用 TLS 进行连接,通过在 GRANT 语句中添加 REQUIRE SSL :

> grant all privileges on mydb.* to someuser@10.0.1.0/255.255.255.0 identified by 'astrongpassword' REQUIRE SSL;

> flush privileges;

第五步:加密数据库密钥

虽然现在很多人都知道使用单向散列(理想情况下是像 bcrypt 这样慢速散列 ),保护用户数据库存储的密码有多重要,但通常没过多考虑使用加密来保护数据库上其他的敏感数据。事实上,许多管理员会告诉你他们的数据库是加密的,因为磁盘本身是加密的。这实际上会影响你的数据库加固,不是因为磁盘加固有缺陷或糟糕的做法,而是因为它会给你一种错误的信任感。

磁盘加密保护你的数据库数据,以防止有人从你的服务器窃取磁盘(或者你买了二手磁盘后忘记擦除磁盘),但是磁盘加密并不能在数据库本身运行时保护你,因为驱动器需要处于解密状态才能被读取。

要保护数据库中的数据,你需要采取额外的措施,在存储敏感字段之前对它们进行加密。这样如果攻击者找到了某种方法来转存完整的数据库,你的敏感字段仍然会受到保护。

有许多加密数据库中字段的方法,而且 MySQL 支持本地加密命令。无论你采取哪种加密方法,我都建议避免你需要将解密密钥存储在数据库本身的加密方法。

理想情况下,你会把解密的密钥存储在应用服务器上,作为本地GPG密钥(如果你使用GPG进行加密)或者将其存储为应用程序服务器上的环境变量。这样即使攻击者可能找到一种方法来破坏应用程序服务器的服务器,他也必须将攻击转换为本地shell访问,以此来获取你的解密密钥。

MySQL 加固原则:掌握最小权限原则

有很多方法来定你的MySQL服务器。确切地说,你如何实施这些步骤取决于你如何设置自己的数据库,以及它在网络中的位置。

虽然前面的五个步骤将有助于保护你的数据库,但我认为更需要掌握的最重要的整体步骤是最小权限原则。你的数据库可能存储来一些非常有用的数据,如果你确保用户和应用程序只具有执行其工作的所需的最小访问权限,那么你将限制攻击者能够做什么,如果黑客找到来危害该用户或者应用程序的方法。

关于“怎么强化MySQL的安全”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网数据库频道,小编每天都会为大家更新不同的知识点。

您可能感兴趣的文档:

--结束END--

本文标题: 怎么强化MySQL的安全

本文链接: https://lsjlt.com/news/74255.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么强化MySQL的安全
    这篇文章主要介绍“怎么强化MySQL的安全”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么强化MySQL的安全”文章能帮助大家解决问题。第一步:设置强密码对于所有...
    99+
    2024-04-02
  • 怎样强化Linux安全
    这篇文章将为大家详细讲解有关怎样强化Linux安全,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。  时常有人说,Linux比Windows更安全。但与网络衔接的任何计算机是不能够相对安全的。...
    99+
    2023-06-13
  • linux如何安全强化SSH
    这篇文章给大家分享的是有关linux如何安全强化SSH的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。安全强化 SSH接下来,进行以下三个更改:禁用 SSH 密码认证限制 root 远程登录限制对 IPv4 或 I...
    99+
    2023-06-27
  • Linux下如何强化SSH安全
    这篇“Linux下如何强化SSH安全”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Linux下如何强化SSH安全”文章吧。1...
    99+
    2023-06-27
  • 怎么加强服务器的安全
    这篇文章主要介绍“怎么加强服务器的安全”,在日常操作中,相信很多人在怎么加强服务器的安全问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么加强服务器的安全”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!1....
    99+
    2023-06-27
  • 怎么增强云主机的安全
    增强云主机的安全可以通过以下方法实现: 使用强密码和多因素认证:确保云主机的登录密码复杂且安全,建议使用包含字母、数字和特殊字符...
    99+
    2024-05-15
    云主机
  • 如何安全强化Linux服务器
    这篇文章给大家分享的是有关如何安全强化Linux服务器的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1. 更新你的服务器保护服务器安全的第一件事是更新本地存储库,并通过应用最新的修补程序来升级操作系统和已安装的应...
    99+
    2023-06-16
  • linux服务器安全强化SSH的配置
    本篇内容介绍了“linux服务器安全强化SSH的配置”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!今天主要介绍一下linux服务器安全强化S...
    99+
    2023-06-16
  • 如何安全强化你的Linux服务器
    这篇文章主要为大家展示了“如何安全强化你的Linux服务器”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何安全强化你的Linux服务器”这篇文章吧。1、更新你的服务器保护服务器安全的第一件事是...
    99+
    2023-06-16
  • 怎么加强云服务器的安全
    加强云服务器安全的方法:1、加强云服务器的物理安全,包括温度、湿度、供电等环境因素;2、加强云服务器网络端口的安全,定期或及时升级杀毒软件,安装系统补丁,设置防火墙;3、加强云服务器的数据安全,设置账号和密码保护,定期对服务器数据进行备份。...
    99+
    2024-04-02
  • 强化Linux安全的10个技能分别是什么
    这篇文章将为大家详细讲解有关强化Linux安全的10个技能分别是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.找出不必要的服务很明显,服务器上跑的服务,并不是每个都有用的。强烈建议检...
    99+
    2023-06-06
  • 如何进行Linux系统安全强化
    这期内容当中小编将会给大家带来有关如何进行Linux系统安全强化,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。选择正确的Linux发行版选择一个好的Linux发行版有很多因素。 避免分发冻结程序...
    99+
    2023-06-15
  • CentOS7中怎么加强系统安全
    要加强CentOS7系统的安全性,可以采取以下措施: 更新系统:定期更新操作系统和安全补丁来修复已知的漏洞。 安装防火墙:配...
    99+
    2024-03-04
    CentOS7
  • Node.js 安全强化:身份验证与授权的全面分析
    身份验证 身份验证是在用户尝试访问受保护资源之前验证其身份的过程。Node.js 提供多种身份验证机制,包括: 基于会话的 cookie:会话 cookie 在用户登录时创建,并包含有关其身份的加密信息。 JSON Web 令牌 (JW...
    99+
    2024-04-02
  • 美国VPS服务器的安全怎么增强
    美国VPS服务器增强安全的方法:1、保护账号和密码,设置多种字符复杂且具有一定长度的密码;2、设置双重认证,能有效提高美国VPS服务器的安全性;3、及时安装和更新系统补丁,以免操作系统的漏洞被蓄意攻击利用;4、对日志程序报表进行分析,看是否...
    99+
    2024-04-02
  • 怎么增强服务器租用的安全性
    使用强密码:确保服务器的密码足够复杂,包含大小写字母、数字和特殊字符,并定期更换密码。 双重验证:启用双重验证机制,例如短信...
    99+
    2024-04-25
    服务器
  • win7怎么强制进入安全模式
    要强制进入安全模式,您可以按照以下步骤操作:1. 重启您的电脑。2. 在计算机启动过程中,按住 F8 键不放。一般情况下,您需要在操...
    99+
    2023-09-01
    win7
  • win8怎么强制进入安全模式
    在Windows 8中,可以通过以下方法强制进入安全模式:1. 使用Shift键:首先,在登录界面按住Shift键,然后点击“电源”...
    99+
    2023-09-02
    win8
  • 如何设置CA证书来强化PostgreSQL的安全性
    这篇文章主要介绍“如何设置CA证书来强化PostgreSQL的安全性”,在日常操作中,相信很多人在如何设置CA证书来强化PostgreSQL的安全性问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方...
    99+
    2024-04-02
  • JavaScript 的 CSRF 强心剂:增强你的网站安全
    跨站请求伪造 (CSRF) 是一种恶意网络攻击技术,攻击者利用受害者的登录会话,在受害者不知情的情况下执行恶意操作。本文将重点介绍如何使用 JavaScript 来增强网站安全,抵御 CSRF 攻击。 CSRF 的原理 CSRF 攻击利用...
    99+
    2024-02-15
    CSRF JavaScript 安全 Cookie Token
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作