15

Mac OS X 10.8.3 で siege から次のコマンドを実行しようとしているときに、この問題が発生しました。

siege -d1 -c 20 -t2m -i -f -r10 urls.txt

Siege からの出力は次のとおりです。

** SIEGE 2.74
** Preparing 20 concurrent users for battle.
The server is now under siege...
done.
siege aborted due to excessive socket failure; you
can change the failure threshold in $HOME/.siegerc

Transactions:                  0 hits
Availability:               0.00 %
Elapsed time:              27.04 secs
Data transferred:           0.00 MB
Response time:              0.00 secs
Transaction rate:           0.00 trans/sec
Throughput:             0.00 MB/sec
Concurrency:                0.00
Successful transactions:           0
Failed transactions:            1043
Longest transaction:            0.00
Shortest transaction:           0.00

FILE: /usr/local/var/siege.log
You can disable this annoying message by editing
the .siegerc file in your home directory; change
the directive 'show-logfile' to false.
4

1 に答える 1

7

問題は、一時ポートが不足している可能性があります。これを改善するには、使用するポートの数を増やすか、ポートが TIME_WAIT に留まる時間を減らすか、またはその両方を行います。

使用可能なポートを展開します。

現在の設定を確認します。

$ sudo sysctl net.inet.ip.portrange.hifirst

net.inet.ip.portrange.hifirst: 49152

ウィンドウを拡大するには、それを低く設定します。

$ sudo sysctl -w net.inet.ip.portrange.hifirst=32768

net.inet.ip.portrange.hifirst: 49152 -> 32768

(hilast は既に最大の 65536 になっているはずです)

セグメントの最大存続期間を短縮する

$ sudo sysctl -w net.inet.tcp.msl=1000

net.inet.tcp.msl: 15000 -> 1000

于 2013-07-24T00:13:14.950 に答える