[過去ログ] 2ch特化型サーバ・ロケーション構築作戦 Part21 (1001レス)
1-

このスレッドは過去ログ倉庫に格納されています。
次スレ検索 歴削→次スレ 栞削→次スレ 過去ログメニュー
299: root▲ ★ 2006/05/01(月) 11:35:01 ID:???0 BE AAS
2 Thread 0x8262500 (LWP 102200) 0x28289973 in poll () from /lib/libc.so.6
1 Thread 0x8262600 (LWP 102201) 0x2828a593 in accept () from /lib/libc.so.6
(gdb) thread 22
[Switching to thread 22 (Thread 0x8241100 (LWP 101965))]#0 0x2828a4b3 in kill
() from /lib/libc.so.6
(gdb) where
#0 0x2828a4b3 in kill () from /lib/libc.so.6
Cannot access memory at address 0xb8d92a3c
(gdb)

ううむ。
300
(1): root▲ ★ 2006/05/01(月) 11:48:27 ID:???0 BE AAS
signal 10問題、簡単なまとめ

1) 通常状態で散発的に発生(全サーバ)

httpd子プロセスの一つが散発的にsignal 10で落ちる
負荷にあんまり関係ないっぽい

2) 高負荷状態で集中的に発生(live22)

httpd子プロセスがたくさんsignal 10で落ちる
高負荷時に発生している模様

ということで上のほうのパッチで 2) が直るといいかなと。
301: 動け動けウゴウゴ2ちゃんねる 2006/05/01(月) 13:04:06 ID:J451Dwo00(1)調 AAS
>>300
1)はたぶん虫さんでしょうね・・・・

libcの虫さんでなければいいのですけど。
302: root▲ ★ 2006/05/01(月) 14:30:49 ID:???0 BE AAS
6.1-RC2

%uname -a
FreeBSD banana273.maido3.com 6.1-RC2 FreeBSD 6.1-RC2 #3: Sun Apr 30 22:25:34 PDT 2006 root@banana273.maido3.com:/var/src/sys/i386/compile/I386_BANANA_61 i386
303: ◆TWARamEjuA 2006/05/01(月) 16:13:09 ID:0P9UpqgV0(1)調 BE AAS
RCといえば、やっと取れたみたい(苦笑)@ProFTPD 1.3.0
304
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/01(月) 17:45:34 ID:bDtDitjaO携(1)調 AAS
thttpdはcgiをBasicサポトしてます。
というのを知ったがどうにも私ゃ知らん。
明日からCプログラミングを習います、はい。
305: root▲ ★ 2006/05/01(月) 18:46:43 ID:???0 BE AAS
>>304
thttpd をバックエンドで試してみる、という選択肢はあるかもですね。

If-Modified-Since やら差分転送やらが、きちんと動くのかがポイントかしら。
306
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/01(月) 20:49:31 ID:6BqJQb+40(1)調 AAS
Apache 2.0.58と2.2.2がリリースされました。
外部リンク[html]:www.apache.org
外部リンク[html]:www.apache.org

2.2.2のほうはmod_proxyにいっぱい修正が入ってます。
307: root▲ ★ 2006/05/02(火) 01:36:41 ID:???0 AAS
>>306
%cat /usr/ports/www/apache22/distinfo
MD5 (apache22/httpd-2.2.2.tar.bz2) = 9c759a9744436de6a6aa2ddbc49d6e81
SHA256 (apache22/httpd-2.2.2.tar.bz2) = 51f8e00ca27ba4d4259daeff30ce6efcdcf086d277ffb7130e215b492a6f77cc
SIZE (apache22/httpd-2.2.2.tar.bz2) = 4851887
MD5 (apache22/apr_dbd_mysql.c) = 59d26a91cb7f1492fea9ab3e6cd054fc
SHA256 (apache22/apr_dbd_mysql.c) = db204a0e9a89620bf890985383b637d201b418002a0976a2476c0c58783cc3a3
SIZE (apache22/apr_dbd_mysql.c) = 18999

対応早。< ports

ぼちぼち、入れてみるか。
308
(1): root▲ ★ 2006/05/02(火) 11:59:02 ID:???0 BE AAS
./srclib/apr/dso/unix/dso.c と
./server/mpm/worker/fdqueue.c へのパッチは、
そのまま必要がありそうですね(変わっていない)。

食事の後ででも、ごにょごにょと。
309: root▲ ★ 2006/05/02(火) 13:39:02 ID:???0 BE AAS
live22 を Apache 2.2.2 + >>308 のパッチに更新した。
310
(1): root▲ ★ 2006/05/02(火) 16:47:50 ID:???0 BE AAS
電源ですが、各方面からの情報により以下のことがわかりました。

1) 現在、以下のサーバが同じ主幹(MasterSwitch)からとられている。

live22, live22x1, live22x2, live22x3, live22x4, live22x5, cobra2247(= live22-2 候補),
news19, hobby7

2) この主幹の電源は現在、ほぼおなかいっぱいの状態である。

3) live22x4, live22x5, cobra2247 は現在遊んでいる。
フル稼働させるには、電源系統のリアレンジが必要と考えられる。

4) XOロケーションには、余裕のある主幹が別にある。
311: root▲ ★ 2006/05/02(火) 16:50:52 ID:???0 BE AAS
で、最初は、news19 と hobby7 の XO 外への移設を考えていました。

しかし、今後これらのサーバもかなり近い近未来に雪だるまの一員になることが
じゅうぶんありうるのかなと、思いました。

ということで現在サービスインしていない 3) のサーバ3台を、
4) の主幹に移動するのが、いちばんよい気がしてきました。

問題なければ、この路線で Jim さんと Ryan さん(現地電源関係担当)に、
相談してみようかなと。
312
(1): ◆FUGOUFZVvA 2006/05/02(火) 18:42:21 ID:nbzYhXHXP(1/2)調 AAS
これは、ひどいと思う。2chスレ:hosting
313
(1): root▲ ★ 2006/05/02(火) 18:48:44 ID:???0 BE AAS
pid 92982 (httpd), uid 2001: exited on signal 10
pid 92988 (httpd), uid 2001: exited on signal 10
pid 92987 (httpd), uid 2001: exited on signal 10
pid 92992 (httpd), uid 2001: exited on signal 10
pid 92984 (httpd), uid 2001: exited on signal 10
pid 94520 (httpd), uid 2001: exited on signal 10
pid 23880 (httpd), uid 2001: exited on signal 10
pid 92983 (httpd), uid 2001: exited on signal 10
pid 92986 (httpd), uid 2001: exited on signal 10
pid 92989 (httpd), uid 2001: exited on signal 10
pid 92990 (httpd), uid 2001: exited on signal 10
pid 23822 (httpd), uid 2001: exited on signal 10
pid 23763 (httpd), uid 2001: exited on signal 10
pid 92994 (httpd), uid 2001: exited on signal 10
pid 12481 (httpd), uid 2001: exited on signal 10
pid 92995 (httpd), uid 2001: exited on signal 10
pid 24104 (httpd), uid 2001: exited on signal 10
pid 92980 (httpd), uid 2001: exited on signal 10

いつもの現象か。
Apache 2.2.2 + patch でも、発生すると。
314: root▲ ★ 2006/05/02(火) 18:51:13 ID:???0 BE AAS
>>312
ここのスレでの話題ではないので、
sec2chd 方面でたんたんと報告していただければと。
315
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/02(火) 18:53:49 ID:gD/Ndbla0(1/2)調 AAS
>>313
corefileも、やっぱり同じ感じで役に立たないですか?
316
(1): root▲ ★ 2006/05/02(火) 18:56:41 ID:???0 BE AAS
>>315
状況は全く同じですね。
まだ core 一つしか調べてないですが。

今の方針は明確に「勝ちに行く」なので、
修正が入っているはずの、最新の OS にバージョンアップをする予定。
ゴールデンウィーク明けまでに 6.1R が出ない場合、
6.1-RC2 でいこうと。
317
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/02(火) 19:01:01 ID:gD/Ndbla0(2/2)調 AAS
>>316
なるほど。
ちなみに、gdb で in kill 状態のスレッドで
info frame
info registers
したら、どんな感じなんでしょう?
318: ◆FUGOUFZVvA 2006/05/02(火) 19:16:34 ID:nbzYhXHXP(2/2)調 AAS
了解しました
319
(1): モーマン☆鯛。 2006/05/02(火) 20:08:27 ID:BKSQN1/Z0(1)調 BE AA×
>>310

320
(1): root▲ ★ 2006/05/02(火) 22:38:10 ID:???0 BE AAS
>>319
> 電源について,主幹と有りますが,そう呼んでしまうとトランス2次側からの電源が別系統で と
> 受け取ってしまいます。

すみませんです。
私の電気屋的知識は、所詮門前のなんたら。

> 要は「分電盤のブレーカーに空きがある」ということで良いのかしら?

です。

> という具合に3系統に分けられると,フロントが落ちた時以外は冗長化が容易では無いかと。

なるほどです。
ただまだ全貌を掌握しているわけではないので、
まずは一歩ずつ進めていこうかなと。
321
(2): root▲ ★ 2006/05/02(火) 22:44:54 ID:???0 BE AAS
>>317
(gdb) thread 73
[Switching to thread 73 (Thread 0x81d5e00 (LWP 101639))]#0 0x2828b4b3 in kill
() from /lib/libc.so.6
(gdb) info frame
Stack level 0, frame at 0xbc0c5a40:
eip = 0x2828b4b3 in kill; saved eip Cannot access memory at address 0xbc0c5a3c
(gdb) info registers
eax 0x0 0
ecx 0xc3ae7fec -1011974164
edx 0xf7f5 63477
ebx 0xa 10
esp 0xbc0c5a3c 0xbc0c5a3c
ebp 0xbc0c5a58 0xbc0c5a58
esi 0x285c5000 677138432
edi 0x3c9 969
eip 0x2828b4b3 0x2828b4b3
eflags 0x200296 2097814
cs 0x33 51
ss 0x3b 59
ds 0x3b 59
es 0x3b 59
fs 0x3b 59
gs 0x1b 27
322
(3): root▲ ★ 2006/05/02(火) 22:46:45 ID:???0 BE AAS
(gdb) thread 14
[Switching to thread 14 (Thread 0x8249900 (LWP 100922))]#0 0x2828b4b3 in kill
() from /lib/libc.so.6
(gdb) where
#0 0x2828b4b3 in kill () from /lib/libc.so.6
Cannot access memory at address 0xb858aa3c
(gdb) info frame
Stack level 0, frame at 0xb858aa40:
eip = 0x2828b4b3 in kill; saved eip Cannot access memory at address 0xb858aa3c
(gdb) info registers
eax 0x0 0
ecx 0xab590bbd -1420227651
edx 0xf7f5 63477
ebx 0xa 10
esp 0xb858aa3c 0xb858aa3c
ebp 0xb858aa58 0xb858aa58
esi 0x285b2000 677060608
edi 0xa7 167
eip 0x2828b4b3 0x2828b4b3
eflags 0x200296 2097814
cs 0x33 51
ss 0x3b 59
ds 0x3b 59
es 0x3b 59
fs 0x3b 59
gs 0x1b 27
323
(1): root▲ ★ 2006/05/02(火) 22:47:44 ID:???0 BE AAS
とりあえず、二つ分。
324: モーマン☆鯛。 2006/05/03(水) 02:05:49 ID:mXyjWaNd0(1)調 BE AAS
>>320
> ただまだ全貌を掌握しているわけではないので、
> まずは一歩ずつ進めていこうかなと。
あいあい。いまはそれで。
325
(6): 動け動けウゴウゴ2ちゃんねる 2006/05/03(水) 04:45:06 ID:qpNDFpsT0(1/3)調 AAS
>>321-323
情報どうもです。
ちょっとだけ光が見えてきたような気がします。

こうなるとVMのマップ状態が知りたくなってくるんですが、
/usr/ports/sysutils/procmap を使用して、現在稼働中のhttpdのマップ状態を
見ることは可能でしょうか?
なお、procmapはprocfsを必要としますので、現在mountしてないのでしたら、
一時的にでもmountする必要があります。

あと、kern.dflssiz, kern.maxssiz, kern.sgrowsiz等は設定されてますでしょうか?
また、Apacheの設定でThreadStackSizeは設定されてますでしょうか?
326
(4): 動け動けウゴウゴ2ちゃんねる 2006/05/03(水) 11:48:39 ID:qpNDFpsT0(2/3)調 AAS
あと、>>321-322 のcoreについて、以下の方法でトレース可能か試してみてください。

>>321について、ebpが0xbc0c5a58なので、そこからebpの流れを追ってみる。
(gdb) p/x *0xbc0c5a58
$1 = 0xXXXXXXXX
(gdb) p/x *0xXXXXXXXX <- 上記で表示されたアドレスを入力
$2 = 0xYYYYYYYY
(gdb) p/x *0xYYYYYYYY <- 上記で表示されたアドレスを入力
...
これを10回程度繰り返す。
327
(3): 動け動けウゴウゴ2ちゃんねる 2006/05/03(水) 11:53:27 ID:qpNDFpsT0(3/3)調 AAS
次に、>>326の結果を利用して、関数呼び出しの流れが取得可能か試す。

(gdb) p/a *(0xbc0c5a58 + 4)
$11 = ...
(gdb) p/a *(0xXXXXXXXX + 4)
$12 = ...
(gdb) p/a *(0xYYYYYYYY + 4)
...

うまくいけば、関数名が表示されると思います。
328
(1): root▲ ★ 2006/05/03(水) 12:19:26 ID:???0 BE AAS
tiger503, tiger507 and cobra2247 の3台は本日電源系統移動作業の予定。
さきほど私のほうで halt -p を実行し、作業可能を伝えました。

>>325
ありがとうございます。
本日中にやってみるです。 < procmap

> あと、kern.dflssiz, kern.maxssiz, kern.sgrowsiz等は設定されてますでしょうか?
> また、Apacheの設定でThreadStackSizeは設定されてますでしょうか?

このへんはデフォルトのままです。
というか、スタックオーバーフローの疑いですか。

>>325-327
これも別途やってみるです。
329: P211018235141.ppp.prin.ne.jp 2006/05/03(水) 18:57:25 ID:IAaJAFY00(1)調 AAS
外からですが、
見ていると、プロセスあたりのスレッド数が32の時のほうが、パフォーマンスは出るような感じですね。

でもそれだと、虫を踏んだ時にLAがめちゃくちゃ上がって、瀕死状態になってしまうと。
330: root▲ ★ 2006/05/04(木) 00:55:46 ID:???0 BE AAS
まずは。

live22、signal 10 でのダウン(虫ふみ)多数。
別途解析すすめる予定。

live22, live22x1 は重くなった局面あり。
プライベート接続側の受信バッファがあふれた模様。

May 3 02:30:34 <0.4> tiger2522 kernel: em1: RX overrun
May 3 02:47:17 <0.4> tiger2522 kernel: em1: RX overrun
May 3 05:04:32 <0.4> tiger2522 kernel: em1: RX overrun

May 3 05:00:00 <0.4> tiger2523 kernel: em1: RX overrun
May 3 05:00:00 <0.4> tiger2523 last message repeated 2 times

live22x2 特に異常なし。

live22x3 リブートかかった模様、原因不明(メッセージなし)。
それとは別にこんなメッセージが。
やや不吉なるも、とりあえず経過観察。

May 3 08:49:50 <0.2> tiger2525 kernel: ad0: TIMEOUT - READ_DMA retrying (1 retry left) LBA=94099079
331: root▲ ★ 2006/05/04(木) 00:59:08 ID:???0 BE AAS
ex14は大きな破綻なしか。
cobra、強いなぁ。
332: root▲ ★ 2006/05/04(木) 01:04:09 ID:???0 BE AAS
live22x3、また変なリブート入った。
おかしいな。
333: root▲ ★ 2006/05/04(木) 01:09:46 ID:???0 BE AAS
live22x3 は、ログインして状況確認中。

メールチェックしてきます。
作業終わっているといいな。
334: root▲ ★ 2006/05/04(木) 01:12:16 ID:???0 BE AAS
live22x3、いけませんね。

受付嬢の設定変えて、フロントエンドからはずします。
335: root▲ ★ 2006/05/04(木) 01:18:07 ID:???0 BE AAS
live22x3 は、ハードウェアトラブルっぽいですね。
いろいろ手配します。

matd の設定いじって、とりあえずフロントエンドからはずしました。
336: root▲ ★ 2006/05/04(木) 01:21:59 ID:???0 BE AAS
live22x4, live22x5, cobra2247(= live22-2 予定)
電源移設作業完了したとの連絡が入りました。

ということで、雪だるま作戦本格再開です。
OSバージョンアップ、設定仕込み等、たんたんとすすめるということで。
337: root▲ ★ 2006/05/04(木) 01:44:53 ID:???0 BE AAS
tiger2525(= live22x3)、remote KVM でチェックしました。
HDD コントローラからエラー出まくり。
HDD or HDD コントローラがあぼーんした模様。

tiger503/507/cobra2247 の作業ありがとうメールに、
tiger2525 の緊急対応を依頼しました。

# ちなみに、tiger2525 はフロントの1台なので、
# 仮に HDD 完全あぼーんでも、交換して OS 入れれば問題なし。
338: root▲ ★ 2006/05/04(木) 02:51:54 ID:???0 BE AAS
tiger2525 (= live22x3) は、HDD あぼーんとのこと。
HDD 交換・OS 再インストールで中の人と調整中。
339: root▲ ★ 2006/05/04(木) 04:19:44 ID:???0 BE AAS
もののけ姫までに、

・live22x3 復活 & フロントに再投入
・live22x4, live22x5, live22-2 投入 with FreeBSD 6.1-RC2 or 6.1R
・live22, live22x[12] OS バージョンアップ + Apache 更新

をめざすことにしよう。
340: root▲ ★ 2006/05/04(木) 04:31:13 ID:???0 BE AAS
>>325-327 は、ちと予想外の障害対応のため、明日にでも。
(core は保存しました)

今日は、そろそろこのへんで。
341: root▲ ★ 2006/05/04(木) 16:52:48 ID:???0 BE AAS
過去ログ(NFS経由)を、すいているlive22のパブリック側で
アクセスするようにしてみた。
342: root▲ ★ 2006/05/04(木) 17:44:32 ID:???0 BE AAS
live22x4, live22x5 をフロントに再投入。

・OS は 6.1-RC2
%uname -a
FreeBSD tiger507.maido3.com 6.1-RC2 FreeBSD 6.1-RC2 #0: Wed May 3 23:09:45 PDT 2006 root@tiger507.maido3.com:/var/src/sys/i386/compile/I386_TIGER_61 i386

・Apache 2.2.2 + patch + worker MPM + libthr

・カーネルパッチ(FD_SETSIZE) とりあえず導入せず

・PREEMPTION とりあえず有効
343: root▲ ★ 2006/05/04(木) 17:49:52 ID:???0 BE AAS
以降の予定

cobra2247 稼動
フロントエンドを切り替えつつ、バージョンアップ
バックエンドバージョンアップ(この際にはサービス停止)
344: root▲ ★ 2006/05/05(金) 00:31:20 ID:???0 BE AAS
cobra2247、バージョンアップの準備していたら
いきなりハングアップした。

KVM 画面もフリーズしている模様。ううむ。
345: root▲ ★ 2006/05/05(金) 00:36:27 ID:???0 BE AAS
見たところ、カーネルパニックしている模様。
ううむ。

ちょっと、しらべてみます。
346: root▲ ★ 2006/05/05(金) 00:38:20 ID:???0 BE AAS
savecore: reboot after panic: spin lock held too long

ううむ、これって。
347
(1): root▲ ★ 2006/05/05(金) 00:43:25 ID:???0 BE AAS
いったん single CPU の kernel に替えてみるか。
なんだかだけど。
348
(1): ◆BFzK/mtqM2 2006/05/05(金) 00:49:56 ID:qTv6eOEO0(1/2)調 AAS
>>347
まだソースがガシガシ更新されているから虫がいるんですかね?
349: root▲ ★ 2006/05/05(金) 00:54:57 ID:???0 BE AAS
>>348
まだ 6.0R のままなんですよ。< cobra2247
make buildworld の間に panic したという。

ほぼ同じハードウェア構成で 6.0R な ex14 はちゃんと動いているので、
ハードウェア障害の予感も。
350: root▲ ★ 2006/05/05(金) 00:57:11 ID:???0 BE AAS
カーネル作っている間にまた固まった、、、。 < cobra2247
351
(1): ◆BFzK/mtqM2 2006/05/05(金) 00:59:00 ID:qTv6eOEO0(2/2)調 AAS
メモリかな?
352: root▲ ★ 2006/05/05(金) 00:59:51 ID:???0 BE AAS
しばらく待ってだめなら、リブート要請を再度出すということで。
(さっき一度出したのですが、その後ちゃんとパニックしてくれたので
いったんキャンセルした)
353: root▲ ★ 2006/05/05(金) 01:00:58 ID:???0 BE AAS
>>351
ありえますが、、、。どうなんだろう。
354: root▲ ★ 2006/05/05(金) 01:06:29 ID:???0 BE AAS
だめなようですね。

リブート要請します。< cobra2247
355
(2): root▲ ★ 2006/05/05(金) 02:35:24 ID:???0 BE AAS
>>325
> あと、kern.dflssiz, kern.maxssiz, kern.sgrowsiz等は設定されてますでしょうか?
> また、Apacheの設定でThreadStackSizeは設定されてますでしょうか?

外部リンク[html]:httpd.apache.org

スタックオーバー風呂ということなら、
大きくする、という手はあるのかも。
356: root▲ ★ 2006/05/05(金) 02:35:57 ID:???0 BE AAS
>>355
ありゃ、変な変換。

ま、いっか。もちょっとしたらお風呂の時間で。
357
(3): root▲ ★ 2006/05/05(金) 03:21:47 ID:???0 BE AAS
<IfModule mpm_worker_module>
ThreadStackSize 262144
StartServers 64
ServerLimit 64
ThreadLimit 32
ThreadsPerChild 32
MaxSpareThreads 2048
MinSpareThreads 2048
MaxSpareThreads 2048
MaxRequestsPerChild 32000000
MaxMemFree 64000
</IfModule>

にしてみた。< live22

前に read.cgi のことをやった時に、確か SunOS さんが
65536 がデフォルトって言っていたっぽいような気がするので、
とりあえずスタックサイズを4倍にしてみたつもり。
358: root▲ ★ 2006/05/05(金) 03:27:19 ID:???0 BE AAS
%uname -a
FreeBSD tiger2524.maido3.com 6.1-RC2 FreeBSD 6.1-RC2 #0: Thu May 4 10:04:11 PDT 2006 root@tiger2524.maido3.com:/home/src/sys/i386/compile/I386_TINYTIGER_61 i386

@ live22x2
359
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 03:33:44 ID:b3qevcS80(1/10)調 AAS
>>357
FreeBSD 6.x のデフォルトのスレッドスタックサイズは1MBです。
360
(1): root▲ ★ 2006/05/05(金) 03:40:32 ID:???0 BE AAS
>>355 >>357
リンク先を読んでみると、

スレッドスタックサイズのデフォルト値が比較的小さく設定されている プラットホーム
(例えば HP-UX) では、自動変数用の領域で大きな容量を 使用するサードパーティ製
モジュールのために Apache がクラッシュする 場合もあります。そのモジュールは他の
プラットホームでは スタックサイズが大きいために、快調に動作するかもしれません。
このタイプのクラッシュは、ThreadStackSize で OS のデフォルト値より大きな値を指定
することで解決します。 サードパーティ製モジュールでこの処置が必要であると記載
されている 場合か、Apache の出力するメッセージでスレッドスタックサイズが
小さすぎると指摘されている場合にのみ、この調整をしてください。

デフォルトスレッドスタックサイズが、Web サーバ用途に必要な量よりも 明らかに
大きすぎる場合、ThreadStackSize を OS のデフォルト値よりも小さな値にすることで、
子プロセスあたりの スレッド数をより多く持たせられるようになります。 このタイプの
調整は、テスト環境でウェブサーバを完全に テストできる場合に限って行なうべきです。
まれに多数のスタックが要求されるリクエストを受けることがあるかも しれないからです。
Web サーバの設定を変更すると、現在の ThreadStackSize の設定が取り消される
場合があります。

…ううむ、大きくするのがよいのか、小さくするのがよいのか。
あるいは実はあまり効果がないのか。

とりあえず、今は >>357 にしておくか。
361
(1): root▲ ★ 2006/05/05(金) 03:41:15 ID:???0 BE AAS
>>359
1000000 かな。それとも 1048576 ?
362
(1): ◆SSu.zv/rvs 2006/05/05(金) 03:42:26 ID:BMUb5uVP0(1/13)調 AAS
スタックは誰が使うスタックですか?
363
(1): root▲ ★ 2006/05/05(金) 03:43:14 ID:???0 BE AAS
だんだん、思い出してきました。

前は、dso 版 read.cgi でこの局面になったですね。
auto 変数で 512M のバッファとかとっていて、
それが Apache 2.0 の worker MPM ではうまく動かなかったんでした。

ちょっと、過去ログを見てみるか。
364: root▲ ★ 2006/05/05(金) 03:43:39 ID:???0 BE AAS
>>362
httpd の 1 スレッドのはず。
365: ◆SSu.zv/rvs 2006/05/05(金) 03:44:36 ID:BMUb5uVP0(2/13)調 AAS
512M?
366
(1): root▲ ★ 2006/05/05(金) 03:44:46 ID:???0 BE AAS
で、>>363 は、
SunOS さんのアドバイスで、apr_palloc() を使って動的にとるようにして、
解決したのでした。
367: root▲ ★ 2006/05/05(金) 03:45:11 ID:???0 BE AAS
× 512M
○ 512K
368
(1): ◆SSu.zv/rvs 2006/05/05(金) 03:45:41 ID:BMUb5uVP0(3/13)調 AAS
それはヒープ? >>366
369
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 03:46:14 ID:b3qevcS80(2/10)調 AAS
>>361

外部リンク[diff]:www.freebsd.org
なので、1048576。
あと、64bit だと2MBがデフォルトですね。

65536は、5.4までのデフォルト。
(5.5は6.xと同じになるみたいです)
370
(1): ◆SSu.zv/rvs 2006/05/05(金) 03:46:50 ID:BMUb5uVP0(4/13)調 AAS
私の中ではスタックは 1M はあるという意識で組んでいたり、
371: root▲ ★ 2006/05/05(金) 03:47:02 ID:???0 BE AAS
read.cgi の件は、これですね。

read.cgi再開発スレ Part2
2chスレ:operate あたり。
372: root▲ ★ 2006/05/05(金) 03:47:29 ID:???0 BE AAS
>>368
そのはずです。
向こうの read.cgi スレでやったはず。
373: root▲ ★ 2006/05/05(金) 03:48:29 ID:???0 AAS
>>369
なるほど、5.4R までのデフォルトと変わっているですか。

>>370
そんなわけで、64k しかなかったと。
374
(1): ◆SSu.zv/rvs 2006/05/05(金) 03:49:05 ID:BMUb5uVP0(5/13)調 AAS
1スレッドのスタックとすると
.dso 等にはどれくらいの残りがあるんですかねぇ
375: root▲ ★ 2006/05/05(金) 03:49:50 ID:???0 AAS
ということは、これではないっぽい、、、のかな。
あるいは 1M にしたことが、副作用を呼んでいるのか。< live22x

# ってことは、Apacheのドキュメントにあるように
# あえて少なくする(5.4Rの時のように)ことも、ありなのかしら。
376: root▲ ★ 2006/05/05(金) 03:50:31 ID:???0 AAS
>>374
ん、ちとはっきりとはわからんです。
(そこに来るまでにどこまで消費されているか、ってことですね)
377
(1): ◆SSu.zv/rvs 2006/05/05(金) 03:52:50 ID:BMUb5uVP0(6/13)調 AAS
どれだけ同時に起動されていて
どのように使っているのかわからないので、一概には言えないけど、
もと 65536 を read.dso に渡していたならそれを巨大にするのはかなり危険かも、
ただし Apache等で必要ならまた別の話ですが、
378: root▲ ★ 2006/05/05(金) 03:55:19 ID:???0 AAS
>>377
live22 は read.cgi 動いてないですが、
フロントにも同じことがいえるのかもですね。 < read.cgi の話

で、FreeBSD 6.0R で変わった(でかくなった)とすると、
そこの部分を元のように*減らして*みる、というのは、
意味があることなのかも。
379: root▲ ★ 2006/05/05(金) 04:00:46 ID:???0 BE AAS
FreeBSD 6.0R では、こうか。

/*
* Miscellaneous definitions.
*/
#define THR_STACK_DEFAULT (sizeof(void *) / 4 * 1024 * 1024)
380: root▲ ★ 2006/05/05(金) 04:02:22 ID:???0 BE AAS
SunOS さんが試したのは、5.3R か。

read.cgi再開発スレ Part2
2chスレ:operate

5.4R まで … 一律64K
6.0R, 5.5R 以降 … 32bit だと 1M 、64bit だと 2M

ということですか。
381: root▲ ★ 2006/05/05(金) 04:06:27 ID:???0 BE AAS
…ということは今の設定(>>357)は結果として、
1スレッドあたりのスタックサイズを 1/4 にしたことになるのかな。
382: root▲ ★ 2006/05/05(金) 04:08:33 ID:???0 BE AAS
という前提で >>360 を読むと、

> ThreadStackSize を OS のデフォルト値よりも小さな値にすることで、
> 子プロセスあたりの スレッド数をより多く持たせられるようになります。

が、とても気になりますね。
383: ◆SSu.zv/rvs 2006/05/05(金) 04:10:12 ID:BMUb5uVP0(7/13)調 AAS
なるのではないかと、
384
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 04:11:39 ID:b3qevcS80(3/10)調 AAS
通常、減らすのは、
ThreadsPerChild に 3000 とか、大きな値を指定する場合で、
普通なら減らす必要はないと思います。
385: root▲ ★ 2006/05/05(金) 04:11:53 ID:???0 BE AAS
つまり、これで試してみることには、おおいに意味があるかもしれないと。
386: root▲ ★ 2006/05/05(金) 04:13:39 ID:???0 BE AAS
>>384
ふむ、、、。

でも問題きりわけのためには、意味があるのかもですね。< 今の設定
387
(1): ◆SSu.zv/rvs 2006/05/05(金) 04:14:06 ID:BMUb5uVP0(8/13)調 AAS
スタック使いすぎでスワップが発生しているなら意味があるのではないかなぁ
そうでないなら意味ないと思う
388: root▲ ★ 2006/05/05(金) 04:14:42 ID:???0 BE AAS
>>387
メモリは余裕ある状態と思います。< live22
389
(1): ◆SSu.zv/rvs 2006/05/05(金) 04:15:39 ID:BMUb5uVP0(9/13)調 AAS
「スタック使いすぎで」はランボーないい方か、

子供たちにスタックを与えすぎて合計のメモリが逼迫しているならってことです
390
(1): root▲ ★ 2006/05/05(金) 04:24:09 ID:???0 BE AAS
…さて、そんななか明日以降の予定。

○ live22x4, live22x5 フロントに再投入(済)
○ live22x2 OS・Apache 更新(済)
・live22x3 復活 & フロントに再投入
・live22-2 (= cobra2247) 投入 with FreeBSD 6.1-RC2 or 6.1R => まずは問題解決しないと
・live22, live22x1 OS バージョンアップ + Apache 更新
391: root▲ ★ 2006/05/05(金) 04:27:02 ID:???0 BE AAS
>>389
なるほど。そういう意味ですか。

…このへん、状況の整理が必要そうですね。
>>325 >>328 の kern. なんたらの話も含めて。

で、今日はちとエネルギー切れという感じです。
といったわけで、そろそろ店じまいの時間で。
392
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 04:31:56 ID:b3qevcS80(4/10)調 AAS
>>325は私の書き込みですが、
procmapを使用して、VMのマッピング状態をみることにより、
Cannot access memory at address 0xXXXXXXXX の
0xXXXXXXXX がマッピングされているのか、
そのアドレスがスレッドスタック領域内か付近か見たかったわけです。

FreeBSDはgrow stackを使用するので、スレッドスタックが1MBだとしても、
最初は128kの領域しか取りません。以後は必要において1MBまで拡張されます。
通常の状態であれば、procmapを使って稼働中のhttpdの状態を見たときは、
下の方に多くの128kの領域があるはずです。
もし、スタックが拡張されていれば128k+拡張された領域が見えます。
393
(2): 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 04:36:01 ID:b7udRDHi0(1/3)調 AAS
スタックを小さくするのは、単にアドレス空間の枯渇を防ぐためですよ。

例えば某OSのデフォルトだと、スタックは1スレッドあたり10M程。
ということは、32bit環境では、どんなに頑張っても
400スレッド(事実上200以下)しか出来ないわけですね。

これを増やすために、1スレッドのサイズを減らすということで。
394
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 04:37:17 ID:b3qevcS80(5/10)調 AAS
kern.dflssiz, kern.maxssiz, kern.sgrowsiz は、
これらを設定した方が良いという意味ではなくて、
設定することにより動きが変わってくるので、確認の意味で書きました。
特に、kern.sgrowsizは、上記の最初の128kというサイズに影響を与えます。

kern.dflssiz, kern.maxssiz は、limit などで表示されるスレッドの制限に
影響を与えますが、これは最初の main スレッドの制限なので、
worker の場合はあまり関係ありません。
395
(1): ◆SSu.zv/rvs 2006/05/05(金) 04:38:00 ID:BMUb5uVP0(10/13)調 AAS
ちなみに、今話しているのはPentinumなマシンなんですよね?
396: 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 04:51:09 ID:b3qevcS80(6/10)調 AAS
>>393
そうですね。
FreeBSDはi386(32bit)だと、デフォルトのサイズは1MBなので、
デフォルトでは2500弱のスレッドしか作れないです。
よって、ThreadsPerChildもそのあたりが限界。
もし、ThreadsPerChildを3000とかにすると、pthread_create()が失敗するので、
Apacheが起動できません。
397: 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 04:55:53 ID:b3qevcS80(7/10)調 AAS
>>395
それは、amd64(64bit)ではなくて、i386(32bit)の話という意味でしょうか?
398: ◆SSu.zv/rvs 2006/05/05(金) 04:56:31 ID:BMUb5uVP0(11/13)調 AAS
x86といったほうがいいのだろか、
399: 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 05:01:22 ID:b3qevcS80(8/10)調 AAS
設定うんぬんということならば、
同じFreeBSDである限り、i386でもamd64でも変わらないでしょうが、
amd64だとVMのアドレス空間が莫大になるので、
アドレス空間の枯渇の問題は、ほぼ起こらないと思っていいでしょう。
400: root▲ ★ 2006/05/05(金) 05:03:40 ID:???0 BE AAS
おふろを出ると、話が進んでいるですね。

>>392
ふむふむ。

>>393
なるほど、わかってきました。

>>394
そういうことでしたか。
401
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 05:07:55 ID:lGySeUIB0(1)調 AAS
なんか「おいでよどうぶつの森」の博物館の
フクロウさんを思い出したのは内緒です。
402
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 05:10:59 ID:b3qevcS80(9/10)調 AAS
あと、kern.sgrowsizを設定しているかどうかにより、
Red Zone が作成されるかどうかにも影響を与えます。

FreeBSDは Thread A のスタックと Thread B のスタックの間に
Red Zone と呼ばれるアクセス読み書き不可の領域をわざとつくり、
Thread A が Thread B のスタックを破壊するのを防ごうとします。
ただ、grow stack のせいで、デフォルトの設定だと
Red Zone が作成されないんですね。

kern.sgrowsizの設定を尋ねたのは、Red Zone が作成される設定になっているか
確認する意味もありました。
403
(1): root▲ ★ 2006/05/05(金) 05:13:54 ID:???0 BE AAS
>>402
なるほど、
ということは、Red Zone を作る設定にすると、grow stack ではなくなる、
ということですか。

>>401
そのこころは、、、。
404
(1): ◆SSu.zv/rvs 2006/05/05(金) 05:15:07 ID:BMUb5uVP0(12/13)調 AAS
なんか 何十年たっても結局同じ話をしているんだなぁ
面白いっすね、

これからプログラムを書こうという人は是非ここを学んで欲しいと思ったりなんかして、
hehehe
405: root▲ ★ 2006/05/05(金) 05:20:15 ID:???0 BE AAS
>>404
> hehehe

表情が思い浮かんだですよ。

で、live22x3 HDD 交換完了とのこと。
これは明日以降、たんたんと。
406: 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 05:22:26 ID:b3qevcS80(10/10)調 AAS
>>403
これは仕様というか、まあバグに近いものだと思いますが、、、

1) Thread Library (libpthread or libthr)は、1MB + 4k(Red Zone)の領域を
mmap()を使用して作成する。
2) カーネルは、grow stack を使用するので、実際には 128k の領域しか作らない。
3) Thread Library は、最後の 4k の領域を、mprotect()を使用して、
読み書き不可に設定する。
4) カーネルは、最後の 4k は実際にマッピングしてないので、何もしない

ということで、デフォルトでは Red Zone は作られないんですね。
なので、Red Zone を作成するためには、デフォルトの1MBという大きさを
128kより小さくするか、kern.sgrowsiz を大きく設定して、最初から大きな
領域をスタックとして割り当てるかどちらかをする必要があります。

ちなみに、これも動きの説明で、kern.sgrowsiz を設定した方が良いという
意味ではないです。
407: root▲ ★ 2006/05/05(金) 14:30:27 ID:???0 BE AAS
cobra2247 ですが、oyster901 = ex14 でコンパイルした
GENERIC カーネルでブートしたところ、make buildworld buildkernel 通りました。

# -j 4 つけると 1 error になり、
# /usr/obj の下にひとつ usr -> var なシンボリックリンクが必要だった。
408
(1): root▲ ★ 2006/05/05(金) 16:07:12 ID:???0 BE AAS
live22x3 6.1-RC2 で復活。
これで、フロントはとりあえずの完成形に。

cobra2247 をやるか。
409
(1): root▲ ★ 2006/05/05(金) 16:22:44 ID:???0 BE AAS
>>408
いや、live22x1 のバージョンアップがありますね。
live22 もか。
410
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 16:31:02 ID:v0LBpmeQ0(1)調 AAS
>>409
姉(live22)のバージョンアップ作業ですが今日の深夜が無難な時間帯です。
明日はF1にダイバスターとサッカー、明後日はF1とサッカーがあります。
411: root▲ ★ 2006/05/05(金) 16:34:04 ID:???0 BE AAS
>>410
んじゃ、そうしますかね。

2時間程度、全部止める必要があるので。
412: root▲ ★ 2006/05/05(金) 16:38:23 ID:???0 BE AAS
【実況】 live22x Part18
2chスレ:operate

スケジュールしました。
準備しておくか。
413: root▲ ★ 2006/05/05(金) 21:29:25 ID:???0 BE AAS
-i 2 -I 60 → -i 10 -I 120 にした。 < bbsd
414: root▲ ★ 2006/05/05(金) 22:03:14 ID:???0 BE AAS
signal 10 で落ちる症状は変わらない模様ですね。

バージョンアップ前に、
いったん、 ThreadStackSize 262144 を元に戻すか。
他もいったん、設定の棚卸というかんじで。
415: 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 22:49:20 ID:b7udRDHi0(2/3)調 AAS
>>322
> esp 0xb858aa3c 0xb858aa3c
> ebp 0xb858aa58 0xb858aa58
ってのは、スタックオーバーフローなんですかね?

まあ、スタック領域がこの辺にあってもおかしくは無いのですが
むしろ、バッファオーバーフローで変な領域にspが設定されている気もします。
(ebpの退避されている領域にゴミが書かれると、espにも伝播して壊れるはず)

実行環境(FreeBSD/amd64)での、スタック/ヒープ/コード(リテラル)/静的データ(bssが別ならそれも)の
それぞれのおよその配置と比べてみて
esp/ebpに設定されているのがどの領域なのかは
確認してみたいところですが。
416
(1): 動け動けウゴウゴ2ちゃんねる 2006/05/05(金) 22:55:44 ID:b7udRDHi0(3/3)調 AAS
それと、
関連スレは全然チェックしてないのですが

Signal10の原因はOSかApacheのコアだというのは間違いないのですかね?
SpeedyCGIとmod_cgidso、及びdso版read.cgiが原因という可能性は?

というのは、もし単純なバッファオーバーフローがapacheのコア部分にあったら
簡単に発見されて修正されそうな気がするので
もしバッファオーバーフローであれば、追加モジュールに原因があるのではと。
417: root▲ ★ 2006/05/05(金) 22:59:19 ID:???0 BE AAS
<IfModule mpm_worker_module>
StartServers 64
ServerLimit 80
MaxClients 640
ThreadLimit 16 <= 8
ThreadsPerChild 16 <= 8
MinSpareThreads 64
MaxSpareThreads 512
MaxRequestsPerChild 1000000
MaxMemFree 16000
</IfModule>

こうしてみた。 < www/menu
418: root▲ ★ 2006/05/05(金) 23:00:28 ID:???0 BE AAS
>>416
live22 は read.cgi 動かしてないので read.cgi (cgidso) 動いてないです。
419
(1): root▲ ★ 2006/05/05(金) 23:36:01 ID:???0 BE AAS
cobra2247 準備が整いました。
あと、www2 の4号機と5号機の登録も。

まずは DNS 登録依頼いきます。

以下の追加登録をお願いします。

+live22-2.2ch.net:206.223.150.52:300
+www2f4.2ch.net:206.223.150.110:300
+www2f5.2ch.net:206.223.150.42:300
420: root▲ ★ 2006/05/05(金) 23:41:48 ID:???0 BE AAS
で、live22-2 を動かすには、
read.cgi と bbs.cgi を更新する必要があるですね。

もちろん、掲示板システムの入れ込みとか F22 (F15?) の起動とか、
そのへんも必要で。
421
(1): ◆SSu.zv/rvs 2006/05/05(金) 23:44:55 ID:BMUb5uVP0(13/13)調 AAS
なんでなんで?

前回その話になったとき、 live22x? を使うんじゃなく
別のvirtualをどんどん追加していくと言っていたような、
422: root▲ ★ 2006/05/05(金) 23:47:25 ID:???0 BE AAS
>>421
なるほどなるほど。

live22x っていう名前、変えてもいいんだった。
うっかりしていました。

news20 でよいですかね。
423: root▲ ★ 2006/05/05(金) 23:48:53 ID:???0 BE AAS
つまり、

cobra2247 = news20
tiger2523, 2524, 2525, 503, 507 = news20x1 〜 news20x5
424: root▲ ★ 2006/05/05(金) 23:50:56 ID:???0 BE AAS
というわけで >>419 はとりさげて、申請出しなおしますです。
425: root▲ ★ 2006/05/05(金) 23:52:48 ID:???0 BE AAS
というわけで、

live22x という名前で、複数バックエンドにする

もんだと、勘違いしていました。すんません。
news20(x) のつもりで、設定ごにょごにょしてくるです。
1-
あと 576 レスあります
スレ情報 赤レス抽出 画像レス抽出 歴の未読スレ

ぬこの手 ぬこTOP 0.047s