误删服务器 /tmp 下的文件之后引发的问题
事件起因
收到阿里云的报告说我的服务器中有挖矿程序,隐藏在/tmp 目录下。查看服务器的 CPU 使用情况,也飙升到了 90%以上,于是,我杀掉了一些不相关的进程,顺手执行了rm -rf /tmp
命令。后来把自己安装的 gitlab 社区版卸载了,卸载过程中自动停掉了 mysql。紧接着通过宝塔面板,我的showDoc
、mysql
全部不好使了。
showDoc
不好使是因为它是基于 php7.3 部署的,我删掉了tmp
目录下的php-cgi-73.sock
文件。mysql
不好使是因为我后来手动创建的/tmp
目录没有写入权限。
解决方案
先将删除的/tmp 目录创建出来
找到不好使应用的日志,比如我的
showDoc
是通过 nginx 部署的,那我只用找到错误日志,看是啥原因访问不了。日志中显示2021/12/10 17:37:41 [crit] 15987#0: *9509 connect() to unix:/tmp/php-cgi-73.sock failed (2: No such file or directory)
是说临时目录下找不到`php-cgi-73.sock`文件,那我先将这个文件创建出来,并开放读写权限。再访问时,又是502 Bad Gateway
,再看 nginx 的错误日志,提示[error] 22205#0: *1 connect() to unix:/tmp/php-cgi-73.sock failed (111: Connection refused)
,这种情况是因为文件创建出来了,权限也给了,但是 php 并没有加载到,只用重启 php 服务即可。
mysql 是因为在卸载 gitlab 时被停掉了,通过/etc/init.d/mysqld status
命令查看状态,提示MySQL is not running, but lock file (/var/lock/subsys/mysql[FAILED]
,执行rm /var/lock/subsys/mysql
删除 lock 文件;执行/etc/init.d/mysqld start
启动 mysql 服务,又报错Starting MySQL..The server quit without updating PID file ([FAILED]ver/data/iZ8vb53kklhrg4j6sviqtpZ.pid).
,找到 mysql 的日志目录(如果不知道日志目录在哪,就去/etc/my.cf
文件中查看),日志目录下能看到一个名为iZ8vb53kklhrg4j6sviqtpZ.err
的错误日志文件,查看内容,找到最近操作时的日志,就基本上知道啥原因了,我是因为tmp
目录没写入权限,开了权限后,执行/etc/init.d/mysqld start
启动即可。
总结
删除需谨慎,幸亏这是自己的服务器,如果是公司的服务器,就是一次事故;
linux 的知识还有待提高,如果没有足够的知识作为支撑,只是会用,一个错误的操作就会引发灾难性的后果。
版权声明: 本文为 InfoQ 作者【熊斌】的原创文章。
原文链接:【http://xie.infoq.cn/article/29a1db5bd01f3954f6c48a1c7】。文章转载请联系作者。
评论