背景
在對啟動了20個worker的nginx進行壓力測試的時候發(fā)現(xiàn):如果把配置文件中event配置塊中的accept_mutex開關(guān)打開(1.11.3版本之前默認開),就會出現(xiàn)worker壓力不均,少量的worker的cpu利用率達到了98%,大部分的worker的壓力只有1%左右;如果把accept_mutex關(guān)掉,所有的worker的壓力差別就不大,而且QPS會有大幅提升;
分析過程
nginx的 1(master)+N(worker) 多進程模型:master在啟動過程中負責讀取nginx.conf中配置的監(jiān)聽端口,然后加入到一個cycle->listening數(shù)組中。
init_cycle函數(shù)中會調(diào)用init_module函數(shù),init_module函數(shù)會調(diào)用所有注冊模塊的module_init函數(shù)完成相關(guān)模塊所需資源的申請以及其他一些工作;其中event模塊的module_init函數(shù)申請一塊共享內(nèi)存用于存儲accept_mutex鎖信息以及連接數(shù)信息
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動安全 [無線安全]玩轉(zhuǎn)無線電——不安全的藍牙鎖 2017-07-26
- 消息隊列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標分割】 2017-07-26
- 詞向量-LRWE模型-更好地識別反義詞同義詞 2017-07-26
- 從棧不平衡問題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來看看(二) 2017-07-26
我想了解如何學習