Nginx+resin調優文檔[原創]

為什么不選擇Apache/mod+resin?
       前面一直使用該模式,
mod_caucho暴露源碼的bug一直未得到徹底的解決。因此切換到Nginx+resin平臺。硬件上要求除了內存一定要足夠大(建議>4G),無其它要求(當然也不能太破,呵呵sweat)。操作系統強烈要求安裝64位,32位操作系統jvm只能識別不到2G的內存,印象中是1.57G(單實例應用)。下面總結自己的一些調優方法及配置。

調優硬件環境

CPU:Intel Xeon*2(雙核)
MEM:8G
SWAP:1G

一、測試32系統所支持的最大可用內存
java -XmxXXXXM -version
不斷加大-Xmx的大小,截止到出現以下提示:
Could not create the Java virtual machine.

二、Nginx配置

   location / {
     root /var/www/app.cn;
     index index.jsp;
     proxy_pass http://localhost:8080;
     include /usr/local/nginx/conf/proxy.conf;
   }
   location ~* \.(jsp|do|shtml)$ {
     root /var/www/app.cn;
     index index.jsp;
     include /usr/local/nginx/conf/proxy.conf;
     proxy_pass http://localhost:8080;
     proxy_set_header X-Real-IP $remote_addr;
   }

      以代理的方式進行整合,靜態文件繼續由Nginx來解析,擴展名為jsp|do|shtml才丟給后端resin來處理。即使resin發現的故障,前端最多只會報500、502 time out的信息。
三、resin配置

1、jvm的優化
#vi $resin_root/bin/httpd.sh

view plainprint?
args="-Xmx6048m -Xms6048m -Xmn2g -Xss128k -XX:NewSize=256m -XX:MaxPermSize=512m -XX:ParallelGCThreads=20 -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:SurvivorRatio=8 -XX:TargetSurvivorRatio=90 -XX:MaxTenuringThreshold=31 -Dsun.net.inetaddr.ttl=60"

    1.1、Xmx與Xms建議配置一致,避免每次垃圾回收完成后JVM 重新分配內存。預留2G左右的內存空間給Nginx與OS就差不多了。
    1.2、Xmn配置成Xmx的1/3。
    1.3、Dsun.net.inetaddr.ttl=60,java對DNS解析域名結果進行緩存,默認超時時間為-1(在重啟JVM前永久緩存),如有涉及域名解析失效需修改該值。

2、resin并發數限制
免費的resin是沒有pro的授權,并發連接數(默認512)配置參數不可見。因此通過修改源碼達到突破限制的目的。
1、修改方法:
    1.1、下載resin3.0.22源碼;
    1.2、修改resin-3.0.22/modules/resin/src/com/caucho/server/port/Port.java 
 

  // default timeout
            private long _timeout = 65000L;
            private int _connectionMax = 512;修改成20480
            private int _minSpareConnection = 16;
            private int _keepaliveMax = -1;
            private int _minSpareListen = 5;
            private int _maxSpareListen = 10;

    1.3、將編譯后的Port.class覆蓋原 /lib/resin.jar包。

2、可以從resin-status結果得到證實
1.png
                                                       [編譯前]
—————————————————————————————————————————
6.png
                                                       [編譯后]

3、resin.conf配置 

<dependency-check-interval>-1</dependency-check-interval>

生產環境建議關閉自檢查 ,原因是會消耗系統一定資源及部分更新會出現不可意料的錯誤。

<!-- Maximum number of threads. -->  
<thread-max>20480</thread-max>

建議與private int _connectionMax參數保持一致。

       其它參數需根據應用的具體情況來調整,如長鏈接超時等。以上為本人整理一些調優筆記,如有遺漏或糾正請與我聯系。

如大家有什么疑問或感興趣的話題可以通過weibo與我交流:http://t.qq.com/yorkoliu

轉自:http://blog.liuts.com/post/204/

原創文章,作者:s19930811,如若轉載,請注明出處:http://www.www58058.com/1757

(0)
s19930811s19930811
上一篇 2015-03-27 18:00
下一篇 2015-03-27 18:04

相關推薦

  • 數據流重導向

    數據流重導向(redirect):就是將某個指令執行后應該要出現在屏幕上的數據,傳輸到其他的位置。 standard output:標準輸出是指指令執行回傳正確的訊息。 standard error output : 指令執行失敗后,所回傳的錯誤訊息。 1標準輸入(stdin):代碼為0,使用< <<2標準輸出(stdout),代碼為1,使…

    Linux干貨 2016-08-08
  • Sed文本文件工具的使用詳解

    Sed文本文件工具的使用詳解 一、概述 sed 工具實際上就是一個非交互式的編輯器,主要是為了處理文本而生的,我們知道處理文本的三劍客是 grep sed awk 我們之前學習過 grep 文本過濾工具,它的主要作用是為了過濾文本,而sed 工具也是過濾文本,只不過sed工具針對的是文件中的每一行,而且sed工具更加強大,下面還具體說明一下sed 工具的原理…

    Linux干貨 2016-10-09
  • 第六周作業

    請詳細總結vim編輯器的使用并完成以下練習題 光標跳轉 字符間跳轉 h或向左箭頭鍵 光標向左移動一個字符 j或向下箭頭鍵 光標向下移動一個字符 k或向上箭頭鍵 光標向上移動一個字符 l或向右箭頭鍵 光標向右移動一個字符 翻屏 Ctrl+f 屏幕向下移動一頁 Ctrl+b 屏幕向上移動一頁 Ctrl+d 屏幕向下移動半頁 Ctrl+u 屏幕向上移動半頁 Ent…

    Linux干貨 2017-01-22
  • 在 Linux 下你所不知道的 df 命令的那些功能

    原文出處: xmodulo   譯文出處:linux.cn – mtunique   歡迎分享原創到運籌維幄 問題: 我知道在Linux上我可以用df命令來查看磁盤使用空間。你能告訴我df命令的實際例子使我可以最大限度得利用它嗎?   對于磁盤存儲方面,有很多命令行或…

    Linux干貨 2015-03-02
  • 系統基礎之AWK詳解

    GUN awk 文本處理三工具:grup,sed,awk     grep,egrep,fgrep:文本過濾工具     sed:行編輯器         模式空間,保持空間   …

    Linux干貨 2016-09-21
欧美性久久久久