免费注册 查看新帖 |

Chinaunix

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

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

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

论坛徽章:
0
2 [报告]
发表于 2009-08-24 18:09 |只看该作者
每个线程写一个记录文件,并记录时间,然后退出时合并成一个文件就OK了

论坛徽章:
0
3 [报告]
发表于 2009-08-24 18:18 |只看该作者

回复 #1 wflyfox 的帖子

若想不使用锁,则只能使用TSS的方式了。
以上。

论坛徽章:
0
4 [报告]
发表于 2009-08-24 20:00 |只看该作者

回复 #3 cwinux 的帖子

TSS是什么意思?

论坛徽章:
1
申猴
日期:2014-02-11 14:50:31
5 [报告]
发表于 2009-08-25 13:08 |只看该作者
顶起来,我也遇到同样的问题,除了每个线程有一个文件外,还有没有其他方法

论坛徽章:
0
6 [报告]
发表于 2009-08-25 14:16 |只看该作者
各个线程都往一个文件里面写就可以吗。分文件做什么?
不用加任何锁也不会乱的。
写的时候,一个LOG行一次写入(调用一次fprintf,write等)即可。
LOG文件打开时候用append方式,写入是原子的。

每个LOG行头有一个字段是进程/线程号。
如果你想看某个线程的LOG, 一个grep命令就提取出来了。

论坛徽章:
0
7 [报告]
发表于 2009-08-25 14:51 |只看该作者
原帖由 思一克 于 2009-8-25 14:16 发表
各个线程都往一个文件里面写就可以吗。分文件做什么?
不用加任何锁也不会乱的。
写的时候,一个LOG行一次写入(调用一次fprintf,write等)即可。
LOG文件打开时候用append方式,写入是原子的。

每个LOG ...

我是这样用的
搞了个日志缓冲循环表
循环写,只要保证每次调用写日志函数时,缓冲表的索引不重复,就没问题了
这样日志也不会丢,用的挺爽的

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
8 [报告]
发表于 2009-08-25 15:41 |只看该作者
别瞎想,加一个互斥锁,效率丝毫不减, 互斥锁只有在真正出现竞争时,才会等待

论坛徽章:
0
9 [报告]
发表于 2009-08-25 15:48 |只看该作者

回复 #6 思一克 的帖子

我实验一下

论坛徽章:
0
10 [报告]
发表于 2009-08-25 15:48 |只看该作者

回复 #8 cookis 的帖子

写日志的地方比较多,竞争的机会应该蛮大的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP