LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 895|回复: 3

求教:两个进程间大量数据传输的解决方法

[复制链接]
发表于 2006-6-16 11:11:45 | 显示全部楼层 |阅读模式
两个进程时间,大量的长时间的数据传输。传输过程中,可能时而数据量特别大,时而数据量特别小。接收端,需要实时判断是否有数据传入,如果有责进行处理。

有人建议我用共享内存,但是当数据量过大的时候,可能造成数据堆积,我怕会造成内存消耗过度。

有没有这样一个方法:在数据量较小或者适中的时候,接收方能够及时处理。当数据量较大的时候,能够缓存到硬盘。而对于接收方,都面向一个唯一的接口,不需要考虑读取的数据来自内存还是硬盘。

请各位指点。
发表于 2006-6-17 10:44:54 | 显示全部楼层
你不是自己已经想出方法来了么?呵呵
回复 支持 反对

使用道具 举报

发表于 2006-6-20 10:27:57 | 显示全部楼层
输出重定向至某个临时文件好了,另一端从该文件读入。
就是简单的文件共享而已(处理好一致性问题)。
“接收端,需要实时判断是否有数据传入,如果有责进行处理。”--->用lseek(fd,0,SEEK_CUR)得到当前offset与文件节点inode->current file size比较,就得到是否有新数据。
回复 支持 反对

使用道具 举报

发表于 2006-6-20 11:37:59 | 显示全部楼层
看这种方法行不行
程序分成三部分,A一个提供数据源,直接写入文件
有一个进程B,把数据从文件中读出,然后通过共享内存方式与进程C进行数据传输

这样数据的写入与发送各读取都分开!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表