如何使用linux日志管理工具来管理oracle osb服务器日志文件?

​场景:做一个OSB项目,生产环境每天至少有几十万次接口调用,因报文量大,数据库存储容量有限,也因早期接口问题较多,所以osb上的每个接口都会把接收到的数据打到log文件中(接口数据打印到log统一由模板实现),便于查找问题,这就导致集群上每台服务器每天的log大小都超过1g,甚至多的话一天一台服务器就有10多G的日志产生,而weblogic服务器中的日志配置不能对*.out类型的日志文件进行控制,且也不支持日志压缩,造成服务器硬盘空间浪费

为此,我们找到了一种方法,就是使用linux自带的日志管理工具logrotate来管理osb服务器上的日志文件,实现步骤如下:

在目录/etc/logrotate.d/下创建文件osb_log

文件内容如下:

DOMAIN/servers/\*/logs/\*.\[o\|l\]\[u\|o\]\[t\|g\] DOMAIN/servers/*/logs/*.[o|l][u|o][t|g]?????

{

daily

rotate 30

copytruncate

compress

delaycompress

missingok

dateext

notifempty

create 644 oracle oracle

prerotate

find $DOMAIN/servers/*/logs -type f \( -iname '*.log*' -o -iname '*.out*' \) -mtime +30|xargs rm -rf

find $DOMAIN/servers/*/logs/ \( -iname '*.log?*' -o -iname '*.out?*' \) -type f -size 0c -mtime +1 | xargs rm -rf

endscript

postrotate

/usr/bin/killall -HUP rsyslogd

endscript

}

保存即可,剩下的事交由系统去处理。

脚本实现的功能:每天把osb domain中的所有admin服务和受管服务下的log进行截断并压缩,同时清除30天前的日志记录

脚本适用环境:linux5.4及以上版本的操作系统,5.4以前的操作系统没经过测试(测试发现脚本日志文件地址的查找在linux5.4版本中支持正则表达式,而linux6.6的版本则只支持通配符方式)

效果:日志文件压缩率达到90%,记得一下子就腾出了50多G的硬盘空间出来

相关推荐
我梦之612 小时前
libevent输出缓存区的数据
服务器·网络·c++·缓存
春生野草12 小时前
MobaXterm远程连接云服务器及配置jdk、Tomcat环境
运维·服务器
一人の梅雨12 小时前
京东商品详情深度解析:从接口调用到商业价值挖掘的技术实现
服务器·数据库·php
月墨江山13 小时前
Ubuntu 20.04 使用 Issac Gym 进行宇树G1人形机器人进行强化学习训练(Linux仿真)
linux·ubuntu·机器人
养生技术人13 小时前
Oracle OCP认证考试题目详解082系列第49题
运维·数据库·sql·oracle·database·开闭原则·ocp
wanhengidc14 小时前
云手机的挂机功能涉及到哪些内容
运维·服务器·网络·游戏·智能手机
菜鸟plus+14 小时前
ElasticSearch
运维·jenkins
努力的白熊嗨14 小时前
多台服务器文件共享存储
服务器·后端
天朝八阿哥14 小时前
关于xfce4-pulseaudio-plugin中文翻译的bug
linux·debian
西贝爱学习14 小时前
【软件】nginx-1.28.0安装包(Windows版)
运维·nginx