まだ重たいCMSをお使いですか?
毎秒1000リクエスト を捌く超高速CMS「adiary

2006/04/14(金)開発のつぶやき

一応使える状態になったので、サイトの日記をこちらに転記したいところ。自動化スクリプトでも書いた方がいいかもしれませんけどね(苦笑)

mixiの方には書きましたけど、元もとblogシステムのベースとなっているcgi用HTMLスケルトンシステム(Satsukiシステムと命名)が非常によく出来ている(自画自賛)ので、それを示すために作ったblogシステムと本末転倒気味ですけど(笑) 目標としてはRubyで動くtDiaryに対する、Perlで動くadiaryぐらいの位置づけになれればいいなーと思っております。Perlといえば、MovableTypeがありますが、あれはmod_perl2非対応なので(そしてDB必須だし、アホみたいに重たいし…)。

Perlは起動が遅いといいますか、インタプリタのPerlスクリプトをコンパイルしている時間が、起動時間の大半(本システムで約80%)を占めます。mod_perlやSpeedyCGIを使えば起動は早くできるのですが、レンタルサーバではそれは無理。データベース(BerkeleyDB含む)必須もレンタルには辛い。

使用するモジュールを徹底的に絞って、不必要なモジュールを直前までロードしないようにし、cgiとしての動作の高速化にはかなり気を使っています。環境非依存も、自前のテキスト型擬似データベース(GROUP BY が発行できちゃう(笑))を作成しました(テキスト型なので万が一の事態にも比較的安心です)。速度の方は、現状データ数がさほど多くないと、本格的なデータベースシステムよりよっぽど高速に動作してます(まだ逆転したことはないです)。個人で(シングルユーザーモード)で使う分にはまったく問題ないと思います。

2006/04/14(金)トラックバック - adiary拡張仕様(日本向け)

トラックバックの技術仕様 Version1.1に対する拡張です。

予備規定

  • 文字コードの表示。日本語の文字コードは「EUC-JP」「UTF-8」「Shift_JIS」「iso-2022-jp」のいずれかの文字列を指定すること。

トラックバックフォーム(POSTデータ)の拡張

  • トラックバックを受信する場合、未知のパラメータ(key)に対するデータは無視すること(規定外のフォームデータを送信してもよい)。
  • charset パラメーター。トラックバックの文字コードを示す。トラックバックが日本語文字を含む場合、必ず含まなければならない
  • x_author パラメーター。その記事を書いた人の名前を x_author として送信することができる(optional)。

トラックバック送信時のヘッダ拡張

  • トラックバックを送信時、クライアントはHTTPの定める「User-Agent」ヘッダを送信し、このときblogシステム(など)を名乗ることができる(optional)。

トラックバックURLへのGETの規定

  • トラックバックURLをGETした場合、サーバソフトは Content-Type ヘッダに、charset を付加し内部文字コードを示さなければならない。ここで示す内部文字コードでトラックバックを送信した場合、文字化けしないことを保証しなければならない

例)Contenet-Type: text/xml; charset=EUC-JP

  • トラックバックURLをGETした場合、サーバソフトは拡張ヘッダ「X-TB-Accept-Charset」を出力し、トラックバックとして受信可能な文字コードをカンマ区切りで示すことができる(optional)。

例)X-TB-Accept-Charset: EUC-JP, UTF-8, Shift_JIS, iso-2022-jp, iso-8859-1

updates

  • 2006/04/14 初版
  • 2006/07/24 author を author_name に変更(WordPressでの問題に対応)
  • 2006/08/01 WordPressへの対応のため、author_name を x_author に変更(fix)*1

*1 : Wordpress が author も author_name も特殊処理をした挙げ句、Queryを消去してくれるお茶目さんなので。おそらくセキュリティがらみだと思いますが……

2006/04/14(金)今後の課題~

とりあえず思いつく物。

  • 本格的なテキストパーサーの作成。はてなパーサーに似せる予定。
  • 画像アップロード。某アルバムシステムの作者さん次第(笑)
  • RSS、アンテナ用更新情報機能

その後のToDo

  • ドキュメントの作成と配布準備
  • メニューの整理と洗練
  • メールでの更新機能

ドキュメントの作成がえらい大変なんだよなぁ(笑)

2006/04/14(金)今日のsnapshot

  • 分類別の表示機能
  • 分類編集機能
  • 日記の削除機能
  • Trackback情報に author 追加

とか。データベースの仕様が変更になったので、mysqlの場合は

mysql> ALTER TABLE xxx_tb ADD (author text);

しましょう。array なんたらが見つからないとエラーが出る場合は、__cache以下をすべて消去してくたざい。

あとmysqlにクライアント文字コード指定を追加しました。文字化けする人はためしてください。adiary.conf.cgi に変更。

<$db = loadpm("DB_mysql", 'database=adiary', 'adiary', 'test', 1.connection_pool, 'ujis')>