背景

     在對(duì)啟動(dòng)了20個(gè)worker的nginx進(jìn)行壓力測(cè)試的時(shí)候發(fā)現(xiàn):如果把配置文件中event配置塊中的accept_mutex開關(guān)打開(1.11.3版本之前默認(rèn)開),就會(huì)出現(xiàn)worker壓力不均,少量的worker的cpu利用率達(dá)到了98%,大部分的worker的壓力只有1%左右;如果把a(bǔ)ccept_mutex關(guān)掉,所有的worker的壓力差別就不大,而且QPS會(huì)有大幅提升;

 

分析過程

  1. nginx的 1(master)+N(worker) 多進(jìn)程模型:master在啟動(dòng)過程中負(fù)責(zé)讀取nginx.conf中配置的監(jiān)聽端口,然后加入到一個(gè)cycle->listening數(shù)組中。

  2. init_cycle函數(shù)中會(huì)調(diào)用init_module函數(shù),init_module函數(shù)會(huì)調(diào)用所有注冊(cè)模塊的module_init函數(shù)完成相關(guān)模塊所需資源的申請(qǐng)以及其他一些工作;其中event模塊的module_init函數(shù)申請(qǐng)一塊共享內(nèi)存用于存儲(chǔ)accept_mutex鎖信息以及連接數(shù)信息

      <li id="grzef"></li>

        網(wǎng)友評(píng)論