X



トップページ運用情報
1001コメント246KB
bbs.cgi再開発プロジェクト4
■ このスレッドは過去ログ倉庫に格納されています
0001桃太郎 ★
垢版 |
04/12/02 19:52:43ID:???
peko鯖の稼動によりボトルネックの一つである事がより明らかになった
bbs.cgi作り直しプロジェクトです。

開発環境の工事現場
また挑戦。@2ch掲示板http://dso.2ch.net/myanmar/

関連は>>2-
0748名無し募集中。。。
垢版 |
04/12/06 16:14:41ID:52y0P5ZZ
タイムラグありすぎて連投してしまうんですが、ここにいるひとたちのせいですか?
特に専用ブラウザ(俺のはゾヌ2)の挙動がなんかヘン
0750不動楽 ★
垢版 |
04/12/06 16:37:09ID:???
dso発ではない旧スクリプトですが、携帯関連の調整します。
DNSが正常化するまでの緊急処置です。
0751動け動けウゴウゴ2ちゃんねる
垢版 |
04/12/06 16:41:36ID:4p7FvfKX
ex7の立てすぎなんとかしてー
0752不動楽 ★
垢版 |
04/12/06 16:41:41ID:???
通常の配布処理しては いけない サーバは、ex7以外にどこでしたっけ
0753不動楽 ★
垢版 |
04/12/06 16:44:04ID:???
あれ、配布して良いんだっけか…
0755FOX ★
垢版 |
04/12/06 16:53:06ID:???
よいはず
0767root▲ ★
垢版 |
04/12/07 03:16:10ID:???
>>766
ちょっと狼で書き込みテストしてみたけど、
書き込みは重くないみたい。
0768root▲ ★
垢版 |
04/12/07 03:25:37ID:???
見てると、どーもスレ立て爆撃みたいっすね。< ex7
不自然に負荷が上がることがあります。

サーバが落ちることはなさそうなんで、
わたし的にはどうすることも(りゃ。

ぼちぼちおふろ入って、ねるかな。
0774動け動けウゴウゴ2ちゃんねる
垢版 |
04/12/07 12:06:58ID:bRpOKfJi
FOX★様

ex7 の bbs.cgi で書き込み時に 500 Internal Server Error が出る時があります。
●を一度ログアウトして、再度ログインしてから書き込むと直ります。
ということは、おそらく、書き込み時の「再度ログインしてね」のパターンの時に
500 になるのだと思います。
お時間がありましたら調査よろしくお願いします。

以上
0776ひろゆき@どうやら管理人 ★
垢版 |
04/12/08 00:05:06ID:???
DBD::DBIって入ってるんでしたっけ?>だいたのサーバ
0778未承諾広告※ ◆TWARamEjuA
垢版 |
04/12/08 00:14:59ID:RJR+xQxy
>>776
DBI::DBD なら入っているかもです(苦笑)

無ければ、
$perl -MCPAN -e shell
して、
>install DBI::DBD
してみよう!
0779root▲ ★
垢版 |
04/12/08 00:21:13ID:???
>>776
bananaには入ってますね。下記はex5。
$ pkg_info -aI | grep DB
p5-DBD-mysql-2.9003 MySQL driver for the Perl5 Database Interface (DBI)
p5-DBI-1.41 The perl5 Database Interface. Required for DBD::* modules

tiger/cobraには入ってませんが、
寝るまでに、入れておきましょ。
0781root▲ ★
垢版 |
04/12/08 00:41:41ID:???
rootありサーバの標準キットに入れることにしたんで、
5.3Rなサーバには、今度全部 >>780 は入るです。
0782ひろゆき@どうやら管理人 ★
垢版 |
04/12/08 03:40:45ID:???
わーい。ありがとうございますー。
DBI::DBDだったか、、
0785FOX ★
垢版 |
04/12/08 07:30:10ID:???
>>772
何か直すとこありましたっけ?

>>774
修正してみたー
でもテストはしていない。
0787FOX ★
垢版 |
04/12/08 07:31:52ID:???
効いていないの?
0789FOX ★
垢版 |
04/12/08 07:34:29ID:???
そうなんだ、
ジンギスカンだからとか、
0791FOX ★
垢版 |
04/12/08 07:42:29ID:???
特に問題は出ていないようなので、
Tiger全部に入れてみよう bbs.cgi(Speedy版)
0792FOX ★
垢版 |
04/12/08 07:49:15ID:???
Tiger/Cobra は全部 bbs.cgi(Speedy版) になりました

live 8/16/17
news 18/19
game 9/10
hobby 7
ex 7
0793動け動けウゴウゴ2ちゃんねる
垢版 |
04/12/08 07:55:14ID:B4x378t7
tatesugiは効いてるけどなんか変なのが出てきた。@live16

━━━━━━━━━━━━━━━━

新このホストでは、しばらくスレッドが立てられません。
またの機会にどうぞ。。。
名無しさん@お腹いっぱい。 (0 , 1) 

ホスト****
てすと 
名前: 名無しさん@お腹いっぱい。
E-mail: 
内容:
てすとです


こちらでリロードしてください。 GO! 
分からないことがあったら2ちゃんねるガイドへ。。。

アクセス規制・プロキシー制限等規制は、2ちゃんねるビューア を使うと回避できることがあります。 
途中経過
はじまりはじまりー
SETTING.TXT よみこみむ? livesaturn
SETTING.TXT よみこみーlivesaturn
SETTING.TXT よみこみーlivesaturn完了!!
各種PATH生成 PATH=../livesaturn/
----------------------------------------
PATH =[../livesaturn/]
DATPATH =[../livesaturn/dat/]
TEMPPATH =[../livesaturn/html/]
IMODEPATH =[../livesaturn/i/]
INDEXFILE =[../livesaturn/index.html]
SUBFILE =[../livesaturn/subback.html]
----------------------------------------
PID=46987
time=1102460019
BBS.CGI - 2005 (SpeedyCGI = yes)(+Samba) 
0794FOX ★
垢版 |
04/12/08 07:57:45ID:???
当たりということで、
0796動け動けウゴウゴ2ちゃんねる
垢版 |
04/12/08 11:17:28ID:jTKsiamC
>>791
問題でまくりですが。。

ex7の板が1000スレを超える乱立で、既存スレが一掃されてます。。
そのままばら撒いたら、危険極まりないかと。
0800動け動けウゴウゴ2ちゃんねる
垢版 |
04/12/08 12:09:41ID:AZJ+q9H2
スレ乱立は止まってるはずだよ
0804動け動けウゴウゴ2ちゃんねる
垢版 |
04/12/08 13:27:36ID:4QK9QQ+X
つまりex7はtatesugiが効いていようが効いてまいがどちらか分からないぐらい糞スレばっかり立ってるって事だ。
0805FOX ★
垢版 |
04/12/08 13:43:46ID:???
つうことだ

気にスンナ、すんな
0807動け動けウゴウゴ2ちゃんねる
垢版 |
04/12/08 13:53:10ID:PFZjuYTD
tatesugiきいてない

VIPER狂喜乱舞してスレ立て祭り

ex7のほかの板にも立て始める

FOX ★が気付くけど何もしない

その板の住人がtatesugi効いてないことに気付く

その板の住人がスレ立て爆撃を始める

tatesugi直る

糞スレだらけの惨状(VIP以外)
0812FOX ★
垢版 |
04/12/13 03:31:00ID:???
>>684bあたりの続きなんですが
また壁にぶつかった。。。

0813FOX ★
垢版 |
04/12/13 03:33:25ID:???
if(open(AAA,"aaa.txt"))
{
my @ppp = <AAA>;
close(AAA);
$FOX->{XXX} = @ppp;
}

なんてことをやりたいのに、、、
$FOX->{XXX}を、あとで見てみると要素数(行数)が入っている
配列を代入するにはどうしたらいいの?
0814▲ 某ソレ511
垢版 |
04/12/13 04:05:20ID:32ZR8wok
こんな感じでうまくいたーよ

if(open(AAA,"aaa.txt"))
{
my @ppp = <AAA>;
close(AAA);
$FOX->{XXX} = \@ppp;
}

で、あとで
@{$FOX->{XXX}}
って感じで読み出す感じで。
0815動け動けウゴウゴ2ちゃんねる
垢版 |
04/12/13 04:09:34ID:LPQQCynf
>>748
ホットゾヌは1も2も飼い主が非公式板で悲鳴を上げております。
0816FOX ★
垢版 |
04/12/13 04:51:53ID:???
おぅおぅ
やってみるです >>814
0817root▲ ★
垢版 |
04/12/13 12:20:48ID:???
BBQ/BBX/BBY/BBS/BBM系をちょっとしたことで軽くできそう。
qb6で試してうまくいったみたいなので、飯の後にでもここに。
0818root▲ ★
垢版 |
04/12/13 13:28:15ID:???
全サーバに配布した。bananaのは変わったはず。>>817

○変更の内容

my $query_addr = "$4.$3.$2.$1.niku.2ch.net.";
のように、BBx系を使用する場合最後に"."をつけるようにした。

これで、DNS queryの時のドメイン名補完がなくなり、DNS検索のコスト(かかる時間)が下がります。

通常の場合、特にBBSのような「その名前はない」という応答の場合、

1) gethostbyname("a.b.c.d.bbs.2ch.net"); を実行、
2) a.b.c.d.bbs.2ch.net に対してDNS問い合わせ => 該当なし
3) a.b.c.d.bbs.2ch.net.maido3.com に対してDNS問い合わせ => 該当なし
4) 呼び出し元に「該当なし」を返す

のような検索をしています。

この変更で 3) がなくなるので、
特にBBSの場合、呼び出しコストが半分になるはず。
0819root▲ ★
垢版 |
04/12/13 13:30:11ID:???
>>818
これが使えるのは、

・BBQ (niku.2ch.net)
・BBS (bbs.2ch.net)
・BBY (bby.2ch.net)
・BBM (bbm.2ch.net)
・BBX (bbx.2ch.net)

の各問い合わせになります。

ということで、SpeedyCGI版bbs.cgiの更新作業を、
よろしくおねがいいたしますです。>FOXさん
0820FOX ★
垢版 |
04/12/13 14:12:14ID:???
おっ
やるやる
0821root▲ ★
垢版 |
04/12/13 14:13:29ID:???
>>820
おまけとして、maido3.com の DNSコンテンツサーバも軽くなるですね。
もうわかっておられると思いますが。
0822FOX ★
垢版 |
04/12/13 14:15:47ID:???
live16 でやってみた、
0824root▲ ★
垢版 |
04/12/13 14:18:49ID:???
>>822
予期した動作をしているか、DNSログ確認してみます。
0825root▲ ★
垢版 |
04/12/13 14:27:19ID:???
大丈夫の模様です。

(使用前、2回問い合わせ)
@4000000041bd256e17e11344 query 376306 7f000001:e90e:a283 1 1102914915.5078.ないしょ.0.52.1102912571.livenhk.live16.2ch.net.bbs.bbs.2ch.net.
@4000000041bd256e17e1da7c cached ns bbs.2ch.net. a.ns.bbs.2ch.net.
@4000000041bd256e17e224b4 cached 1 a.ns.bbs.2ch.net.
@4000000041bd256e17e276bc tx 0 1 1102914915.5078.ないしょ.0.52.1102912571.livenhk.live16.2ch.net.bbs.bbs.2ch.net. bbs.2ch.net. cedf9323
@4000000041bd256e181fd1c4 nxdomain cedf9323 2560 1102914915.5078.ないしょ.0.52.1102912571.livenhk.live16.2ch.net.bbs.bbs.2ch.net.
@4000000041bd256e18215864 sent 376306 103
@4000000041bd256e1824139c query 376307 7f000001:306f:a284 1 1102914915.5078.ないしょ.0.52.1102912571.livenhk.live16.2ch.net.bbs.bbs.2ch.net.maido3.com.
@4000000041bd256e1824e68c cached ns maido3.com. ns1.maido3.com.
@4000000041bd256e18251d3c cached ns maido3.com. ns2.maido3.com.
@4000000041bd256e182528f4 cached 1 ns1.maido3.com.
@4000000041bd256e182530c4 cached 1 ns2.maido3.com.
@4000000041bd256e1825638c tx 0 1 1102914915.5078.218.ないしょ.1102912571.livenhk.live16.2ch.net.bbs.bbs.2ch.net.maido3.com. maido3.com. cedf94fe cedf93fe
@4000000041bd256e183e5644 nxdomain cedf94fe 2560 1102914915.5078.ないしょ.0.52.1102912571.livenhk.live16.2ch.net.bbs.bbs.2ch.net.maido3.com.
@4000000041bd256e183f9a7c sent 376307 114

(使用後、1回のみ)
@4000000041bd257225883914 query 376313 7f000001:fc9b:a71c 1 1102914920.6534.ないしょ.0.10.1102912571.livenhk.live16.2ch.net.bbs.bbs.2ch.net.
@4000000041bd25722588c5b4 cached ns bbs.2ch.net. a.ns.bbs.2ch.net.
@4000000041bd25722588f87c cached 1 a.ns.bbs.2ch.net.
@4000000041bd25722589275c tx 0 1 1102914920.6534.ないしょ.0.10.1102912571.livenhk.live16.2ch.net.bbs.bbs.2ch.net. bbs.2ch.net. cedf9323
@4000000041bd257225e97f6c nxdomain cedf9323 2560 1102914920.6534.ないしょ.0.10.1102912571.livenhk.live16.2ch.net.bbs.bbs.2ch.net.
@4000000041bd257225ead344 sent 376313 100
0826FOX ★
垢版 |
04/12/13 14:29:35ID:???
んじゃ 順次、順二、淳二
0829FOX ★
垢版 |
04/12/13 15:35:49ID:???
>>814
やってみたけど、 $FOX(SpeedyCGI においてグローバル) では
うまく行かなかったです。

どうしてかなぁ
0830動け動けウゴウゴ2ちゃんねる
垢版 |
04/12/13 17:30:20ID:DB7UVgUV
これでどうかしらん。

if (open(AAA, "aaa.txt")) {
@{$FOX->{XXX}} = <AAA>;
close(AAA);
}

でもグローバルなら安直に

@FOX_XXX = <AAA>

でいいような気がする。
0831FOX ★
垢版 |
04/12/13 18:45:21ID:???
>>830
たしかに、、、

ただ、将来の変更への耐性が落ちるか、
それはその時にその担当者に頑張ってもらおう。
0832FOX ★
垢版 |
04/12/14 14:34:57ID:???
file i/o を減らすのだ 第八弾(ID生成ルーチン)

1) 毎回 HDD にアクセスしているのを何とかしたい、
2) 毎月同じIDになるのを何とかする?
3) あとなんかあったっけ?

今 コード出します。
0833FOX ★
垢版 |
04/12/14 14:36:21ID:???
{

#IDを生成する
use Digest::MD5;
my $md5 = Digest::MD5->new;

use Digest::MD5 qw(md5_hex);
#my $idnum = md5_hex($ENV{'REMOTE_ADDR'});
my $idnum = md5_hex($GB->{IDNOTANE});

$idnum = substr($idnum,-4);

$md5->add($idnum);
$md5->add($GB->{FORM}->{"bbs"});
#$md5->add(substr($GB->{DATE},6,2));
my $md5datefile = "$GB->{PATH}/md5.cgi";
if(-e $md5datefile){
open(MD5FILE,"<$md5datefile");
my $md5line = <MD5FILE>;
close(MD5FILE);
my ($md5date,$md5number) = split /<>/,$md5line;
if($md5date eq $GB->{MD5DATE}){
$md5->add($md5number);
}else{
open(MD5FILE,">$md5datefile");
my $data = "";
sysopen(RANDOM, "/dev/random", O_READ) || die "cannot open /dev/random $!\n";
sysread(RANDOM, $data, 16);
close(RANDOM);
print MD5FILE "$GB->{MD5DATE}<>$data";
close(MD5FILE);
$md5->add($data);
}
}else{
open(MD5FILE,">$md5datefile");
my $data = "";
sysopen(RANDOM, "/dev/random", O_READ) || die "cannot open /dev/random $!\n";
sysread(RANDOM, $data, 16);
close(RANDOM);
print MD5FILE "$GB->{MD5DATE}<>$data";
close(MD5FILE);
$md5->add($data);
}
chmod(0777,"$md5datefile");
my $idcrypt = $md5->b64digest;
$idcrypt = substr($idcrypt,0,8);
0834動け動けウゴウゴ2ちゃんねる
垢版 |
04/12/14 16:37:18ID:dKRMgTcD
こんな感じ?

use Digest::MD5;
use Digest::MD5 qw(md5_hex);

my $md5datefile = "$GB->{PATH}/md5.cgi";

if (!defined $FOX->{MD5NUMBER}) {
# まだ読み込まれていない
open(MD5FILE, "<$md5datefile");
my $md5line = <MD5FILE>;
close(MD5FILE);
($FOX->{MD5DATE}, $FOX->{MD5NUMBER}) = split(/<>/, $md5line, 2);
}

if ($FOX->{MD5DATE} ne $GB->{MD5DATE}) {
# 日付が変わったので作り直し
my $data = '';
sysopen(RANDOM, '/dev/random', O_READ) || die "cannot open /dev/random $!\n";
sysread(RANDOM, $data, 16);
close(RANDOM);
open(MD5FILE, ">$md5datefile");
print MD5FILE "$GB->{MD5DATE}<>$data";
close(MD5FILE);
chmod(0777, $md5datefile);
$FOX->{MD5DATE} = $GB->{MD5DATE};
$FOX->{MD5NUMBER} = $data;
}

#my $idnum = md5_hex($ENV{'REMOTE_ADDR'});
my $idnum = md5_hex($GB->{IDNOTANE});

my $md5 = Digest::MD5->new;
$md5->add(substr($idnum,-4));
$md5->add($GB->{FORM}->{"bbs"});
#$md5->add(substr($GB->{DATE},6,2));
$md5->add($FOX->{MD5NUMBER});
my $idcrypt = substr($md5->b64digest, 0, 8);
0836▲ 某ソレ511
垢版 |
04/12/14 17:22:01ID:VWWSBm/+
やぱ、プロセス最初の起動で
2つのデータを読み込む、あたりが一番楽だと思う。

と思ったら、>>834で十分だいじょぶっぽいか。
0838マァヴ ★
垢版 |
04/12/14 17:27:14ID:???
ああ、なつかしのID生成ルーチン(^_^;)
ID生成ルーチンのセオリーとしては
「ルーチンを公開しても、リモホやIPが推測できない」
です。
0840FOX ★
垢版 |
04/12/14 17:48:04ID:???
>>834 みたくして、

日付の変わる 24時のあたり大丈夫ですかねぇ

a) bbs.cgi は何十本も常駐している。
b) 寿命は現在10分である

というあたり、
0841
垢版 |
04/12/14 17:55:02ID:kwpC6qYO

 1)どこぞのexで実験する
 2)じっけん じっけん
 3)おやつは300円までですよ
0843FOX ★
垢版 |
04/12/14 17:59:13ID:???
んじゃ dsoで、そしてex9へ
0844未承諾広告※ ◆TWARamEjuA
垢版 |
04/12/14 18:27:42ID:mhtbHAbI
うぅむ、、、/dev/randomからの採取は、crondで毎日00:00に採取して、ファイルにして保存。
bbs.cgiで、1回取得しておけばSpeedyに引っかかって、ごっつぅえぇ感じになるかと♪
■ このスレッドは過去ログ倉庫に格納されています

ニューススポーツなんでも実況