返回顶部
首页 > 资讯 > 数据库 >如何解决当MySQL数据库遇到Syn Flooding问题
  • 338
分享到

如何解决当MySQL数据库遇到Syn Flooding问题

2024-04-02 19:04:59 338人浏览 独家记忆
摘要

这篇文章给大家分享的是有关如何解决当Mysql数据库遇到Syn Flooding问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Syn攻击是最常见又最容易被利用的一种攻击手法,

这篇文章给大家分享的是有关如何解决当Mysql数据库遇到Syn Flooding问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

Syn攻击是最常见又最容易被利用的一种攻击手法,利用tcp协议的缺陷,发送大量伪造TCP连接请求,常用假冒的IP发来海量的SYN包,被攻击的服务器回应SYN+ACK,因为对方是假冒的IP,永远收不到包并且不会回应,导致被攻击服务器保持大量SYN_RECV状态的半连接,并且会重试默认5次回应握手包,塞满TCP等待连接队列,资源耗尽,让正常的业务请求连接不进来。

Syn攻击常见于应用服务器,而数据库服务器在内网中,应该很难碰到类似的攻击,但有时候应用程序如果和数据库建连姿势不正确,在数据库端,也会被认为是Syn攻击,并拒绝连接建立。

【问题描述】

数据库突发的拒绝链接,应用报错,出问题的时间点上,数据库服务器的操作系统日志里,即/var/log/messages,可看到如下报错信息:

kernel: possible SYN flooding on port 3306. Sending cookies.

【问题分析】

出问题的点上,从数据库的监控指标来看,Threads Connected 这个指标有增长。这个也是很明显,因为对数据库来说,Syn Flooding就是应用程序突发的对数据库发起建连,操作系统处理不过来,所以报Syn Flooding, 从数据库的性能指标来看,连接数肯定是会有一个突发的增长。应对方案就是需要分析这些突发的增长是怎么来的,削峰填谷,让连接更平稳。

【解决方案】

在数据库服务端,做如下调整:这个调整的意思是说:增加TCP半连接的缓冲,默认值是2048,我们调整到8192,让系统的抗突发压力增大一些。Tcp_syn_retires和Tcp_synack_retires默认是5,也就是服务器端要发送五次包,才会终止重试,我们把这个参数调整为2. 只重试一次,让出错的包尽量提早出错,以减少缓存的连接数。

echo 8192 > /proc/sys/net/ipv4/tcp_max_syn_backlog
echo 2 > /proc/sys/net/ipv4/tcp_syn_retries
echo 2 > /proc/sys/net/ipv4/tcp_synack_retries

这个参数调整,即时生效,无需重启。当然服务器重启后,这些参数也会回退到默认值。经此调整,数据库端的抗压能力得到加强,但并没有完全解决问题。

我们在客户端也做相应调整:

为减少数据库的连接数压力,通常我们建议连接池做如下配置:

testWhileIdle="false"。空闲时不检测连接串健康
minIdle="0"。连接池里面空闲连接的最小个数
maxAge="30000"。一个链接超过多少毫秒就可以回收掉。
initialSize="1"。连接池里面初始连接的最小个数
timeBetweenEvictionRunsMillis="5000"。回收线程的运行间隔(毫秒)

对于现在的场景,我们建议调高minIdle这个参数,从0调整到5. 让连接池平时有5个空闲连接存在,这样,发起对数据库请求的时候,会先使用这5个空闲连接。达到削峰填谷的作用。当然,副作用就是数据库平时的连接数会增长。具体调整到多少合适,需要结合实际的数据库连接负载情况。对于.net程序,也有相应的连接池参数可以调整:可以适当修改minPoolSize这个参数,也调整到5.

经此调整,基本上大部分的数据库Syn Flooding问题都能解决。

当然,这些都是调优的手段,只能是微微的改善系统。提高抗压能力。最终的分析,还是要看连接压力从何而来。以及为何需要突发建立大量连接到数据库。对于此种突发场景,用数据库是否合适。替代方案是前面用Redis加一层缓冲。避免突发的对数据库发起建连请求。这个就涉及到应用的改造了。

感谢各位的阅读!关于“如何解决当mysql数据库遇到Syn Flooding问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

您可能感兴趣的文档:

--结束END--

本文标题: 如何解决当MySQL数据库遇到Syn Flooding问题

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

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

猜你喜欢
  • 如何解决当MySQL数据库遇到Syn Flooding问题
    这篇文章给大家分享的是有关如何解决当MySQL数据库遇到Syn Flooding问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Syn攻击是最常见又最容易被利用的一种攻击手法,...
    99+
    2024-04-02
  • 如何解决Mysql大量数据导入遇到的问题
    这篇文章主要介绍如何解决Mysql大量数据导入遇到的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在项目中,经常会碰到往数据库中导入大量数据,以便利用sql进行数据分析。在导入数...
    99+
    2024-04-02
  • 如何解决python连接数据库mysql解压版安装配置及遇到问题
    这篇文章主要为大家展示了“如何解决python连接数据库mysql解压版安装配置及遇到问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决python连接...
    99+
    2024-04-02
  • 如何解决MySQL使用中遇到的问题
    这篇文章给大家分享的是有关如何解决MySQL使用中遇到的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。sql_mode=only_full_group_by引起group b...
    99+
    2024-04-02
  • 如何解决mysql数据库服务找不到的问题
    这篇文章主要介绍了如何解决mysql数据库服务找不到的问题,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。mysql数据库服务找不到的解决办法:首...
    99+
    2024-04-02
  • 设计MySQL数据库常常会遇到的问题
    本文主要给大家介绍设计MySQL数据库常常会遇到的问题,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下设计MySQL数据库常常会遇到的问题吧。第一题:...
    99+
    2024-04-02
  • 如何解决Mysql数据库从5.6.28版本升到8.0.11版本部署项目时遇到的问题
    这篇文章将为大家详细讲解有关如何解决Mysql数据库从5.6.28版本升到8.0.11版本部署项目时遇到的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。mysql数据...
    99+
    2024-04-02
  • 数据库编程中遇到的Python问题及解决方法
    数据库编程中遇到的Python问题及解决方法在进行数据库编程时,我们经常会遇到各种各样的问题,如连接数据库、创建表、插入数据、查询数据等等。本文将围绕数据库编程中常见的问题展开讨论,并提供相应的解决方法和代码示例,以帮助读者更好地理解和使用...
    99+
    2023-10-22
    数据库连接:在Python中 SQL查询:在数据库编程中
  • Excel数据导入Mysql常见问题汇总:如何解决导入数据时遇到的乱码问题?
    Excel数据导入Mysql常见问题汇总:如何解决导入数据时遇到的乱码问题?导入Excel数据到Mysql数据库是日常工作中常见的任务。但有时候在导入过程中,会遇到乱码问题,导致数据显示不正确。本文将总结常见的乱码问题,并提供解决方案,以帮...
    99+
    2023-10-22
    MySQL 乱码问题 关键词:Excel导入
  • 如何解决Mysql导入导出时遇到的问题
    这篇文章给大家分享的是有关如何解决Mysql导入导出时遇到的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。背景自从把我手上的任务全部转换成docker运行和管理之后,遇到了一...
    99+
    2024-04-02
  • 如何解决MySQL中使用innobackup 2.4遇到的问题
    这篇文章将为大家详细讲解有关如何解决MySQL中使用innobackup 2.4遇到的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 一 ...
    99+
    2024-04-02
  • 如何解决数据写入mysql数据库的问号问题
    这篇文章将为大家详细讲解有关如何解决数据写入mysql数据库的问号问题,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。解决数据写入mysql的问号问题&nbs...
    99+
    2024-04-02
  • MySQL 数据库如何解决高并发问题
    前言 我们都知道初创公司一开始都是以单体应用为首要架构,一般都是单体单库的形式。但是版本以及版本的迭代,数据库需要承受更多的高并发已经成了 架构设计 需要考虑的点。 那么解决问题,就得说到方案。但是方案有很多,我们...
    99+
    2022-05-20
    MySQL 高并发 MySQL 高并发解决方案
  • 如何解决写gulp遇到的ES6问题
    这篇文章给大家分享的是有关如何解决写gulp遇到的ES6问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言Gulp.js 是一个自动化构建工具,开发者可以使用它在项目开发过程...
    99+
    2024-04-02
  • 使用@ApiModel遇到的问题如何解决
    这篇文章主要介绍了使用@ApiModel遇到的问题如何解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇使用@ApiModel遇到的问题如何解决文章都会有所收获,下面我们一起来看看吧。@ApiModel遇到的问...
    99+
    2023-07-02
  • sybase15 迁移数据库时遇到的问题
    在创建逻辑卷的时候首先要创建pv pvcreate /dev/sdb创建pv之后开始创建vg vgcreate vg_db /dev/sdb创建vg后开始划lv也就是逻辑卷 lvcreate -L 1G e...
    99+
    2024-04-02
  • ajax如何解决跨域访问遇到的问题
    这篇文章给大家分享的是有关ajax如何解决跨域访问遇到的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Ajax请求一个目标地址为非本域(协议、域名、端口任意一个不同)的web...
    99+
    2024-04-02
  • Excel数据导入Mysql常见问题汇总:如何解决导入时遇到的数据长度超限问题?
    Excel数据导入Mysql常见问题汇总:如何解决导入时遇到的数据长度超限问题?导入Excel数据到Mysql数据库是日常工作中经常遇到的任务之一。但是,在导入过程中常常会遇到数据长度超限的问题,特别是当Excel表格中某些字段的数据长度超...
    99+
    2023-10-22
    MySQL 关键词:Excel数据 数据长度超限问题
  • Excel数据导入Mysql常见问题汇总:如何解决导入过程中遇到的数据校验问题?
    Excel数据导入Mysql常见问题汇总:如何解决导入过程中遇到的数据校验问题?导入Excel数据到MySQL数据库是我们在数据处理工作中经常需要进行的操作。然而,在这个过程中常常会遇到一些数据校验问题,导致导入失败或者导入后的数据不符合我...
    99+
    2023-10-22
    Excel导入 数据校验 Mysql常见问题
  • Mysql如何解决数据库N+1查询问题
    这篇文章主要介绍Mysql如何解决数据库N+1查询问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!简介在orm框架中,比如hibernate和mybatis都可以设置关联对象,比如...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作