pandaychen 发表于 2013-06-09 12:55

一种多进程下的设计模式求指教

遇到的场景是这样的,
主进程负责取任务并更新任务的后续状态,主进程取了任务之后fork让子进程去执行(如果有多个任务就fork多次),子进程需要返回结果给主进程,
那么这个就类似于多个消费者,一个生产者问题,用共享内存+信号量即可解决;
但是上面的这种解决办法是需要对共享内存加锁的,所以我想请教下:有无一个更为高效或者成熟的模型,或者实现方法(不仅限于共享内存),来解决此类问题?


之前有想过用sockpair这种方式来做,感觉不是很高效,所以就想问下在C里面这种问题的解决思路:)

linux_c_py_php 发表于 2013-06-09 14:05

建议多线程 或者 socket通信,不要使用共享内存以及共享内存锁。

cxytz01 发表于 2013-06-09 16:52

回复 2# linux_c_py_php

不要使用共享内存以及共享内存锁。 --求解


   

linux_c_py_php 发表于 2013-06-11 17:49

cxytz01 发表于 2013-06-09 16:52 static/image/common/back.gif
回复 2# linux_c_py_php

不要使用共享内存以及共享内存锁。 --求解

1, 扩展性差, 共享内存和分布式是冲突的.
2, 共享内存容易被破坏, 比如突然掉电, 进程崩溃, 很容易死锁或者内容破损, 无法恢复.
页: [1]
查看完整版本: 一种多进程下的设计模式求指教