程序是作業系統分配資源(cpu時間、記憶體)的基本單位,執行緒是排程執行的基本單元。乙個執行緒必定屬於乙個程序,乙個程序可包含多個執行緒。
nginx、redis是常見的多程序模型,tomcat、memcached是多執行緒模型。
多程序資料共享複雜,需要用管道,訊號,訊息佇列,共享記憶體,套接字等通訊機制,但資料同步簡單,而多執行緒共享程序資料段,資料共享簡單,但同步複雜。
多程序占用記憶體多、建立、銷毀切換複雜,cpu利用率低,而多執行緒占用記憶體小,建立銷毀、切換簡單、速度快。
多程序程式設計除錯簡單、程序間不會互相影響,適用於多核多機分布式,擴充套件到多台機器時簡單,而多執行緒程式設計除錯複雜,乙個執行緒掛掉可能影響整個程序,適用於多核分布式。
需要頻繁建立銷毀、需要大量計算、切換頻繁、多核分布時優先使用執行緒,需要更穩定安全、支援多機分布時適合選擇程序。
對比維度
多程序
多執行緒
總結
資料共享、同步
資料共享複雜,需要用ipc;資料是分開的,同步簡單
因為共享程序資料,資料共享簡單,但也是因為這個原因導致同步複雜
各有優勢
記憶體、cpu
占用記憶體多,切換複雜,cpu利用率低
占用記憶體少,切換簡單,cpu利用率高
執行緒佔優
建立銷毀、切換
建立銷毀、切換複雜,速度慢
建立銷毀、切換簡單,速度很快
執行緒佔優
程式設計、除錯
程式設計簡單,除錯簡單
程式設計複雜,除錯複雜
程序佔優
可靠性程序間不會互相影響
乙個執行緒掛掉將導致整個程序掛掉
程序佔優
分布式適應於多核、多機分布式;如果一台機器不夠,擴充套件到多台機器比較簡單
適應於多核分布式
程序佔優
多程序多執行緒的選擇
關於多程序和多執行緒,教科書上最經典的一句話是 程序是資源分配的最小單位,執行緒是cpu排程的最小單位 這句話應付考試基本上夠了,但如果在工作中遇到類似的選擇問題,那就沒有這麼簡單了,選的不好,會讓你深受其害。經常在網路上看到有的xdjm問 多程序好還是多執行緒好?linux下用多程序還是多執行緒?...
多程序與多執行緒的選擇 轉
程序是具有一定獨立功能的程式關於某個資料集合上的一次執行活動,程序是系統進行資源分配和排程的乙個獨立單位。執行緒是程序的乙個實體,是cpu排程和分派的基本單位,它是比程序更小的能獨立執行的基本單位。執行緒自己基本上不擁有系統資源,只擁有一點在執行中必不可少的資源 如程式計數器,一組暫存器和棧 但是它...
多執行緒 多程序?
這幾天在思考如何改進原型在多個客戶端的情況下的效能,特地溫習了一下多程序和多執行緒的一些知識。在linux下程序的程序和執行緒在核心看來區別很小,都是乙個可排程單元,都擁有記憶體管理結構等等。但是關鍵的差別是程序的資源都是私有的,而執行緒則是和別人共享的,所以執行緒的上下文切換可能比程序的開銷要小很...