搜索
java - log4j 远程日志收集的性能问题?
PHP中文网
PHP中文网 2017-04-17 14:19:47
[Java讨论组]

如题,采用log4j 的 socketappender 向远程机发送logEvent, 如果远程机的处理速度慢于客户端日志的产生速度,会造成客户端的阻塞,有没有什么好的解决办法?

PHP中文网
PHP中文网

认证0级讲师

全部回复(2)
ringa_lee

到底是处理速度不够,还是时间都花在了三次握手上了,你是使用的长连接吗?

如果不是因为TCP三次握手问题,建议考虑用一个本地队列进行缓存。

黄舟

谢邀,没用过这个。。

不过你的问题是消费者和产生着的问题我还是可以帮忙下,其实问题的原因找到这里已经是比较简单的了。

就好像超市一样,排队的人太多超市会考虑增加收银员(处理通道),因为大家都用的现金消费给钱找钱(来了就处理)太慢了!超市推出了刷卡消费(延迟处理),什么?我是回民哦!不能和汉民一起结账(特殊的大数据量或是特殊记录),超市会增加了专门一个收银员来处理这样的消费。

其实无非就这么几种办法了
1.增加处理通道
2.缓存到处理的本地队列处理或是用db先存着
3.这个东西没用过不太清楚,不过log一般来说可能会很碎,如果时效不敏感是否可以考虑成批的发送?
4.处理的步骤可以分段处理,这就和你的业务有关了,尽可能的减少及时即用甚至队列处理的速度

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号