【激速】mod_perl Spe ..
371:355
06/07/01 12:15:04
ab -n 100 -c 10
CGI c CGI perl perlcc -B SpeedyCGI mod_speedycgi fastcgi c fastcgi perl Registry PerlRun html
1回目 80.35 24.59 12.53 32.28 112.21 181.51 79.98 7.38 7.14 287.30
2回目 76.72 24.56 12.80 34.48 121.06 182.21 121.81 74.02 44.14 278.04
3回目 79.79 24.38 12.74 33.25 119.92 181.57 120.37 85.51 42.99 280.69
4回目 76.24 24.42 13.22 33.15 122.28 179.48 121.18 85.56 30.75 287.75
5回目 76.19 24.48 12.75 33.24 116.35 182.61 118.93 87.59 48.18 288.21
平均 77.86 24.49 12.81 33.28 118.36 181.48 112.45 68.01 34.64 284.40
Requests per second
372:355
06/07/01 12:17:41
ab -n 100 -c 10
CGI c CGI perl perlcc -B SpeedyCGI mod_speedycgi fastcgi c fastcgi perl Registry PerlRun html
1回目 80.35 24.59 12.53 32.28 112.21 181.51 79.98 7.38 7.14 287.30
2回目 76.72 24.56 12.80 34.48 121.06 182.21 121.81 74.02 44.14 278.04
3回目 79.79 24.38 12.74 33.25 119.92 181.57 120.37 85.51 42.99 280.69
4回目 76.24 24.42 13.22 33.15 122.28 179.48 121.18 85.56 30.75 287.75
5回目 76.19 24.48 12.75 33.24 116.35 182.61 118.93 87.59 48.18 288.21
平均 77.86 24.49 12.81 33.28 118.36 181.48 112.45 68.01 34.64 284.40
Requests per second
373:355
06/07/01 12:18:55
すいません。
>371と>372は同じものです。
374:355
06/07/01 12:31:33
ab -n 200 -c 20
CGI c CGI perl perlcc -B SpeedyCGI mod_speedycgi fastcgi c fastcgi perl Registry PerlRun html
1回目 78.10 24.62 12.69 31.51 114.04 184.03 95.03 10.00 8.64 292.87
2回目 81.17 24.66 12.73 33.03 119.16 185.93 118.80 90.98 55.16 293.11
3回目 77.62 24.74 13.25 32.99 114.92 192.23 119.23 79.47 44.99 280.26
4回目 78.70 24.81 12.88 32.10 118.08 188.86 119.64 77.49 48.46 286.11
5回目 79.50 24.73 12.98 33.11 115.42 182.41 117.86 62.33 46.55 284.11
平均 79.02 24.71 12.91 32.55 116.32 186.69 114.11 64.05 40.76 287.29
Requests per second
375:355
06/07/01 12:33:33
ab -n 400 -c 40
CGI c CGI perl perlcc -B SpeedyCGI mod_speedycgi fastcgi c fastcgi perl Registry PerlRun html
1回目 80.57 24.42 12.50 31.78 110.56 176.86 100.96 16.91 12.96 293.94
2回目 80.33 24.47 12.56 33.84 118.34 180.34 113.21 21.93 23.52 287.48
3回目 78.31 25.03 12.71 32.34 116.58 183.24 110.40 81.42 55.92 300.39
4回目 79.41 25.16 12.49 33.90 124.34 183.00 106.40 75.04 56.51 293.20
5回目 77.44 24.50 12.55 32.24 120.68 183.12 109.45 81.47 46.63 300.58
平均 79.21 24.72 12.56 32.82 118.10 181.31 108.08 55.35 39.11 295.12
Requests per second
376:355
06/07/01 12:38:01
ab -n 1000 -c 100
CGI c CGI perl perlcc -B SpeedyCGI mod_speedycgi fastcgi c fastcgi perl Registry PerlRun html
1回目 78.12 24.91 12.97 30.99 91.33 174.89 92.12 20.86 16.17 287.40
2回目 80.17 25.31 12.80 32.12 109.90 174.87 94.91 25.45 18.14 281.79
3回目 78.44 24.65 12.57 32.41 112.69 170.94 101.65 46.86 54.87 274.96
4回目 78.01 23.84 12.96 32.05 113.81 166.39 102.72 95.56 46.12 283.29
5回目 78.69 24.87 12.52 32.35 113.24 166.31 101.21 74.98 34.28 283.35
平均 78.69 24.72 12.76 31.98 108.19 170.68 98.52 52.74 33.92 282.16
Requests per second
377:355
06/07/01 12:40:23
ab -n 1500 -c 150
CGI c CGI perl perlcc -B SpeedyCGI mod_speedycgi fastcgi c fastcgi perl Registry PerlRun html
1回目 76.39 24.19 12.50 31.27 99.27 172.32 88.22 18.96 17.69 275.84
2回目 72.94 24.22 12.56 31.99 112.01 166.82 96.86 27.05 21.28 277.10
3回目 73.62 24.78 12.62 32.71 114.98 163.69 97.89 71.29 40.18 273.88
4回目 73.88 23.90 12.61 32.49 112.21 164.86 98.73 75.77 21.71 256.73
5回目 74.24 24.13 12.69 33.07 114.19 167.17 98.56 75.81 40.84 255.67
平均 74.21 24.24 12.60 32.31 110.53 166.97 96.05 53.78 28.34 267.84
Requests per second
378:355
06/07/01 12:42:34
ab -n 2000 -c 200
CGI c CGI perl perlcc -B SpeedyCGI mod_speedycgi fastcgi c fastcgi perl Registry PerlRun html
1回目 75.00 24.42 12.59 31.47 109.51 170.30 87.57 21.46 17.50 250.27
2回目 75.09 24.05 12.51 31.69 116.31 169.27 91.84 37.49 32.77 261.21
3回目 73.87 24.67 12.60 32.76 113.69 164.81 92.60 74.82 46.47 260.43
4回目 73.51 24.43 12.59 32.68 113.51 170.00 92.98 74.82 45.72 260.72
5回目 73.26 24.08 12.88 32.72 112.25 165.43 93.40 71.43 43.67 261.65
平均 74.15 24.33 12.63 32.26 113.05 167.96 91.68 56.00 37.23 258.86
Requests per second
379:355
06/07/01 12:43:06
以上、報告終わり。
380:nobodyさん
06/07/01 12:44:06
平均は真ん中3つも出してくれよ。
381:355
06/07/01 12:56:02
>>380
了解
今から出します。
382:355
06/07/01 13:07:11
MAX、MINを除外した平均値
CGI c CGI perl perlcc -B SpeedyCGI mod_speedycgi fastcgi c fastcgi perl Registry PerlRun html
ab -n 10 -c 1 81.72 26.77 13.86 36.29 118.88 180.88 121.80 95.51 41.18 270.26
ab -n 100 -c 10 77.58 24.49 12.76 33.21 119.11 181.76 120.16 81.70 39.29 285.25
ab -n 200 -c 20 78.77 24.71 12.86 32.71 116.14 186.27 118.63 73.10 46.67 287.70
ab -n 400 -c 40 79.35 24.67 12.54 32.81 118.53 182.15 108.75 59.46 42.02 295.84
ab -n 1000 -c 100 78.42 24.81 12.78 32.17 111.94 170.73 99.26 49.10 32.85 282.81
ab -n 1500 -c 150 73.91 24.18 12.60 32.40 112.80 166.28 97.77 58.04 27.72 268.82
ab -n 2000 -c 200 74.13 24.31 12.59 32.36 113.15 168.23 92.47 61.25 40.72 260.79
Requests per second
383:nobodyさん
06/07/01 13:13:38
うわ、ありがとうございます。
やっぱり不安定なやつの救済にはならなかったかorz
384:355
06/07/01 13:29:33
MAX、MINを除外した平均値(データ数2以下の場合通常の平均)
prefork
nicky.cgi改
CGI perlcc -B SpeedyCGI mod_speedycgi fastcgi Registry PerlRun html
ab -n 10 -c 1 0.45 1.24 7.03 8.39 7.61 8.08 0.36 239.77
ab -n 100 -c 10 0.45 1.22 6.58 8.00 7.60 4.76 0.23 253.31
ab -n 200 -c 20 abort all 1.19 6.54 7.91 7.59 2.06 abort all 259.89
ab -n 400 -c 40 abort all 1.17 6.45 7.78 7.32 1.11 abort all 257.71
ab -n 1000 -c 100 abort all 1.16 6.42 7.70 7.17 3.05 abort all 244.45
ab -n 1500 -c 150 abort all abort all 6.35 7.65 6.85 3.75 abort all 231.70
ab -n 2000 -c 200 abort all 1.17 4.22 7.71 6.87 6.48 abort all 230.92
Requests per second
385:355
06/07/01 13:38:10
MAX、MINを除外した平均値(データ数2以下の場合通常の平均)
worker
nicky.cgi改
CGI perlcc -B SpeedyCGI fastcgi Registry PerlRun html
ab -n 10 -c 1 0.45 1.24 6.91 7.50 7.88 0.34 221.72
ab -n 100 -c 10 0.45 1.21 6.44 7.49 4.14 0.33 242.03
ab -n 200 -c 20 abort all 1.19 6.37 7.37 3.69 0.22 239.23
ab -n 400 -c 40 abort all 1.17 6.36 7.24 1.39 0.12 233.45
ab -n 1000 -c 100 abort all 1.17 6.50 7.08 3.16 abort all 214.85
ab -n 1500 -c 150 abort all 1.18 6.50 6.75 3.70 abort all 217.76
ab -n 2000 -c 200 abort all 1.19 6.29 6.89 3.85 abort all 219.70
Requests per second
386:nobodyさん
06/07/01 13:40:29
>>335
またまた、ご苦労様です。
これだけあると、見るのも大変だけど、作る方は、もっと大変なんでしょうね。(^^;
これを見ると、mod_perl,fastcgiは、同時接続数が増えた際のレスポンスの落ち込みが
他と比べて大きいですね。
fastcgiでは、大きなソースだと、その差が見えずらくなりますが。
この中では、fastcgi cが一番速いですが、cで書くんだったら、fastcgiを使わずに
module作った方が良いかなと言う気もします。
開発・導入コスト、スピード、メンテナンス性を考えると、Apache API 使いたいとか
言うのでなければ、mod_speedycgiって、とても良い選択肢ですね。
387:nobodyさん
06/07/01 13:57:12 HcFO9A5X BE:309277-#
よくわかってないのですが、
mod_speedycgiとspeedy(perperl)って何が違うんですか?
388:355
06/07/01 14:00:16
>>386
mod_speedycgiは1つだけ欠点が。
worker環境では動きませんでした。
運用可能なのは、Apache1(確認)とApache2のprefork(確認)のみと思われます。
389:nobodyさん
06/07/01 14:12:54
>>387
SpeedyCGIは
httpd→SpeedyCGIフロントエンド起動→SpeedyCGIバックエンド呼び出し
こういう感じになります。
mod_speedycgiはSpeedyCGIフロントエンドがアパッチプロセスに埋め込まれて常駐します。
httpd内でSpeedyCGIフロントエンド呼び出し→SpeedyCGIバックエンド呼び出し
こういう感じかな。
小さいソースでSpeedyCGIが伸びないところをみると、SpeedyCGIフロントエンド起動はコストが高いのかも(インタープリタ起動のコストの2/3ぐらい?)。
390:nobodyさん
06/07/01 20:49:09
パフォーマンス悪かろうが何だろうが、それでも mod_perl を使うけどな(´Д`)
391:nobodyさん
06/07/01 21:20:12
mod_perlはApache Software Foundationのお膝元ってのが大きい。
392:nobodyさん
06/07/01 21:28:46
>>390
それはそれで個人の自由だからいいんでない。
393:nobodyさん
06/07/01 21:47:44
>>389
Hello Worldで、SpeedyCGIが伸びないのは、mod_cgi経由だからかなという気がしています。
perlを使うと言う前提で考えれば、通常のcgiと比較して、何が省略できて、逆に何が余分に
掛かるのかと言う話なんですよね、多分。
mod_cgiを通すから、コストが掛かるのか、純粋にspeedyの起動に時間が掛かるのかは分か
らないのですが。
mod_perlが同時接続数が増えると成績悪くなるのは、余分に掛かるものが、無視できなくなっ
たためなのかな。
ちなみに、両方のテストと共、PerlRunには酷なテストでしたね。
大元のスクリプトのは毎回呼び出すけど、useしたものはメモリーに置くという方式なので、
速度的にメリットを出せる部分が全然使われてません。
意味がなくても、use CGI;use DBI;use Templateあたりを追加したHelloWorldなソースで比
べると、CGIよりも良い成績が出るのではないかと思っています。
大きなソースの場合、アプリの機能を、ほとんどモジュール側に持って行けば、それなりに
速くなる筈です。殆どの機能をモジュール側に持って行ったら、PerlRun使わずに、Registry
使えよという話になるんですが。
まあ、このPerlRunとCGIの差が、mod_perlを使った際に、余分に掛かる物の量なんでしょうね。
394:355
06/07/01 22:37:21
>>393
> 意味がなくても、use CGI;use DBI;use Templateあたりを追加したHelloWorldなソースで比
> べると、CGIよりも良い成績が出るのではないかと思っています。
useしたものはメモリーに置くということは知りませんでした。
基本的にできるだけ同じ条件で取る方向で測定したので、知っていても同じ条件で取ったと思います。
インタープリタをプロセス内にあることのアドバンテージは起動コストの高い>382で出ていると思います。(hello world)
395:355
06/07/01 22:40:01
×インタープリタを
○インタープリタが
396:nobodyさん
06/07/01 23:38:12
mod_perlではスワップ発生してたりしないかな?
397:393
06/07/02 00:05:08
>>394
> useしたものはメモリーに置くということは知りませんでした。
出鱈目な事を言っているといけないので、資料を当たってみました。
下記の "Apache::PerlRun--a closer look" が参考になると思います。
URLリンク(perl.apache.org)
という事で、スクリプトの書き方によって、PerlRunもRegistryに近い速度を出せるそうです。
まあ、ベンチを取る時に、全体のコード量と、useする比率をどの程度にするのが妥当かと
いうのは、非常に難しい問題なのですが。
398:355
06/07/02 00:14:54
>>396
>mod_perlではスワップ発生してたりしないかな?
一応ベンチ取ったときに書き込みましたが、長すぎて読みにくかったかな。
>384の場合のみ発生しています。
Registryは-c 40からPerlRunは-c 100からです。
399:355
06/07/02 01:06:21
すいません。
一部訂正。
エクセルを使ったMAX、MINを除外した平均値の算出に誤り。
=IF(COUNT(B3:B7)>2,(SUM(B3:B7)-MAX(B3:B7)-MIN(B3:B7))/3,AVERAGE(B3:B7))
データが4点の場合2で割らないといけませんが、3の決めうちで割ってしまっています。
=IF(COUNT(B3:B7)>2,(SUM(B3:B7)-MAX(B3:B7)-MIN(B3:B7))/(COUNT(B3:B7)-2),AVERAGE(B3:B7))
でデータ数-2で割るように修正したデータを載せます。
>382、>384、>385のうち>382だけはこの影響は受けません。
ABORTがないため3の決めうちで問題ないからです。
不注意申し訳ないです。
400:355
06/07/02 01:18:46
MAX、MINを除外した平均値
prefork
nicky.cgi改
CGI perlcc -B SpeedyCGI mod_speedycgi fastcgi Registry PerlRun html
ab -n 10 -c 1 0.45 1.24 7.03 8.39 7.61 8.08 0.36 239.77
ab -n 100 -c 10 0.45 1.22 6.58 8.00 7.60 4.76 0.34 253.31
ab -n 200 -c 20 abort all 1.19 6.54 7.91 7.59 3.09 abort all 259.89
ab -n 400 -c 40 abort all 1.17 6.45 7.78 7.32 1.11 abort all 257.71
ab -n 1000 -c 100 abort all 1.16 6.42 7.70 7.17 3.05 abort all 244.45
ab -n 1500 -c 150 abort all abort all 6.35 7.65 6.85 3.75 abort all 231.70
ab -n 2000 -c 200 abort all 1.17 6.33 7.71 6.87 6.48 abort all 230.92
Requests per second
401:355
06/07/02 01:27:29
MAX、MINを除外した平均値(データ数2以下の場合通常の平均)
worker
nicky.cgi改
CGI perlcc -B SpeedyCGI fastcgi Registry PerlRun html
ab -n 10 -c 1 0.45 1.24 6.91 7.50 7.88 0.34 221.72
ab -n 100 -c 10 0.45 1.21 6.44 7.49 4.14 0.33 242.03
ab -n 200 -c 20 abort all 1.19 6.37 7.37 5.54 0.33 239.23
ab -n 400 -c 40 abort all 1.17 6.36 7.24 4.17 0.35 233.45
ab -n 1000 -c 100 abort all 1.17 6.50 7.08 4.75 abort all 214.85
ab -n 1500 -c 150 abort all 1.18 6.50 6.75 5.55 abort all 217.76
ab -n 2000 -c 200 abort all 1.19 6.29 6.89 5.78 abort all 219.70
Requests per second
402:nobodyさん
06/07/02 03:23:34
最後にlighttpd+FastCGI
K6-2 475MHz
512MB
Vine3.2最小インストール+コンパイル環境
+lighttpd-1.4.11ソース+fcgi-2.4.0ソース
テストソース hello world(>367-368)
fast_hello.pl、nicky.cgi改はFastCGIソース
hello.html、nicky.htmlは同等のhtml
以下、結果報告。
403:nobodyさん
06/07/02 03:24:37
ab -n 10 -c 1
fast_hello.pl nicky.cgi改 hello.html nicky.html
1回目 80.17 7.43 404.65 294.84
2回目 80.22 7.50 438.85 290.78
3回目 81.09 7.50 433.39 294.58
4回目 82.52 7.59 403.80 284.79
5回目 82.24 7.60 443.26 299.15
3点平均 81.18 7.53 425.63 293.40
Requests per second
ab -n 100 -c 10
fast_hello.pl nicky.cgi改 hello.html nicky.html
1回目 82.15 7.37 545.05 419.07
2回目 81.17 7.45 581.38 362.70
3回目 81.97 7.40 558.21 375.57
4回目 78.28 7.44 577.86 394.92
5回目 80.37 7.47 548.81 422.58
3点平均 81.17 7.43 561.63 396.52
Requests per second
ab -n 200 -c 20
fast_hello.pl nicky.cgi改 hello.html nicky.html
1回目 79.99 7.50 554.36 399.54
2回目 79.05 7.47 530.38 394.03
3回目 79.49 7.44 540.64 391.67
4回目 81.20 7.48 488.14 410.85
5回目 80.41 7.42 532.57 371.96
3点平均 79.96 7.46 534.53 395.08
Requests per second
404:402
06/07/02 03:27:00
ab -n 400 -c 40
fast_hello.pl nicky.cgi改 hello.html nicky.html
1回目 80.74 7.38 501.38 385.98
2回目 80.67 7.38 538.61 389.09
3回目 81.04 7.38 524.94 388.81
4回目 81.28 7.39 530.10 364.66
5回目 81.20 7.39 547.67 386.51
3点平均 80.99 7.38 531.22 387.10
Requests per second
ab -n 1000 -c 100
fast_hello.pl nicky.cgi改 hello.html nicky.html
1回目 79.60 7.16 523.19 386.82
2回目 80.89 6.91 532.83 394.17
3回目 80.15 6.83 559.98 403.73
4回目 81.76 6.95 527.91 386.09
5回目 80.55 7.17 548.08 387.12
3点平均 80.53 7.01 536.27 389.37
Requests per second
ab -n 1500 -c 150
fast_hello.pl nicky.cgi改 hello.html nicky.html
1回目 73.97 6.97 531.91 390.80
2回目 74.34 6.50 546.51 392.37
3回目 74.77 6.94 528.98 393.63
4回目 73.94 6.52 520.37 392.40
5回目 73.49 6.96 541.37 387.22
3点平均 74.08 6.81 534.09 391.86
Requests per second
405:402
06/07/02 03:33:58
ab -n 2000 -c 200
fast_hello.pl nicky.cgi改 hello.html nicky.html
1回目 72.94 6.76 508.09 387.18
2回目 72.54 6.75 519.62 387.63
3回目 72.72 6.77 517.59 383.83
4回目 72.96 6.43 528.62 381.39
5回目 72.59 6.27 509.80 388.59
3点平均 72.75 6.65 515.67 386.21
Requests per second
406:402
06/07/02 03:38:35
MAX、MINを除外した平均値
lighttpd
hell world、nicky.cgi改
fast_hello.pl nicky.cgi改 hello.html nicky.html
ab -n 10 -c 1 81.18 7.53 425.63 293.40
ab -n 100 -c 10 81.17 7.43 561.63 396.52
ab -n 200 -c 20 79.96 7.46 534.53 395.08
ab -n 400 -c 40 80.99 7.38 531.22 387.10
ab -n 1000 -c 100 80.53 7.01 536.27 389.37
ab -n 1500 -c 150 74.08 6.81 534.09 391.86
ab -n 2000 -c 200 72.75 6.65 515.67 386.21
Requests per second
407:402
06/07/02 03:39:08
以上、報告終了。
408:nobodyさん
06/07/02 03:41:42
>>390
メモリ食うからpreforkだと起動コストが高くなるってだけ。workerにすればmod_perlが最速。
・・・だといいな。
409:nobodyさん
06/07/02 06:47:26 rDIMAYNl
はげしく乙です!!!!!!!!!!!!!!!!!! >>407
410:nobodyさん
06/07/02 06:48:00 rDIMAYNl
すごすぎて、もう一回書いちゃおう。
禿げ上がるほど乙です!!! >>407
411:nobodyさん
06/07/02 10:25:42
>>402
お疲れ様でした。
lighttpdの静的コンテンツの出力は、噂通りに速いですね。
ただ、FastCGIのhelloWorldな動的コンテンツでは、Apacheの方が速い。
でも、この差はソースが大きくなると見えなくなるので、実質問題にならない
差ですね。
RoR界隈では、lighttpd+FastCGIが流行っている様ですが、動的コンテンツ
の速度はApacheとほとんど同じだけど、静的コンテンツの速度が速いので
トータルで速くなると言う事なのか、インストールが簡単なのか、それとも他
の理由があるのか、どうなんでしょう。
ところで、lighttpdは、普通のcgiは出来ないんでしょうか?
412:402
06/07/02 11:51:36
>>411
lighttpdは普通のcgiもできます。
測定しなかったのは興味がなかったのと、遅いので時間がかかるのがいやというだけです。
ちょっとワガママが入ってます。
413:nobodyさん
06/07/02 12:07:51
>>412
通常のCGIは、どうでも良かったりしますが、lighttpd + SpeedyCGIは興味があるかなと。
414:402
06/07/02 12:13:08
>>413
了解です。
lighttpd + SpeedyCGIも追加します。
415:nobodyさん
06/07/02 15:51:41
測定に使ってるマシンのスペックはどうなんだろう。ターゲットマシンだけじゃなくて、クライアントのPCもそれなりに高性能じゃないといけないと思うけど。
416:nobodyさん
06/07/02 16:01:25
ポカーン
417:nobodyさん
06/07/02 16:38:15 BE:212257038-#
"差"を計ってるのにスペックとな
418:nobodyさん
06/07/02 16:46:53
(○口○*) ポーカン
419:nobodyさん
06/07/02 18:19:12
>>415
クライアントの差が出るとすると、-c 1 より -c 10 の方が高い成績を出している
l静的コンテンツ取得の所位じゃない?
リクエストの応答を受けてから、次のリクエストまでの時間を多少稼げる。
ただ、動的コンテンツ取得については、さほど意味のある値ではないと思う。
420:402
06/07/02 20:18:01
>>415
すいません。
急用で外出していました。
測定条件の記入漏れです。
localhostで測定しています。
つまり、サーバーマシン=クライアントマシンです。
421:nobodyさん
06/07/02 20:37:17
abってすごく負荷かかるんだよ。ターゲットマシンとサーバマシンは分けるのが普通。
まあ、簡易に測定する場合は同一マシンでやっちゃうこともあるけど。
422:nobodyさん
06/07/02 21:00:23
分けてもカニるチップなLANカードじゃパケットの取りこぼしと再送の誤差が入るし。
423:402
06/07/02 21:05:35
すいません。
まずかったかな。
424:402
06/07/02 21:18:01
まあ、あれこれ言っても今更仕方がないし傾向をみるためだけのものと思ってください。
どのみちベンチは個々の環境に左右されるので。
後、もう少し待ってください。
lighttpdのSpeedyCGIとCGIのベンチ終わります。
425:nobodyさん
06/07/02 21:32:03
別にいいんでね?>localhost
マシンの性能計ってるわけじゃないし
426:nobodyさん
06/07/02 22:04:59
エビにどれだけ喰われてるかが気になるが、
427:nobodyさん
06/07/02 22:13:04
200クライアントとか安ルータでは厳しい。
428:nobodyさん
06/07/02 22:15:55
直結でもしない限り、ルータでレスポンス低下とかね。
429:nobodyさん
06/07/02 22:20:09
K6-2 475MHz
512MB
Vine3.2最小インストール+コンパイル環境
+lighttpd-1.4.11ソース+fcgi-2.4.0ソース
テストソース
S hello world(>367-368)
L nicky.cgi改
以下、結果報告。
430:429
06/07/02 22:23:16
ab -n 10 -c 1
CGI S CGI L SpeedyCGI S SpeedyCGI L
1回目 29.65 0.46 34.28 2.37
2回目 29.65 0.46 40.63 7.34
3回目 29.64 0.46 42.76 7.34
4回目 29.64 0.46 42.71 7.35
5回目 29.49 0.46 42.47 7.36
3点平均 29.64 0.46 41.94 7.34
Requests per second
ab -n 100 -c 10
CGI S CGI L SpeedyCGI S SpeedyCGI L
1回目 27.93 0.45 39.92 5.53
2回目 28.49 ABORT 40.25 6.87
3回目 27.07 0.45 38.74 6.85
4回目 27.88 0.45 41.55 6.76
5回目 27.55 0.45 39.25 6.72
3点平均 27.79 0.45 39.81 6.78
Requests per second
ab -n 200 -c 20
CGI S CGI L SpeedyCGI S SpeedyCGI L
1回目 27.83 ABORT 38.94 5.63
2回目 29.22 ABORT 40.63 6.58
3回目 27.79 ABORT 39.02 6.82
4回目 28.04 ABORT 40.86 6.96
5回目 28.65 ABORT 37.50 6.69
3点平均 28.17 #DIV/0! 39.53 6.70
Requests per second
431:429
06/07/02 22:30:12
ab -n 400 -c 40
CGI S CGI L SpeedyCGI S SpeedyCGI L
1回目 27.78 ABORT 40.24 5.86
2回目 27.71 ABORT 39.33 6.95
3回目 27.92 ABORT 39.44 6.66
4回目 27.50 ABORT 40.26 6.71
5回目 27.52 ABORT 39.55 6.76
3点平均 27.67 #DIV/0! 39.74 6.71
Requests per second
ab -n 1000 -c 100
CGI S CGI L SpeedyCGI S SpeedyCGI L
1回目 28.61 ABORT 37.56 6.03
2回目 28.16 ABORT 40.09 6.42
3回目 27.91 ABORT 39.45 6.54
4回目 27.26 ABORT 36.94 6.55
5回目 27.66 ABORT 39.12 6.60
3点平均 27.91 #DIV/0! 38.71 6.50
Requests per second
ab -n 1500 -c 150
CGI S CGI L SpeedyCGI S SpeedyCGI L
1回目 27.98 ABORT 38.02 6.11
2回目 28.02 ABORT 38.09 6.67
3回目 27.50 ABORT 38.17 6.48
4回目 27.03 ABORT 36.71 6.48
5回目 26.88 ABORT 37.58 6.47
3点平均 27.50 #DIV/0! 37.90 6.48
Requests per second
432:429
06/07/02 22:31:23
ab -n 2000 -c 200だけもう少しお待ちを。
433:429
06/07/02 22:38:08
×fcgi-2.4.0ソース
○PersistentPerl-2.22ソース
434:429
06/07/02 22:44:58
ab -n 2000 -c 200
CGI S CGI L SpeedyCGI S SpeedyCGI L
1回目 26.36 ABORT 37.97 6.41
2回目 27.70 ABORT 38.01 6.90
3回目 27.72 ABORT 38.17 6.99
4回目 26.38 ABORT 35.61 7.00
5回目 26.89 ABORT 38.00 6.89
3点平均 26.99 #DIV/0! 37.99 6.93
Requests per second
435:429
06/07/02 22:50:29
MAX、MINを除外した平均値
lighttpd
S(hell world)、L(nicky.cgi改)
CGI S CGI L SpeedyCGI S SpeedyCGI L fastcgi S fastcgi L html S html L
ab -n 10 -c 1 29.64 0.46 41.94 7.34 81.18 7.53 425.63 293.40
ab -n 100 -c 10 27.79 0.45 39.81 6.78 81.17 7.43 561.63 396.52
ab -n 200 -c 20 28.17 abort all 39.53 6.70 79.96 7.46 534.53 395.08
ab -n 400 -c 40 27.67 abort all 39.74 6.71 80.99 7.38 531.22 387.10
ab -n 1000 -c 100 27.91 abort all 38.71 6.50 80.53 7.01 536.27 389.37
ab -n 1500 -c 150 27.50 abort all 37.90 6.48 74.08 6.81 534.09 391.86
ab -n 2000 -c 200 26.99 abort all 37.99 6.93 72.75 6.65 515.67 386.21
Requests per second
436:429
06/07/02 22:51:24
以上、報告終了。
437:nobodyさん
06/07/02 22:53:09
windows版のApacheをインストールして、 ab.exeを使えばいい。
同時接続数100とかでやると、タスクマネージャのCPU使用率がぐわっとあがるのがわかる。
438:nobodyさん
06/07/02 22:57:54
>>437
どのアクセラレータもその影響をうけるんだから、比較には問題なくない?
あと、>427も言ってるが今度はルータの影響受けるんでPC間直結になると思うが。
439:429
06/07/02 23:06:24
lighttpd+FastCGIの補足。
この組み合わせの動的呼び出しは、方法が見つからなかったのでlighttpd.confに記述してlighttpdと同時に対象CGIを起動。
1回目のキャッシュクリアはせず。
このため、1回目の起動でスコアが落ちてません。
3点平均でご勘弁を。
またSpeedyCGI Lのab -n 2000 -c 200のスコアが変だったのでSpeedyCGI L全部取り直しましたが同じでした。???
440:429
06/07/02 23:09:26
>>439
> 1回目のキャッシュクリアはせず。
方法がよくわからなかったと言うのが本当のところです。
lighttpd再起動でよかったのかな?
441:nobodyさん
06/07/02 23:12:25
>>438
影響どころか気絶するルータもある
442:nobodyさん
06/07/02 23:17:36
>>437
ネットワークを酷使すればCPU使用率急上昇は普通。
そのCPU使用率はab.exeのものと確認済み?
443:nobodyさん
06/07/03 01:27:55
この初心者スレの存在意義って何だろう?
444:nobodyさん
06/07/03 01:45:16
Speedyが同時多発接続でgdgdになってきてるのはエビに食われてるからだと思うんだよね。
445:nobodyさん
06/07/03 01:58:48
>>429
度々、御苦労様です。
静的コンテンツについては、lighttpdが圧勝、動的コンテンツについては、hello Worldで見る
分には、mod_cgi下で動く、通常のCGIとSpeedyCGIについては、lighttyがやや速く、mod_fastcgi
下では、Apacheがやや速いという結果の様ですね。
スクリプトが大きくなると、その差は消えてしまいますが。
lighttpdは、静的コンテンツについては魅力的だけど、mod_speedycgiが無いから、perl使う
分には、Apache使っていた方が良いかなと思いました。
ちなみに、Hello Worldでテストする分には、mod_speedycgiより、PHPの方が速いんですが、
ソースが大きくなるにつれて、perlに抜かれちゃうんですよね。
446:nobodyさん
06/07/03 12:04:55
>>444
> Speedyが同時多発接続でgdgdになってきてるのはエビに食われてるからだと思うんだよね。
んだな。
が、他クライアントをつなぐと今度はNICにCPU食われる。
結局はNICのCPU消費とどっちが大きいかだけの違いでねえ?
いいんでねえ、localhost。
447:nobodyさん
06/07/03 12:54:22
NIC食うからねえCPU。
URLリンク(www.nicmania.net)
448:nobodyさん
06/07/03 19:21:39
> この初心者スレの存在意義って何だろう?
それは、何だ、Javaと並ぶ巨大宗教Perlの莫大な遺産の活用じゃない。
449:nobodyさん
06/07/03 22:39:17
CPU100%にならないように気をつけながらベンチマークとるのが普通なんだが。
まあ、まるで役にたたないとは言わないが、仕事でやるなら最初からやり直させるな。
450:nobodyさん
06/07/03 22:47:49
はぁ?
451:nobodyさん
06/07/03 22:49:14
ベンチとるときはCPU振り切れるのが普通。
452:nobodyさん
06/07/03 22:49:51
それがベンチ
453:nobodyさん
06/07/03 22:50:43
>>448
つーか、
スレリンク(php板)
あたりに書くつもりだった誤爆じゃない?
書き込み時刻を見ると、なんとなく辻褄が合う。
スルーしなくっちゃ。
ここのスレは、おそらく住人が10人以下の人里離れた小さな村。
普通の初心者は近付かない。
454:nobodyさん
06/07/03 22:56:10
>>449
> CPU100%にならないように気をつけながらベンチマークとるのが普通なんだが。
処理をフル回転で速く終わらせ、スコアを競うのがベンチマークw
455:nobodyさん
06/07/03 23:04:14
>>453
センセー、質問。
「なぜに他のスレとの辻褄まで調べてるんですか?」
456:nobodyさん
06/07/03 23:06:38
だから、クライアントのCPUが100%にならないように、に決まってるだろ。そんなのいちいち説明しなくてもわかりそうなもんだが。
457:nobodyさん
06/07/03 23:06:39
>>455
調べる事が好きだから。
458:nobodyさん
06/07/03 23:09:05
>>456
>449のカキコでは誰もそうは思わんよ。
459:nobodyさん
06/07/03 23:11:27
>>457
一番スルーしてなくない?
460:nobodyさん
06/07/03 23:12:36
>>459
若干の自己矛盾を感じている。orz
461:nobodyさん
06/07/03 23:15:01
>>460
ウケルー
メチャ、センスある
462:nobodyさん
06/07/04 02:20:16
>447のサイトのメインP、Pen4 2.4Gだよ。
エビとニクどっちが食うんだろう?
463:nobodyさん
06/07/04 02:21:17
↑メインP→メインPC
464:nobodyさん
06/07/05 12:19:01
マシンのベンチを取るスレはここですか?
465:nobodyさん
06/07/05 18:20:09
↑ベンチをすれば当然マシンのベンチでもあるなw
466:nobodyさん
06/07/06 02:34:15
>>445
>ちなみに、Hello Worldでテストする分には、mod_speedycgiより、PHPの方が速いんですが、
PHPの環境は?まさか普通のapacheモジュール版と比較したりしてないよね?
467:nobodyさん
06/07/07 20:11:33 hqAFRSkq
WebProg板のスレだというのに、1日書き込みがないだけで気になる。
468:nobodyさん
06/07/07 23:42:15
>>466
まさかの普通のapacheモジュール版ですが、このケースで比較対象として問題あります?
469:nobodyさん
06/07/07 23:55:24
>>468
ノープロブレム。
文脈からして、当然そうだよな。
470:nobodyさん
06/07/08 00:11:01
mod_speedycgiのHello WorldにはCのHello Worldも負けてるのになあ。
471:nobodyさん
06/07/08 11:43:01
>>470
PHPは、短いソースでは速いですね。
ちなみに、apxs -g -n hello とかで出来る、hello worldなソースをmake;make installすると、
私がちょっとテストした環境で、mod_speedycgiの2.5倍程度の速度が出ました。
Cを使うなら、handler書くのが良いのかなと思いました。
そこからすると、mod_perlも、Registry使わずに、handlerな形にすると、順位に変動が
ある様な気もしています。
まあ、アプリが大きくなれば吸収されてしまう差なので、速度の為だけにそうする必要が
あるケースは稀でしょうが。
472:nobodyさん
06/07/08 16:05:57
このスレを見て、MovableTypeでspeedyCGIを使いたいと思って
apache1.3の環境でspeedyCGIを入れ、mt.cgiの先頭を書き換えて実行してみました。
1回目は無事表示されるんですが、リロードするとInternalServerErrorが。
何かインストールで失敗してるんでしょうか…?
473:nobodyさん
06/07/08 16:45:31
ここはそういうスレではないです
474:nobodyさん
06/07/08 18:54:22 uy7Z+OsL BE:341069-#
>>472
mtの前に、hello.cgiとか動かしてみればいいんでないすか。
475:nobodyさん
06/07/08 19:13:56
>>471
何か内容が反対に受け取られてるような気が?
補足すると
mod_speedycgiのHello WorldにはCのHello Worldも負けてるのに
比較対照がノーマルPHPなわけはないだろう。
こう言いたかったのよ。
476:472
06/07/08 19:20:32
>>473
質問スレではないかもしれないとは思ったのですが、
皆さんはかなりお詳しいと思い、悩んだのですが思い切って質問させていただきました。
気分を害しましたら、ごめんなさい。
>>474
レスありがとうございます。
「hello.cgi」というのは、要するにテスト用のcgiを作成して、ということでよろしいですか?
googleなどでヒットするhello.cgiを試しに作ってみて、先頭部分を# !/usr/bin/speedyと
書き換えてみましたところ、無事リロードしても表示されました。
となると、問題はmt.cgiなのでしょうか…?
googleでいろいろ調べまくったのですが、どうも有益な情報が見つかりません。
movabletypeでspeedyCGIを動かしている方々、どうぞお知恵を拝借ください…。
477:nobodyさん
06/07/08 19:56:46
>>476
>1回目は無事表示されるんですが、リロードするとInternalServerErrorが。
グローバル変数の初期化ができてない典型のように思えますが、
そのmtはmod_perlやFastCGIでは正常に動き、SpeedyCGIのみ動かない状態でしょうか?
mtは触ったことがないですが、mod_perlかどうか判定してコードを切り替えているという事は聞いた事があります。
≠mod_perlの判定のためCGI用のコードが実行されている?
後、mtはSpeedyCGIよりFastCGIの方が情報が多いので楽かも。
URLリンク(as-is.net)
ここが有名。
478:nobodyさん
06/07/08 20:47:04 BE:53064623-#
MTのコードちょっと覗いてみたら
mod_perl用に条件分岐しまくりワロタ
479:471
06/07/08 20:48:33
>>475
mod_speedycgiのHello WorldにはCGI/CのHello Worldも負けてるのに
比較対照がCGI/PHPなわけはないだろう。
と言う意味で解釈していたのですが、これで良いんですよね?
処理系の速度としては、C > perl > PHP というのは周知の事実。
PHPが速いと言われるのは、Apacheのmoduleとして動かしているからで、
この起動速度は、PHPが速く、小さいコードでは、その差が効いてPHPが
速い。
この先は触れていないんですが、、コードが大きくなると、処理系の遅さが
効いてきて、perl系に抜かれるという意味で書いてました。
480:475
06/07/08 20:58:10
>>479
すまそ。
正確に把握されてたのね...
481:472
06/07/08 21:07:45
>>477
レスありがとうございます。
FastCGIは試していないのですが、mod_perlをインストールする際にエラーが出て
インストールできなかったので、他の方法がないのかと探していてこのスレへたどりつきました。
ここを見ていると、mod_perlはいまいち評価が高くないように感じ、speedyCGIを試していたところでした。
>グローバル変数の初期化ができてない典型のように思えますが、
まさにそうだと思うのですが、対処法がわかりません…。
参考サイトを見ながら、FastCGIの導入を勉強してみます。
レスどうもありがとうございました。大変助かりました。
482:477
06/07/08 21:22:44
>>481
あえてSpeedyCGIを試すなら、mod_perl判定フラグをtrueにすればいいのではないかと思いますが。
SpeedyCGIとFastCGIはメモリ消費も速度も近いので、楽な方を選ぶべきだと思います。
483:477
06/07/08 21:49:31
>>481
後、忘れていました。
FastCGIはScriptAliasがかかっているDirでは正常に動かないです。
mtのインスコ先にScriptAliasがかかっている場合は外してしまって、
変わりに
Alias /cgi-bin/ "......."
<Location /cgi-bin/>
AddHandler cgi-script .cgi
fastcgi-script .fcgi
.....
</Location>
のような感じで設定したらいいです。
484:477
06/07/08 21:50:32
×fastcgi-script .fcgi
○AddHandler fastcgi-script .fcgi
485:477
06/07/09 00:58:13
後、
×<Location /cgi-bin/>
○<Location /cgi-bin>
もう一つ、
URLリンク(as-is.net)
の通りにやるなら、
AddHandler fastcgi-script .fcgi
これは要らないです。
間違いだらけ、本当にすいません。
486:477
06/07/09 01:02:01
また間違いました。
AddHandler fastcgi-script .fcgi
やっぱり要ります。
連投しまくり、すいません。
487:472
06/07/09 01:17:20
>>477
477さん、いろいろとありがとうございます。
あれからひたすら何度も試しているのですが、実は全然うまくいきません(つД`)
Apache1.3にfcgiとmod_FastCGIを適用させようとしているんですが、エラーが…。
httpd.confに以下の内容を書き込んでapacheを再起動します。
LoadModule fastcgi_module libexec/apache/mod_fastcgi.so
AddModule mod_fastcgi.c
<IfModule mod_fastcgi.c>
AddHandler fastcgi-script .fcgi
FastCGIConfig -maxClassProcesses 4 -minProcesses 1
FastCgiIpcDir /tmp
</IfModule>
すると、
Syntax error on line 206 of /usr/local/apache/conf/httpd.conf:
Invalid command 'LoadModule', perhaps mis-spelled or defined by a module not included in the server configuration
とエラーが返されます。サイトの説明通りにやっているんですが…。
次ページ最新レス表示スレッドの検索類似スレ一覧話題のニュースおまかせリスト▼オプションを表示暇つぶし2ch
5372日前に更新/249 KB
担当:undef