文件服务器访问速度突然变慢

文件服务器访问速度突然变慢,第1张

服务器的网速快慢跟天气有一定的关系。比如说有暴风暴雨的情况下,那么这种可能网速也会变慢的。计算机也要及时升级、安装系统补丁程序,同时卸载不必要的服务、关闭不必要的端口,以提高系统的安全性和可靠性。

一切本来都是那样的宁静,所有的网络服务都在默默地工作着。然而近一段时间来,经常有人打电话反映一个相同的问题:在接收E-Mail时,服务器端经常应答超时,从而无法正常收到E-Mail,但如果过一会儿再收,则又可能正常接收到。大家对此表现出了很大的不满。因此,我们就迅速动手寻找问题的根源,以争取尽快修复这个故障。一、查阅基本信息首先我们翻看了归档资料,确定了E-Mail运行在一个配置为PIII 500MHz,128M内存,20G硬盘的工控机上, *** 作系统是Redhat linux 65,使用Sendmail做为E-Mail Server,并且采用系统的passwd文件做为Sendmail邮件用户的认证文件。根据网管日志记载该邮件系统的用户在这一段时间以来发展十分迅速,用户数从1万名增加到了超过2万名。二、初步分析通过上面信息的了解,我们基本上确认速度变慢的主要的原因是用户量的增长。因此,在这此前提下进行了分析。我们在linux控制台下,输入以下命令查看系统的进程情况:ps –auxw我们发现,该命令列出了大量的发送邮件和POP进程。然后根据网管日志的记录,分别在低峰、平均、高峰期间进行了并发用户数的检查,发现在高峰情,并发的用户数已从原来的20个用户上升到了40个用户。到此为止,我们得出了初步的结论:由于用户的不断增长,并发用户也越来越多,使得机器无法处理完这些并发请求,以致E-Mail服务器对用户响应过慢,甚至超时而无法使用。因此,我们认为解决这一故障的办法就是升级机器。三、深入分析因此,我们便查看了另外一台配置相同,正在运行WEB服务的服务器,我们发现该服务器在同时处理50个用户访问时,并没有感到处理能力不足。这时,我们开始进一步分析E-Mail服务的整个过程。首先用户的邮件接收程序通过POP协议与服务器的POP模块进行通讯,并提供用户名与密码;接着E-Mail服务器的POP模块要将用户提供的密码进行加密;然后与系统文件/etc/passwd中的用户密码进行逐行匹配,并找出相应的用户名,再进行第二次匹配;如果匹配成功,校验通过,否则就返回用户名或密码不正确。校验通过后,服务器开始将属于该用户的邮件传送给用户的邮件接收程序。 这时,我们想到了,所有的用户连接都有一个共同的环节,那就是都要打开系统文件/etc/passwd,进行用户的验证,会不会是因此带来瓶颈问题呢?我们就在linux控制台上输入以下命令,查看使用/etc/passwd文件有多少个进程:fuser /etc/passwd这时,列出了很多POP进程,症结总算找到了。原来是因为系统文件/etc/passwd是一个文本文件,在用户名、密码的匹配过程中,是采用逐行进行匹配,而我们的/etc/passwd文件有2万多行,因此最好的情况下是第一次匹配就成功,最坏的情况就是2万多次后才匹配成功,因此平均需要1万次的匹配。该过程所消耗的时间足以使得电子邮件接收程序超时,而无法等到匹配结束。四、解决方法故障的根源找到了,解决方法也就自然简单。因为服务器POP模块通过搜索密码文件验证一个用户的身份所需的时间很长,使得进程产生了积累,从而事实上加重了系统的负担,即此时正在使用邮件接收程序的用户在长时间内仍保持连接状态,而无法正常进行下一步的工作。所以主要是解决方法就是将采用文件文件/etc/passwd的方法转成数据库形式。因此可以采用以下两种方法之一解决:1)使用linux的NIS系统,将系统的密码文件/etc/passwd转换成为NIS的信息库。由于NIS采用的是数据库引擎,所以运行起来,便于查找,效率可以大大提高。2)重新配置Sendmail,使其不采用系统文件/etc/passwd来进行用户校验,而是采用一个特定的数据库存储,由于也是采用了数据库引擎,所以运行起来,便于查询,效率也可以大大提高。你还可以采用Postfix等内建数据库支持的E-Mail系统来替换Sendmail,由于Postfix可以直接在Sendmail基础上实现数据的自动转换,因些整个 *** 作十分简单。五、解决效果我们最后采用了Postfix替换Sendmail,将其用户密码列表转换成为数据库模式,问题就迎刃而解。现在我们仍然在使用这台机器,而且用户已经增长到3万个,高峰时期用户的并发数也已经从40个上升到60-70个,但现在系统还是有条不紊地进行着,运行良好。六、体会在这个简单的例子中,我们深深地感受到在日常的系统管理工作中必须仔细地分析问题,而不要轻易地将问题归结于服务器硬件能力上。

MySQL 在崩溃恢复时,会遍历打开所有 ibd 文件的 header page 验证数据字典的准确性,如果 MySQL 中包含了大量表,这个校验过程就会比较耗时。 MySQL 下崩溃恢复确实和表数量有关,表总数越大,崩溃恢复时间越长。另外磁盘 IOPS 也会影响崩溃恢复时间,像这里开发库的 HDD IOPS 较低,因此面对大量的表空间,校验速度就非常缓慢。另外一个发现,MySQL 8 下正常启用时居然也会进行表空间校验,而故障恢复时则会额外再进行一次表空间校验,等于校验了 2 遍。不过 MySQL 80 里多了一个特性,即表数量超过 5W 时,会启用多线程扫描,加快表空间校验过程。

如何跳过校验MySQL 57 下有方法可以跳过崩溃恢复时的表空间校验过程嘛?查阅了资料,方法主要有两种:

配置 innodb_force_recovery可以使 srv_force_recovery != 0  ,那么 validate  = false,即可以跳过表空间校验。实际测试的时候设置 innodb_force_recovery =1,也就是强制恢复跳过坏页,就可以跳过校验,然后重启就是正常启动了。通过这种临时方式可以避免崩溃恢复后非常耗时的表空间校验过程,快速启动 MySQL,个人目前暂时未发现有什么隐患。

2   使用共享表空间替代独立表空间这样就不需要打开 N 个 ibd 文件了,只需要打开一个 ibdata 文件即可,大大节省了校验时间。自从听了姜老师讲过使用共享表空间替代独立表空间解决 drop 大表时性能抖动的原理后,感觉共享表空间在很多业务环境下,反而更有优势。

临时冒出另外一种解决想法,即用 GDB 调试崩溃恢复,通过临时修改 validate 变量值让 MySQL 跳过表空间验证过程,然后让 MySQL 正常关闭,重新启动就可以正常启动了。但是实际测试发现,如果以 debug 模式运行,确实可以临时修改 validate 变量,跳过表空间验证过程,但是 debug 模式下代码运行效率大打折扣,反而耗时更长。而以非 debug 模式运行,则无法修改 validate 变量,想法破灭。

建议手动清理及维护相关区域(也可直接下载安装清理工具,不过在清理过程中注意清理的文件类别):
1、缓存清理
2、硬盘文件碎片整理
3、清除过期备份资源
4、查杀病毒及插件
5、对网络进行相关优化(比如硬件部分:更换交换机、路由器等)
6、其他优化:现在共享的优化及清理工具都具备,效果还不错)
7、服务器硬件部分维护:除尘、CPU散热系统(风扇及重新涂装导热合金与CPU之间的导热硅胶)。

宽带网速慢可能有以下几种常见原因:
一、访问的网站服务器带宽窄或服务器繁忙,您可尝试换时段访问或者访问其他网站,判断是否此问题导致;
二、如电脑配置比较低或系统处理能力弱等电脑原因;
三、病毒或者木马等原因造成上网速度慢,建议您可以下载病毒防护软件进行全盘扫码杀毒;
四、使用路由器共享上网导致的网速慢;
五、Modem设备出现工作不稳定,建议您更换Modem设备测试;
六、线路原因(如线路长、线路噪声较大、入户线质量不好、用户端线路改动等)。
如非上述情况,可联系当地人工客服,反馈情况。

宽带网速慢可能有以下几种常见原因:
一、访问的网站服务器带宽窄或服务器繁忙,您可尝试换时段访问或者访问其他网站,判断是否此问题导致;
二、如电脑配置比较低或系统处理能力弱等电脑原因;
三、病毒或者木马等原因造成上网速度慢,建议您下载病毒防护软件进行全盘扫码杀毒;
四、使用路由器共享上网导致网速慢;
五、Modem设备出现工作不稳定,建议您更换Modem设备测试;
六、线路原因(如线路长、线路噪声较大、入户线质量不好、用户端线路改动等)。
如非上述情况,可联系当地人工客服,反馈情况。

应该是内存的问题,你的内存1G比较小,pos机向服务器请求命令比较占系统内存,当请求命令过高时,内存会遵循循环令牌指令规律,所以会出现卡机,慢等现象,当重启后内存中的沉积请求命令清空,所以就会速度快起来。所以建议增加服务器内存。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zz/10354777.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-07
下一篇 2023-05-07

发表评论

登录后才能评论

评论列表(0条)

保存