Linux个人系统中家目录下.xsession-errors文件过大的解决办法
学watch命令时,尝试了一下雪峰流云大佬的一篇博客中所说的,一个动态监测当前目录中的文件变化
watch -d -n 1 -t 'ls -AltF .'
ls -AltF 的参数详解:
-F 在文件后面加一个文件符号表示文件类型
共有 */=>@| 这几种类型,* 表示可执行文件,/ 表示目录,= 表示接口( sockets) ,> 表示门, @ 表示符号链接, | 表示管道。
-l 以列表方式显示
-A 和-a的区别就是-A不显示 . 和 …文件夹,其他一样
-t 根据时间排序文件
作者:雪峰流云
来源:CSDN
原文:https://blog.csdn.net/tao_627/article/details/18922795
结果发现家目录下面有一个名为.xsession-errors的文件,一直在写入,并且这个文件特别大。 赶紧上网查了一下这个文件是何方神圣:
图片来自Daniel López Azaña
的博客
博客的大概意思(google翻译)是说:
.xsession-errors文件是X Window系统记录Linux图形环境中发生的所有错误的位置,只要运行了基于X Window的图形化界面,任何图形化界面的应用都可能将错误信息写入这个文件,只要磁盘允许,就会无限增长,任何 Linux发行版都会受到影响。
虽然/etc/X11/Xsession文件中有控制机制,当这个文件超过一定大小,每次启动图形化界面环境时都会清空这个文件,但是并不是所有人的Linux每天都关机,Linux用户可能不重启计算机长达数周甚至数月,因此这个文件可能达到十分庞大的大小。
这个文件通常位于家目录下,它可能导致家目录磁盘配额爆满,甚至,如果在安装系统的时候没有合理的分区,把家目录放在了和根目录一个分区下,它甚至会导致计算机停止工作。
并且作者在博客中给出了以下几种解决办法:
方法0
注意:方法0不是Daniel López Azaña博客中介绍的方法之一,因此以0计数
我对Linux文件截断的理解:当编辑一个已经被另一个进程打开的文件,并保存时,这个文件就会发生截断,直接后果就是这个文件不能再被之前打开的该文件的进程写入。
因此,只要用文本编辑器打开.xsession-errors,并保存退出(而非直接退出),就会发生文件截断,在此次登录回话中,该文件就不能再被X Window写入。
另外:
>.xsession-errors # 或 echo >.xsession-errors
不会造成文件截断,因此不能起到方法0的作用。
方法1
在crontab中添加一个定时任务,定期检查.xsession-errors文件大小,如果超过某个阈值,就清空或者截断它
crontab -e # 编辑crontab定时任务脚本
写入如下内容
- 示例1:每隔15分钟检查一次,如果超过5g,就清空该文件:
*/15 * * * * [ $(du -k .xsession-errors | awk '{ print $1 }') -gt 5000000 ] && >/home/$(whoami)/.xsession-errors
- 示例2:做同样的检查,但是保留最后10000行:
*/15 * * * * [ $(du -k .xsession-errors | awk '{ print $1 }') -gt 5000000 ] && tail -10000 /home/$(whoami)/.xsession-errors > /home/$(whoami)/.xsession-errors
方法2
为.xsession-errors文件设置immutable属性,禁止写入此文件
sudo chattr +i .xsession-errors
方法3
通过软链接将日志转存到/dev/null中
rm .xsession-errors
ln -s /dev/null .xsession-errors
但是这个方法,在重启计算机的时候,这个符号链接就会被常规文件替换,并继续增长。为了避免这种情况出现,可以将以下内容添加到家目录的.bashrc中:
# 如果家目录下的.xsession-errors文件不是软链接,删除并重建软链接
if [ ! -h $HOME/.xsession-errors ]; then
/bin/rm $HOME/.xsession-errors
ln -s /dev/null $HOME/.xsession-errors
fi
方法4
编辑 /etc/X11/Xsession (X Window的配置文件),检索以下内容:
ERRFILE=$HOME/.xsession-errors
修改为:
ERRFILE=/dev/null
即:修改错误日志文件保存路径为/dev/null。当然,也可以把日志保存在别的地方,比如tmpfs文件系统的分区(一般为/tmp目录)下,
保存在这个目录下的文件会在重启系统后删除。但是这又回到了一开始的问题:我们的计算机可能很长时间不关机。
上一篇: java之线程创建的两种方式,六种状态和匿名内部类创建子类或实现类对象
下一篇: Java的内部类