Linux运维常见故障排查和处理的技巧汇总

作为Linux运维,工作中多多少少会遇见这样那样的问题或故障,从中总结经验,查找问题,汇总并分析故障的原因,这是一个Linux运维工程师良好的习惯。每一次技术的突破,都经历着苦闷,伴随着快乐,可我们还是执着的继续努力,从中也积累了更多的经验。

下面汇总了可能出现的故障及解决方法,看看你是否遇到过?并对你有帮助?

第一:常见问题解决集锦

1.shell脚本不执行
问题:某天研发同事找我说帮他看看他写的shell脚本,死活不执行,报错。我看了下,脚本很简单,也没有常规性的错误,报“:badinterpreter:Nosuchfileordirectory”错。
看这错,我就问他是不是在windows下编写的脚本,然后在上传到linux服务器的……果然。
原因:在DOS/windows里,文本文件的换行符为rn,而在*nix系统里则为n,所以DOS/Windows里编辑过的文本文件到了*nix里,每一行都多了个^M。
解决:
1)重新在linux下编写脚本;
2)vi:%s/r//g:%s/^M//g(^M输入用Ctrl+v,Ctrl+m)
附:sh-x脚本文件名,可以单步执行并回显结果,有助于排查复杂脚本问题。

2.crontab输出结果控制
问题:
/var/spool/clientmqueue目录占用空间超过100G
原因:
cron中执行的程序有输出内容,输出内容会以邮件形式发给cron的用户,而sendmail没有启动所以就产生了/var/spool/clientmqueue目录下的那些文件,日积月累可能撑破磁盘。
解决:
1)直接手动删除:ls|xargsrm-f;
2)彻底解决:在cron的自动执行语句后加上>/dev/null2>&1

3.telnet很慢/ssh很慢
问题:
某天研发 同事说10.50访问10.52memcached服务异常,让我们检查下看网络/服务/系统是否有异常。检查发现系统正常,服务正常,10.50ping10.52也正常,但10.50telnet10.52很慢。同时发现该机器的namesever是不起作用的。
原因:
becauseyourPCdoesn’tdoareverseDNSlookuponyourIPthen…whenyoutelnet/ftpintoyourlinuxbox,it’lldoadnslookuponyou。
解决:
1)修改/etc/hosts使hostname和ip对应;
2)在/etc/resolv.conf注释掉nameserver或者找一个“活的”nameserver。

4.Read-onlyfilesystem
问题:
同事在mysql里建表建不成功,提示如下:
mysql>createtablewosontest(colddname1char(1));
ERROR1005(HY000):Can’tcreatetable‘wosontest’(errno:30)
经检查mysql用户权限以及相关目录权限没问题;用perror30提示信息为:OSerrorcode30:Read-onlyfilesystem
可能原因:
1)文件系统损坏;
2)磁盘又坏道;
3)fstab文件配置错误,如分区格式错误错误(将ntfs写成了fat)、配置指令拼写错误等。
解决:
1)由于是测试机,重启机器后恢复;
2)网上说用mount可解决。

5.文件删了磁盘空间没释放
问题:
某天发现某台机器df-h已用磁盘空间为90G,而du-sh/*显示所有使用空间加起来才30G,囧。
原因:
可能某人直接用rm删除某个正在写的文件,导致文件删了但磁盘空间没释放的问题
解决:
1)最简单重启系统或者重启相关服务。
2)干掉进程
/usr/sbin/lsof|grepdeleted
ora25575data33uREG65,654294983680/oradata/DATAPRE/UNDOTBS009.dbf(deleted)
从lsof的输出中,我们可以发现pid为25575的进程持有着以文件描述号(fd)为33打开的文件/oradata/DATAPRE/UNDOTBS009.dbf。在我们找到了这个文件之后可以通过结束进程的方式来释放被占用的空间:echo>/proc/25575/fd/33
3)删除正在写的文件一般用cat/dev/null>file

6.find文件提升性能
问题:
在tmp目录下有大量包含picture_*的临时文件,每天晚上2:30对一天前的文件进行清理。之前在crontab下跑如下脚本,但是发现脚本效率很低,每次执行时负载猛涨,影响到其他服务。
#!/bin/sh
find/tmp-name“picture_*”-mtime+1-execrm-f{};
原因:
目录下有大量文件,用find很耗资源。
解决:
#!/bin/sh
cd/tmp
time=`date-d“2dayago”“+%b%d”`
ls-l|grep“picture”|grep“$time”|awk‘{print$NF}’|xargsrm-rf

7.获取不了网关mac地址
问题:
从2.14到3.65(映射地址2.141)网络不通,但是从3端的其他机器到3.65网络OK。
原因:
#arp
AddressHWtypeHWaddressFlagsMaskIface
192.168.3.254etherincompletCMbond0
表面现象是机器自动获取不了网关MAC地址,网络工程师说是网络设备的问题,具体不清。
解决:
arp绑定,arp-ibond0-s192.168.3.25400:00:5e:00:01:64

8.http服务无法启动一例
问题:某天研发同事说网站前端环境http无法启动,我上去看了下。报如下错:
/etc/init.d/httpdstart
Startinghttpd:[SatJan2917:49:002011][warn]moduleantibot_moduleisalreadyloaded,skipping
Useproxyforwardasremoteip:true.
Antibotexcludepattern:.*.[(js|css|jpg|gif|png)]
Antibotseedcheckpattern:login
(98)Addressalreadyinuse:make_sock:couldnotbindtoaddress[::]:7080
(98)Addressalreadyinuse:make_sock:couldnotbindtoaddress0.0.0.0:7080
nolisteningsocketsavailable,shuttingdown
Unabletoopenlog[FAILED]
原因:
1)端口被占用:表面看是7080端口被占用,于是netstat-npl|grep7080看了下发现7080没有占用;
2)在配置文件中重复写了端口,如果在以下两个文件同时写了Listen7080
/etc/httpd/conf/http.conf
/etc/httpd/conf.d/t.10086.cn.conf
解决:
注释掉/etc/httpd/conf.d/t.10086.cn.conf的Listen7080,重启,OK。

9.toomanyopenfile
问题:
报toomanyopenfile错误
解决:
终极解决方案
echo“”>>/etc/security/limits.conf
echo“*softnproc65535″>>/etc/security/limits.conf
echo“*hardnproc65535″>>/etc/security/limits.conf
echo“*softnofile65535″>>/etc/security/limits.conf
echo“*hardnofile65535″>>/etc/security/limits.conf
echo“”>>/root/.bash_profile
echo“ulimit-n65535″>>/root/.bash_profile
echo“ulimit-u65535″>>/root/.bash_profile
最后重启机器或者执行ulimit-u655345&&ulimit-n65535

10.ibdata1和mysql-bin致磁盘空间问题
问题:
2.51磁盘空间报警,经查发现ibdata1和mysql-bin日志占用空间太多(其中ibdata1超过120G,mysql-bin超过80G)
原因:
ibdata1是存储格式,在INNODB类型数据状态下,ibdata1用来存储文件的数据和索引,而库名的文件夹里的那些表文件只是结构而已。
innodb存储引擎有两种表空间的管理方式,分别是:
1)共享表空间(可拆分为多个小的表空间文件),这个是我们目前多数数据库使用的方法;
2)独立表空间,每一个表有一个独立的表空间(磁盘文件)
对于两种管理方式,各有优劣,具体如下:
①共享表空间:
优点:可以将表空间分成多个文件存放到不同的磁盘上(表空间文件大小不受表大小的限制,一个表可以分布在不同步的文件上)
缺点:所有数据和索引存放在一个文件中,则随着数据的增加,将会有一个很大的文件,虽然可以把一个大文件分成多个小文件,但是多个表及索引在表空间中混合存储,这样如果对于一个表做了大量删除操作后表空间中将有大量空隙。对于共享表空间管理的方式下,一旦表空间被分配,就不能再回缩了。当出现临时建索引或是创建一个临时表的操作表空间扩大后,就是删除相关的表也没办法回缩那部分空间了。
②独立表空间:在配置文件(my.cnf)中设置:innodb_file_per_table
特点:每个表都有自已独立的表空间;每个表的数据和索引都会存在自已的表空间中。
优点:表空间对应的磁盘空间可以被收回(Droptable操作自动回收表空间,如果对于删除大量数据后的表可以通过:altertabletbl_nameengine=innodb;回缩不用的空间。
缺点:如果单表增加过大,如超过100G,性能也会受到影响。在这种情况下,如果使用共享表空间可以把文件分开,但有同样有一个问题,如果访问的范围过大同样会访问多个文件,一样会比较慢。如果使用独立表空间,可以考虑使用分区表的方法,在一定程度上缓解问题。此外,当启用独立表空间模式时,需要合理调整innodb_open_files参数的设置。
解决:
1)ibdata1数据太大:只能通过dump,导出建库的sql语句,再重建的方法。
2)mysql-binLog太大:
①手动删除:
删除某个日志:mysql>PURGEMASTERLOGSTO‘mysql-bin.010′;
删除某天前的日志:mysql>PURGEMASTERLOGSBEFORE’2010-12-2213:00:00′;
②在/etc/my.cnf里设置只保存N天的bin-log日志
expire_logs_days=30//BinaryLog自动删除的天数

二、故障排查汇总表在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 6
    点赞
  • 66
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux运维常见的Shell脚本有很多,以下是其几个常见的: 1. 自动备份脚本:用于定期备份重要数据和文件。通过Shell脚本可以实现自动化备份的操作,可以指定备份的目录和文件,以及备份的频率和存储位置。这样可以节省管理员手动备份的时间和精力。 2. 日志分析脚本:用于对系统日志进行分析和统计。通过Shell脚本,可以编写脚本来检索系统日志的特定信息,比如错误日志或者登录日志,并可以进行分析和生成报告,帮助管理员找出系统的问题和异常。 3. 系统监控脚本:用于监控服务器的性能和资源。通过Shell脚本可以实现对服务器资源的监控,比如CPU利用率、内存使用情况、磁盘空间等。当资源达到预设阈值时,可以触发报警或者自动化的操作。 4. 系统部署脚本:用于快速部署和配置服务器。通过Shell脚本可以编写自动化的脚本来安装和配置应用程序或者服务器环境,比如搭建Web服务器或者数据库服务器。这样可以提高部署的效率和一致性。 5. 定时任务脚本:用于定期执行特定的任务。通过Shell脚本可以编写定时任务,比如定期清理临时文件、定时发送邮件等。这样可以实现一些常规性的操作,并减轻管理员的工作负担。 这些是Linux运维常见的几个Shell脚本,当然实际应用可能还有其他的脚本,根据具体需求会有所不同。通过编写Shell脚本,可以提高运维工作的自动化程度和效率,同时减少出错的可能性。 ### 回答2: Linux运维通常会使用一些常见的Shell脚本来简化和自动化一些重复的任务。以下是一些常见的Linux运维脚本: 1. 系统备份脚本:用于执行服务器的完全备份或增量备份,包括文件和数据的备份、压缩和存储。通过定期运行备份脚本可以确保数据的安全性。 2. 日志文件分析脚本:用于对系统日志进行分析和报告,通过提取关键信息、统计特定事件的发生次数和分析日志文件的大小等指标,帮助系统管理员及时发现问题,并进行相应的故障排除。 3. 定时任务脚本:用于定期执行某些任务,比如系统状态监控、磁盘空间检查、服务启动和停止等。通过设置定时任务脚本,可以在预定时间自动执行相应的操作,提高工作效率。 4. 监控脚本:用于监控系统的各项指标,如CPU利用率、内存占用率、磁盘空间使用情况和网络带宽等。通过定期运行监控脚本,可以及时发现系统的异常情况并采取相应措施。 5. 安全检查脚本:用于检查系统的安全性,包括密码强度、账户权限、开放的端口等。通过运行安全检查脚本,可以发现系统的安全漏洞并采取相应措施,增强系统的安全性。 6. 网络设置脚本:用于配置和管理网络设置,包括IP地址、子网掩码、网关、DNS等。通过运行网络设置脚本,可以快速配置和修改系统的网络设置,提供便利性和灵活性。 以上是一些常见的Linux运维脚本,通过使用这些脚本,系统管理员可以更高效地管理和维护Linux服务器,提高工作效率和系统安全性。 ### 回答3: Linux运维常见的Shell脚本有很多,以下是一些常见的例子: 1. 自动备份脚本:用于定期备份重要数据或文件,可以设置定时任务,自动执行备份任务,并将备份文件按照日期存储。 2. 系统资源监控脚本:可以通过Shell脚本编写一个用于监控系统资源使用情况的脚本,包括CPU使用率、内存使用量、磁盘空间等,并将结果输出到日志文件或发送邮件进行监控。 3. 日志分析脚本:用于分析日志文件,提取关键信息,如错误日志分析、访问日志统计等。 4. 系统自动安装脚本:可以编写一个脚本,自动安装各种软件或配置系统环境,简化系统部署过程。 5. 监控进程脚本:编写一个Shell脚本来监控某个进程的运行状态,当进程停止运行时,自动重启或发出警报。 6. 网络检测脚本:可以编写一个用于检测网络连通性的脚本,通过ping命令检测网络连通性,并将结果记录下来。 7. 系统性能优化脚本:用于自动优化系统性能,例如调整内核参数、清理无用进程、释放缓存等。 8. 定时任务脚本:使用crontab命令结合Shell脚本可以编写定时任务,如每天自动备份、每周清理日志等。 总之,Shell脚本在Linux运维扮演了重要的角色,可以帮助管理人员自动化执行各种任务,提高效率,减少人工操作的工作负担。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值