1、今天壓力測試時,開始12秒後出現了不少異常, 都是 java.net.NoRouteToHostException: Cannot assign requested address. java
一、首先我這瀏覽器能夠正常訪問接口,排除了是防火牆問題,不是被牆了。linux
二、開發用apacheab能夠進行壓測,而且返回數據良好,排除了是tcpip的的鏈接數問題。apache
若是是這個問題,解決辦法以下:瀏覽器
經網上查資料, 是因爲linux分配的客戶端鏈接端口用盡, 沒法創建socket鏈接所致,雖然socket正常關閉,可是端口不是當即釋放, 而是處於TIME_WAIT狀態, 默認等待60s後才釋放。
查看linux支持的客戶端鏈接端口範圍, 也就是28232個端口:
cat /proc/sys/net/ipv4/ip_local_port_range
32768 - 61000
解決方法:
(1). 調低端口釋放後的等待時間, 默認爲60s, 修改成15~30s
echo 30 > /proc/sys/net/ipv4/tcp_fin_timeout
(2). 修改tcp/ip協議配置, 經過配置/proc/sys/net/ipv4/tcp_tw_resue, 默認爲0, 修改成1, 釋放TIME_WAIT端口給新鏈接使用。
echo 1 > /proc/sys/net/ipv4/tcp_tw_reuse
(3). 修改tcp/ip協議配置,快速回收socket資源, 默認爲0, 修改成1.
echo 1 > /proc/sys/net/ipv4/tcp_tw_recycle
三、最後發現是jmeter的keepalive沒有關閉,這裏是http的keepalive。
這裏消息結束後沒有及時關閉鏈接致使連接不夠用。
關閉後,成功解決。