定期清理linux服务器日志文件的几个思路

定期清理linux服务器日志文件的几个思路,第1张

定期清理linux服务器日志文件的几个思路

1,在跑批程序中,用java代码调用shell脚本

2,在跑批程序中,用纯java代码实现,也就是使用java的文件 *** 作类File;

3,纯shell脚本方式,使用linux服务器的调度程序调用shell脚本;

结合最近的项目,这里提供一个示例。首先,我们是在跑批项目中实现的定期清理日志功能,

因为我们有跑批项目,使用的是Control M进行调度,所以这种方式还是很方便的。

第一步:写shell脚本

find /home/logs/ -mtime +30 -name "*.log" -exec rm -rf {} \

脚本其实很简单,一行代码就够了,把这个代码放在一个shell文件中,然后放在服务器的

指定目录下,等待java程序调用。

第二步:写java代码,调用shell脚本,示例代码仅提供思路,请大家自己调试

// 设置可执行权限

String commond = "chmod 777 clearLogFileOnTime.sh"

Process proc = Runtime.getRuntime().exec(commond)

proc.waitFor() 

// 执行shell脚本

commond = "bash clearLogFileOnTime.sh"

proc = Runtime.getRuntime().exec(commond)

第三步:配置Control M,进行作业调度

关于Control M的配置不再赘述,主要就是设置跑批程序的执行时间,以及一些其他参数。

查了下资料,也是来自百度

我用centos大概试了一下,需要安装lsof包(yum install lsof),安装完成可以使用lsof命令。lsof全名list opened files,也就是列举系统中已经被打开的文件。

使用命令 lsof | grep deleted

输出:

[root@nginx01 vhost]# lsof |grep deleted

mysqld1140 mysql5u REG 253,001569798 /tmp/ibHYMja2 (deleted)

mysqld1140 mysql6u REG 253,001587795 /tmp/ibNzx1q8 (deleted)

mysqld1140 mysql7u REG 253,001587796 /tmp/ibFtQqLe (deleted)

mysqld1140 mysql8u REG 253,001587797 /tmp/ibPIDS6k (deleted)

mysqld1140 mysql 12u REG 253,001587798 /tmp/ibdkDLFr (deleted)

可以看出/tmp/*这5个文件虽然被删除了,但因为进程未关闭,所以磁盘空间并未释放。

因此,楼主要做的就是kill某些 使用被删除文件的进程。

我猜测重启下服务器应该也行,因为文件肯定被删了,不会再占用空间,不会造成启动故障。

楼主解决后请回复下,我也想学习学习!多交流啊,我是新手!

Linux下DNS缓存实现通常有两种方式:

一种是用DNS缓存程序NSCD(name service cache daemon)负责管理DNS缓存。

一种实现DNS缓存则是用Bind来架设Caching Name Server来实现。

如果是清除NSCD上的Cache,可重新启动NSCD服务来达成清除DNS Cache的效果。用这个命令:

# service nscd restart

或是

#/etc/init.d/nscd restart

如果是清除BIND服务器上的CACHE,用这个命令:

# rndc flush

如果你的DNS服务器是用dnsmasq实现的,用下面这个命令:

$ sudo /etc/init.d/dnsmasq restart

注:DNSmasq是一个轻巧的,容易使用的DNS服务工具,它可以应用在内部网和Internet连接的时候的IP地址NAT转换,也可以用做小型网络的DNS服务。


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

原文地址:https://54852.com/yw/8591661.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存