免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 11681 | 回复: 23
打印 上一主题 下一主题

[C] 请教linux c多线程系统日志系统的实现 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-08-24 15:51 |只看该作者 |正序浏览
如果用互斥变量的话,IO操作的低效率会降低系统的性能和响应速度。
用什么办法比较好呢?

论坛徽章:
0
24 [报告]
发表于 2009-08-26 08:57 |只看该作者
总结一下:
如果写日志的地方不太多,就按照append+write打开,写完关闭。
如果写日志的地方多,就用一个专门的日志进程,其他进程用某种IPC把要写的内容告诉日志进程,日志进程按照某种逻辑依次写文件。

论坛徽章:
1
申猴
日期:2014-02-11 14:50:31
23 [报告]
发表于 2009-08-25 22:33 |只看该作者
append 就可以了,我做的话还会加个日志池,达到一定量的时候再去写

或者结合数据结构,先全部写到数据结构中,最后一并写

论坛徽章:
0
22 [报告]
发表于 2009-08-25 19:58 |只看该作者
原帖由 fish-fly 于 2009-8-25 19:45 发表
用消息队列或者unix域socket
线程本身不写日志
只需要发到消息队列或者socket中去
让日志子系统一条一条读出来再写好了。。。


如果这样,用PIPE就可以了。PIPE在一定大小的数据的写是原子的。

实际上,用append方式写就挺好的。

论坛徽章:
0
21 [报告]
发表于 2009-08-25 19:45 |只看该作者
用消息队列或者unix域socket
线程本身不写日志
只需要发到消息队列或者socket中去
让日志子系统一条一条读出来再写好了。。。

论坛徽章:
0
20 [报告]
发表于 2009-08-25 17:02 |只看该作者
原帖由 思一克 于 2009-8-25 16:38 发表


我的做法就是有LOG要写了就APPEND打开,写LOG后就关闭。

我有个程序确实是文件记录数据很频繁,所以不想这么做,程序是多进程,每个工作进程又有很多工作线程,
现在只是为每个进程打开文件,在定时器到了rotate log的时候才这么做,程序做过比较大的压力测试确实没发现写交错的情况,
但心里没底,所以想有点理论支持

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
19 [报告]
发表于 2009-08-25 16:47 |只看该作者
原帖由 wflyfox 于 2009-8-25 15:48 发表
写日志的地方比较多,竞争的机会应该蛮大的


那你就该考虑精简单日志了,因为文件IO是很耗资源的

论坛徽章:
0
18 [报告]
发表于 2009-08-25 16:46 |只看该作者
原帖由 zhoubug 于 2009-8-25 16:24 发表

同写一个文件 多次打开不同描述符应该是没问题的 前提是APPEND+write这两个条件,这个在很早前讨论write的原子性是有帖子可以看下。想问下思一克,如果是同一个描述符用write不加锁的情况。这两天看apache的代 ...


这个我不是很清楚。可以写个程序实验看。
估计是。

论坛徽章:
0
17 [报告]
发表于 2009-08-25 16:39 |只看该作者
点错了~~给了某人一蛋蛋

论坛徽章:
0
16 [报告]
发表于 2009-08-25 16:38 |只看该作者
原帖由 zhoubug 于 2009-8-25 16:24 发表

同写一个文件 多次打开不同描述符应该是没问题的 前提是APPEND+write这两个条件,这个在很早前讨论write的原子性是有帖子可以看下。想问下思一克,如果是同一个描述符用write不加锁的情况。这两天看apache的代 ...


我的做法就是有LOG要写了就APPEND打开,写LOG后就关闭。
  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP