X



【Perl】掲示板を使ろう!
0001名無しさん@お腹いっぱい。
垢版 |
2001/05/03(木) 20:56ID:lB9ErFH.
-前スレッド http://tako.2ch.net/test/read.cgi?bbs=perl&key=959378033&ls=50
-PHP版  http://corn.2ch.net/test/read.cgi?bbs=php&key=982779383&ls=50

今のところのまとめ。
■ほういち氏
  ▽サンプル掲示板
    http://www13.big.or.jp/~bell/nanashi/perl/
  ▽ソースコード
    http://www13.big.or.jp/~bell/cgi-bin/files/
    http://xbbs21.virtualave.net/xbbs/up/src/up010.lzh
■347氏
  ▽サンプル掲示板
    http://takotubo.virtualave.net/bin/board.cgi
  ▽ソースコード
    http://xbbs21.virtualave.net/xbbs/up/src/up022.lzh
■570氏
  ▽サンプル掲示板
    http://maasa.antique.to/2ch/sample/index.html
■panton氏
  ▽ソースコード
   http://www.panton.f2s.com/bbs/lib/IndexedFile.html
   http://www.panton.f2s.com/bbs/lib/IndexedFile.pm.txt
0003panton
垢版 |
2001/05/03(木) 22:42ID:???
ども。
俺のは下のURLに変えているので、
http://www.panton.f2s.com/bbs/lib/IndexedFile.pm
訂正させてください。
一応説明させていただくと、
データファイルの高速ランダムアクセスを、
インデックスファイルにより実現するモジュールです。
データの要素にはハッシュが格納できます。
構想中のBBSシステム用に作った物ですが、汎用のモジュールなので、
使ってみてバグを見つけてくれるとうれしい。
0004名無しさん@お腹いっぱい。
垢版 |
2001/05/03(木) 23:23ID:???
暇だからpanton氏のも試してみるかな。
347氏もそろそろハンドルを名乗るのがいいと思われ。
ほういちさんの所は止まってるなあ・・・
570氏のはどうだろう・・・・
gunzipさん最近見かけないな。病院が忙しいのかな?
0009
垢版 |
2001/05/04(金) 08:20ID:???
。。。。。。。コピペしたから気付かなかった。。。。。。
001081
垢版 |
2001/05/04(金) 08:22ID:???
>>9
あう、重ね重ね申し訳ない・・・
0012名無しさん@お腹いっぱい。
垢版 |
2001/05/04(金) 23:26ID:???
>>11
(1) みんな黄金週間で遊びまわっている。
(2) 世間が黄金週間のうちに仕事の遅れをとりもどそうと必死。
私は(2)です・・・
0014347
垢版 |
2001/05/06(日) 16:48ID:???
>>4
名無しさんの逆ってのが良くてそのまま使ってましたが。。。
これじゃだめかな?

しばらくやれるかどうか。。。
00154
垢版 |
2001/05/06(日) 19:13ID:???
>>14
なるほど・・・・言われてみれば確かに逆。
いやいやハンドルは何だっていいです。頑張って
0016_gunzip@お仕事やめたい
垢版 |
2001/05/07(月) 06:04ID:???
■■■■■■■□□□□□□□□□□□□□□□□□□□
0      20      40      60      80       100

■終わった
-IxAccessFile.pm (ログ、スレッド管理の入出力関係用)
-Article.pm (各投稿記事用クラス)
-post.cgi (1スレッド用・・・極めていいかげん)
-rm.cgi (投稿者/管理者記事削除)

□手を付けてない
-投稿制限 #後回し
-記事訂正 #コレは簡単
-admin.cgi (そのまま) #面倒くさい
-setup.cgi (そのまま) #たぶん要らない
-post.cgi (複数スレッド用) #時間無い

▽あるといいな(なくてもいいな)
Storable or FreezeThaw or Data::Dumper
▽気が向けば
-tmpl_parse.pl (テンプレートファイルからコードを書かせ・・・たいなあ)

#コメント
入出力関係のは出来ているので(一応)、後は割とラクダと思う。
GW殆ど(というか全く)休めず、時間が全くとれないので捗らん(ぐは)
0017_gunzip@お仕事やめたい x 50
垢版 |
2001/05/07(月) 06:13ID:???
>>panton氏
=line 248
>my $pointer = $self->_getpointer($id);
この部分は不要ですよね。既に$idからファイル内の位置が得られているのですから。
----------
あと、ドキュメントのBUGSとTODOに記載されている各項について
("バリューに改行が入っているデータは扱えない。"・・・とか)
何か書こうかと思ったけれど・・・ちょっと後回しにします。
#「配列、スカラーへの対応」とかはどうするのかなあ・・・と興味が。
0019名無しさん@お腹いっぱい。
垢版 |
2001/05/07(月) 06:28ID:???

  ∧ ∧   / ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄
  (,,・∀・) < あんまり無理するなよ
〜(___ノ   \_______________
0020名無しさん@お腹いっぱい。
垢版 |
2001/05/07(月) 17:13ID:???

  ∧ ∧   / ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄
  (,,・∀・) < 楽しみに待ってるぞ >>all
〜(___ノ   \_______________
0023panton
垢版 |
2001/05/09(水) 22:30ID:???
>>17 _gunzip氏
(248行目でしたが・・)確かにそうですね。修正します。

> ("バリューに改行が入っているデータは扱えない。"・・・とか)
> 何か書こうかと思ったけれど・・・ちょっと後回しにします。
> #「配列、スカラーへの対応」とかはどうするのかなあ・・・と興味が。

うーん、考えどころです。
StorableとかFreezeThawとか使っちゃえば、必然的にそこらへん
全て解決するし、もっと言えば、メッセージオブジェクトとか
突っ込んじゃえばさらに楽だよなぁ・・・とか。
0025age
垢版 |
2001/05/18(金) 18:49ID:???
age
0027age
垢版 |
2001/05/22(火) 17:48ID:VQJfqVeI
age
0029名無しさん@お腹いっぱい。
垢版 |
2001/06/02(土) 07:33ID:???
長らくご愛顧頂き誠にありがとうございました。

===========終了===========
0032名無しさん@お腹いっぱい。
垢版 |
2001/06/07(木) 16:01ID:???
特に2ch型とかにしなくてもいいから、とりあえず基本中の基本、
みたいなシンプルなヤツを誰か書いてくれんだろうか…
Perl上手い人ほど、わざわざシンプルなのって書かないんだよね。
0033名無しさん@お腹いっぱい。
垢版 |
2001/06/07(木) 16:28ID:???
いつぞやの七行BBS
#!/usr/local/bin/perl
%f=map{tr/+/ /;s/%(..)/pack("H2",$1)/eg;s/</&</;s/>/&>/;$_}split/[&=]/,
$ENV{QUERY_STRING};$f{n}||="名無し";open F,"+<bbs.dat";flock F,2;$e=
"$f{n} &>$f{m}<BR>\n"if($f{m});@e=($e,<F>)[0..20];seek F,0,0;print F @e;
print"content-type: text/html\n\n<title>BBS</title><h1>BBS</h1><form
action='bbs.cgi'><p>名前<input name=n value='$f{n}'><br>記事<input name=m
size=50><br><input type=submit></p></form><hr><p>@e</p><hr>";
__END__
>>32
シンプルだぞ(笑)
0035名無しさん@お腹いっぱい。
垢版 |
2001/06/07(木) 21:20ID:???
>>33
元スレの25だけど、無駄なファイルアクセス避けるためには、
$e="$f{n} &>$f{m}<BR>\n"if($f{m});@e=($e,<F>)[0..20];seek F,0,0;print F @e;
は、下みたいにしたほうがいいかもね。
@e=<F>;if($f{m}){seek F,0,0;print F @e=("$f{n} &>$f{m}<BR>\n",@e)[0..20]}
003633
垢版 |
2001/06/07(木) 21:53ID:???
>>35
なるほど。発言があったときのみ書き込むわけですね。

ぢつは33=元スレの20だけど、こりゃ20原案25作成ですね。
フォームの解析なんてホント目から鱗でした。
マジ勉強になります。
003732
垢版 |
2001/06/07(木) 22:44ID:???
>>33
それ、スゴーク好きなんだけど、もうちょっと何か…(;´ー`)y-~~
でも勉強になりました。
0045rubbish_lister
垢版 |
2001/06/11(月) 22:47ID:oKTfyTH6
panton氏のIndexedFile.pmを見ましたが、いいですねぇ。
BBSを作るのがかなり楽になりそうです。

恩恵に預かるだけでは良くはならないので、
ソース中で幾つか気になった点を書いておきます。


* line 154
これは
sub articles{ return @{ $_[0]->{_idxlist} } }
でいいのではないでしょうか。

* IO::File
IO::Fileはかなり大きいので使わずに済ませてもいいのでは?
CGIスクリプトとしての動作が前提なので、軽くしてまずいという事は無いかと。

* "$_"
気付いておられると思いますが、
所々暗黙の$_を使用していますね。
これもついでに。
0047rubbish_lister
垢版 |
2001/06/11(月) 23:30ID:oKTfyTH6
>>46
いや、$_がダメってことは無いですよ。
ただ使うならばlocal宣言して欲しい…ということです。

# 消えるとまずいデータは極力$_に入れないようにしてはいますが
004846
垢版 |
2001/06/12(火) 00:23ID:???
>>47
そういう意味なんすか
サンクス
0049初期不良
垢版 |
2001/06/12(火) 01:00ID:MAetbv9U
>>47
確かにそれ関係でばぐった時はちょっとやっかいだった
0051ウェブ作成初心者
垢版 |
2001/06/27(水) 00:45ID:DrGg5Duk
PERLなんて奇特なもんしりゃーせんです、ハイ。
知ってるのは“REMEMBER PEARL HABOR”くらいッス。

www.tripod.lycos.comとかはどうやって ウェブサイトや掲示板を作るかよくわかりません。
とりあえずトライポッドに無料サイトを開設して掲示板を設置したいのですが、
ウェブ作成関連のプログラミングにめちゃ詳しい方教えてください。
メモ帳でcgiファイル?を作ってアップする?とか意味がわかるようでわからないです。
0055名無しさん@お腹いっぱい。
垢版 |
2001/06/29(金) 02:23ID:4xodowQE
いま掲示版作っています。

データファイルをCSVに使用と思ってるのですが、CSVって、クオーテーションマークだけをエスケープすれば委員ですよね。
あと、CRとかLFとかもエスケープしたいのですが、どうすればいいですか・?

<br>に変換するにはあんまり美しくない気がして。
0056名無しさん@お腹いっぱい。
垢版 |
2001/06/29(金) 02:33ID:4xodowQE
うん
0058名無しさん@お腹いっぱい。
垢版 |
2001/06/29(金) 11:56ID:HUBABICM
>>55
CRLFも、クオーテーションマークでくくれば、
エスケープの必要なし。
005958
垢版 |
2001/06/29(金) 11:57ID:HUBABICM
惜しい、もうすこしでIDがBASICだったのに…
0062名無しさん@お腹いっぱい。
垢版 |
2001/06/30(土) 20:10ID:rUTTiUww
CSVについて
" " で囲みさえすれば、エスケープする必要があるのは、" 自身だけではないのでしょうか。
0063名無しさん@お腹いっぱい。
垢版 |
2001/06/30(土) 20:18ID:???
掲示板のデータファイルを考えているのですね。
CSVのモジュールを使えば、そんなこと考えなくてもいいのでは。
0065名無しさん@お腹いっぱい。
垢版 |
2001/07/01(日) 09:11ID:Q4XVcLok
uzee
0066panton
垢版 |
2001/07/04(水) 04:10ID:iYqhBR52
>>45 rubbish_lister様
遅レスで申し訳ないです。

> * line 154
> これは
> sub articles{ return @{ $_[0]->{_idxlist} } }
> でいいのではないでしょうか。

あれ?こうすると、配列でなくリストで返されて、スカラーコンテキストだと、
採用されるのは要素数ではなく最後の要素になっちゃうと思ったんですけど、
違うんですね。勉強になりました。
オーバーヘッド的にはどうなんでしょう?
挙動から予想すると、配列全部ではなく、
要素数が帰ってるみたいなので、大丈夫なんでしょうか?

IO:Fileはそのとおりです。
以前TODOに入れてたような気がしたけど、ないですね。TODOで。

$_ は個人的に混乱しない限り使わせていただきます。
Perl大好きっ子なんで。
0067名無しさん@お腹いっぱい。
垢版 |
2001/07/06(金) 22:51ID:???


  ∧ ∧   / ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄
  (,,・∀・) < さっぱりだよ。
〜(___ノ   \_______________
0068名無しさん@お腹いっぱい。
垢版 |
2001/07/08(日) 17:52ID:???
初歩的な質問ですみませんが、
データファイルって、読み込みの時にもロックした方がいいですか?

それから、レスを多次元配列に入れてから書き出したいのですが、
配列全体のサイズが100KBとかになっても問題ないですか
0069名無しさん@お腹いっぱい。
垢版 |
2001/07/09(月) 00:38ID:vYQpj6T6
>>68
おれはflockが使えるときは読み込みのときでも
flock(FILE, LOCK_SH) ってやってるよ。
ただしsymlinkを使ったりする場合は読み込みではロックしない。

配列サイズは、サーバのメモリ容量とアクセス頻度を考慮して
判断すべきだから一概にいえないけど、
うちの環境では100KBならまず気にしない。1MBだと気にするかも。
0070名無しさん@お腹いっぱい。
垢版 |
2001/07/09(月) 10:12ID:8Wkoq3g6
>69
気にしてください、お願いします
0072名無しさん@お腹いっぱい。
垢版 |
2001/07/09(月) 10:34ID:???
>>70
そっか、そうすると
たとえばデータファイルで100行分、まあ、レス100を表示するとすると、
データファールから1行読み込んで、書き出し、1行読み込んで書き出し
みたいにするのが現実的デスカ。

たとえばスレッドID、はじめのレス番号、最後のレス番号を与えると、
そのレスの内容を配列で返す。みたいな関数を作って、というのが楽そうだったのだけど、
あまりおすすめできないと言うことですね。
0075名無しさん@お腹いっぱい。
垢版 |
2001/07/10(火) 23:59ID:???
更新時に、

lock
更新対象読み込み
更新対象変更
更新対象書き込み
unlock

すれば、壊れないよ。
ただ、更新中に読む奴がいたら表示は狂う。

いちばんいいのは、全部一時ファイルに書き出して一気にrename。
これなら事実上ほとんど表示も狂わない。
ただ、読み込みアクセスが多いと更新失敗する確率は高くなるけど。
0076panton
垢版 |
2001/07/14(土) 06:17ID:8g/6IMoE
オヒザシブリデゴザイマス
IndexedFile.pm を更新しました。
http://www.panton.f2s.com/bbs/lib/IndexedFile.pm
http://www.panton.f2s.com/bbs/lib/IndexedFile.html

IO::Fileの使用廃止と、色々バグ修正があります。
前のバージョンには重大なバグがありました。

見つからなかったってことは、全然使われてねーんだな。
っと思って、手抜きテスト用ボードなんか用意してみました。
http://www.panton.f2s.com/bbs/sbbs.txt
http://www.panton.f2s.com/bbs/sbbs.txt (ソース)

たいしてテストしてないのでまだバグあるでしょう、・・見つけてよーん。
0078_gunzip
垢版 |
2001/07/14(土) 08:49ID:???
では二つ三つ.......。
--------------------------
キー名に英数字以外のものが含まれているとおかしくなりますね。
("@threads"とか"perl-user"とか。)
196行目の
>my %hash = ('DUMMY', split /^(\w+?):/m, readline($self->_dathandle));

my %hash = ('DUMMY', split /^(.+?):/m, readline($self->_dathandle));
にすれば回避は出来ますが...。
--------------------------
modify_row()使用時、更新されたデータは、
データファイルの末尾に追加+インデックス更新されるわけですが、
頻繁に同じ項目を更新するような場合、ファイルの肥大化が問題にならないかな....。

例えば、掲示板のスレッド毎に情報をハッシュの形で格納してある場合
%thread = (
    count => 77, #投稿数
    subject => "【Perl】掲示板を使ろう!",
    key => 988890976,
    server => "http://corn.2ch.net/",
    dir => "php"
);
投稿がある→そのスレッドの情報を取得( get_by_id() )→(何らかの処理)
→投稿数をインクリメント→スレッド情報更新( modify_row() )
Ex.
$thread = $logfile->get_by_id($id);
$thread->{ count }++;
$logfile->modify_row($id, $thread);
とすると、投稿の度にハッシュ$threadの内容は末尾に追加されるので
(スレッドの情報ログのサイズ) = ( (スレッドの情報サイズ) * (投稿回数) ) * (スレッド数)
になってしまいますね。

・・・と、ここまで書いたときにsynchronize()を思い出した....。
例えば、スクリプト側で
if( $thread->{ count }++ % 5 ){
     $logfile->synchronize();
}
としておけば問題ないね。

いくらかのパディングを余分に取っておいて、
更新された情報が元の場所に収まりそうならそのまま上書きし、
無理なら末尾に回す、とするのもイイかもかも。
0079_gunzip
垢版 |
2001/07/14(土) 08:49ID:???

あと、198行目の
>chomp $hash{$_} foreach keys %hash;
は、スライスで
chomp @hash{ keys %hash };
と書けたりします。(参考までに)
0081名無しさん@お腹いっぱい。
垢版 |
2001/07/16(月) 17:17ID:???
はじめまして。現在機能優先で掲示板を作っていて、コードの
効率は後回し中なのですが、いくつか質問があります。

・一般ではOpenでテキストを読み書きするのが多いようですが、
(MINIBBS程度の規模でも)TieやDBOPENを使ったものが見かけないのは
なぜですか?負荷について問題があるのでしょうか?

・発言データに関して、追加書き込みモードを基本にしてもファイルロックは
必要でしょうか?またどの程度の堅牢性を期待すべきでしょうか?

・読み出しに関して、基本的なスクリプトでは@LINE=<FILE>と
していますが、While(<FILE>)やその他の方法のうち、お勧め
なのはどれでしょうか?また、Seekを使った読み出しについて
教えてくださいませんか?
0082panton
垢版 |
2001/07/16(月) 19:29ID:YjhPdxYw
>>81
ageで書いてもいいんじゃないかと思うけどなんでsage?

> ・TieやDBOPENを使ったものが見かけないのはなぜですか?
>  負荷について問題があるのでしょうか
掲示板の場合リニアなデータ構造が多いのでハッシュがメインの
タイは不向きといえば不向き。配列を結びつける事も出来るが、
インターフェイスが不完全。

> ・追加書き込みモードを基本にしてもファイルロックは
>  必要でしょうか?
必要です。堅牢性についてはデータの重要性によります。

> ・読み出しに関して、基本的なスクリプトでは@LINE=<FILE>と
> していますが、While(<FILE>)やその他の方法のうち、お勧め
> なのはどれでしょうか?
>>69あたりからを読んでください。
seekに関しては、固定長なら使えるけど、掲示板のように
データ長が不定なデータだと不向き。

そこら辺を解決するためにIndexedFile.pmを作ってるんですが・・・
0083名無しさん@お腹いっぱい。
垢版 |
2001/07/16(月) 19:58ID:SlpU2cdo
>>82
age忘れです。

リニアな構造ということですが、発言IDやTIMEをキーにして
残りは従来のままスカラーでもよいと思ったんですが、、、。
負荷についてわからないというのは、ハッシュでは数百発言とも
なると負荷がかかるのかとか、あるいは値のサイズによって
負荷が変わるのかとかも考えたのですが。

追加書き込みモードについては、一般に恐れているのは
全部読み出し>退避+追加>全部書き出しの過程での全データ
消失だと思うので、追加書き込みでの危険性があまり認識
できないのです。
0084panton
垢版 |
2001/07/17(火) 15:17ID:/BDSxh5c
>>83
リニアというのは、掲示板は発言の並びに順番があるということです。
TIMEなどをキーにしてkeysでsortなんかをすることも出来ますが、
DBMの起動オーバーヘッドなんかを考えると、
あえて使う必要も無いかなという程度です。
記事数や値のサイズによる負荷の増加は気にするほどではないと思いますが、
よく知りません。

ファイルロックについては、いろんなところで調べてみるといいと思います。
追記モードでも同時に起こると、ファイルの同じ位置に書き込もうとして
データがおかしくなります。
0085名無しさん@お腹いっぱい。
垢版 |
2001/07/17(火) 17:07ID:sUEgTyfs
>>84
ありがとうございます。

あと他にも、疑問が生じたときに、理由は自分で考えてみたのですが
これでいいのでしょうか?

while (<FILE>)よりも@line <FILE>のほうが、読み込み時に
早くcloseを行うのでよさげ
・・・・>読み込み時は共有可、書き込み時はどっちみちロック

ANHTTP環境ではflock不可
・・・・>Renameロックかflockコメント化で我慢

全読み>全書き込みvs追加モード
・・・・>ファイルアクセスより管理性重視?

レスポンスお願いします。
0087名無しさん@お腹いっぱい。
垢版 |
2001/07/17(火) 19:12ID:HRgjK2II
>>86
それは最悪でしょう。
そいういうものこそDB_FileのDB_RECNOを使うほうが良いと思いますがね。
0089名無しさん@お腹いっぱい。
垢版 |
2001/07/17(火) 22:22ID:???
>>85
> while (<FILE>)よりも@line <FILE>のほうが
なんでそんな結論になったのか知らないけど、普通ダメ。過去ログ読めよ。
> ANHTTP環境ではflock不可
HTTPDとflockは関係ありません。
> 全読み>全書き込みvs追加モード
質問の意味がわかりません。

なんか基本的なところがわかってないんじゃない?
CGI-MLとかの過去ログでも漁って勉強してきましょう。

>>88
全部読み込んでから[5]だけ残して他は捨てるっていう動作。
0090名無しさん@お腹いっぱい。
垢版 |
2001/07/18(水) 01:34ID:???
>>85
> while (<FILE>)よりも@line <FILE>のほうが、読み込み時に
> 早くcloseを行うのでよさげ
いくらclose()したって、ねぇ…。
89さんの言う通り、避けるべきかと。
「負荷」とか「メモリ」という言葉を(以下略
0091名無しさん@お腹いっぱい。
垢版 |
2001/07/18(水) 13:28ID:aJuOjafs
>>90
それは今になってみたら分かります。が、
初心者はこんなことを思っていたという、、、、。

>> ANHTTP環境ではflock不可
>HTTPDとflockは関係ありません。
御免なさい、WIN95+ActivePerl+〜というべきでした。

>> 全読み>全書き込みvs追加モード
>質問の意味がわかりません。
何で追加モードがあるのに、わざわざ全読み全書き込みするのか、という
ことです。
0093名無しさん@お腹いっぱい。
垢版 |
2001/07/19(木) 04:20ID:???
>>91
追加は追加。増える一方。
書き換えも行わない。

全読み全書きは、中途での処理の可能性を残している。
本当に全部書いてるのか?
加えて、書き換えてるんなら同じじゃない。

実際にテストして考えてから書き込んでくれ。
0095名無しさん@お腹いっぱい。
垢版 |
2001/07/19(木) 13:12ID:???
(既存の掲示板スクリプトは)何で追加モードが・・・
ってこと?
そういうのばかりでもないし、そうする必要があるのかもしれないし、
ただ馬鹿なだけかもしれない。
どっちにしろ他人のスクリプトなんてどうで良い。
0098名無しさん@お腹いっぱい。
垢版 |
2001/07/19(木) 19:13ID:FUSlV7zU
>>95
納得。 レス感謝

あとはレス行為に感謝
0099名無しさん@お腹いっぱい。
垢版 |
2001/07/19(木) 21:37ID:1tfXBWXc
>>96 >>94
どっちなの
レスを投稿する