Apache の rotatelogs コマンドを使ってみる

いつも Apache のログは logrotate でローテーションさせてるんですが PostgreSQL のように単体?でできないかなと思っていたら ちゃんとそういうコマンドがあるようです。

[参考]
Apache のログ管理 | バシャログ。

さっそく設定してみます。 Ubuntu10.04 では rotatelogs は /usr/sbin に入っていました。

$ which rotatelogs
/usr/sbin/rotatelogs

自分でコンパイルした場合は prefix の指定配下の bin に入ります。 私は Apache2.4.2 を /usr/local/apache242 に入れたので rotatelogs は /usr/local/apache242/bin になります。

$ vi /usr/local/apache242/conf/httpd.conf

CustomLog の設定を参考サイトに合わせて変更します。

【変更前】
CustomLog "logs/access_log" common

 ↓

【変更後】
CustomLog "|/usr/local/apache242/bin/rotatelogs logs/access_log.%Y%m%d 86400 540" common

Apache を再起動。

$ sudo /usr/local/apache242/bin/apachectl restart

アクセスするとログが出力されます。

$ ls -1 /usr/local/apache242/logs
access_log
access_log.20120428
error_log
httpd.pid

これで Apache だけでログのローテーションが設定できるようになりました。

Apache2.4 の新機能 mod_sed を試してみる

Apache2.4.2 が出たので、インストールついでに mod_sed を試してみたいと思います。

ダウンロードしたソースをコンパイルするわけですが APR を入れていないと configure でエラーになります。

$ ./configure --prefix=/usr/local/apache242
checking for chosen layout... Apache
checking for working mkdir -p... yes
checking for grep that handles long lines and -e... /bin/grep
checking for egrep... /bin/grep -E
checking build system type... x86_64-unknown-linux-gnu
checking host system type... x86_64-unknown-linux-gnu
checking target system type... x86_64-unknown-linux-gnu

Configuring Apache Portable Runtime library ...

checking for APR... no
configure: error: APR not found.  Please read the documentation.

下記のページを参考に apr を入れてコンパイルします。

[参考]
Apache 2.4 で mod_lua を使ってみる

/usr/local/apache242 に入れます。

$ ./configure --prefix=/usr/local/apache242 \
  --with-apr=/usr/local/apr-httpd/ \
  --with-apr-util=/usr/local/apr-util-httpd/
$ make
$ sudo make install

最後に mod_sed のモジュールを有効にします。

$ vi /usr/local/apache242/conf/httpd.conf

コメントを外します。

#LoadModule sed_module modules/mod_sed.so

これでインストールは終了です。

次に実際の動作のための mod_sed の設定をします。 mod_sed は、入力と出力の内容に対して sed コマンドを使うように置換することができます。

入力と出力は使うディレクティブが違うだけなので 簡単に試せる出力で使ってみます。

次のように設定します。 AddOutputFilter で、拡張子 html に対して Sed フィルタを指定しています。

<IfModule sed_module>
    <Directory "/usr/local/apache242/htdocs/sed">
        AddOutputFilter Sed html
        OutputSed "s/monday/MON/g"
        OutputSed "s/sunday/SUN/g"
    </Directory>
</IfModule>

/usr/local/apache242/htdocs/sed にある .html のファイルは "monday","sunday" を出力すると "MON","SUN" に置換されます。

試してみます。次のファイルを用意。

$ cat /usr/local/apache242/htdocs/sed/test.html

<body>
sunday monday tuesday wednesday thursday friday saturday
</body>

アクセスします。

$ wget -q --no-proxy -O - http://localhost/sed/test.html

<body>
SUN MON tuesday wednesday thursday friday saturday
</body>

sunday monday が SUN MON に変わりました。

while ループ内の別プロセス

while が好きなので次のようなループを よく書きます。

ls -1 | while read FILE
do
    echo $FILE
done

これはパイプを使っているので while 以降が別プロセスになってしまいます。 (下の赤文字の部分が別プロセスです)

ls -1 | while read FILE
do
    echo $FILE
done 

なので、 ループ内で変数の値を設定しても ループの外では参照することができません。

例えば次のような場合

AAA=0 
ls -1 | while read FILE
do
    echo $FILE
    AAA=1 
done
echo $AAA 

結果として 0 が出力されます。

node.js で CoffeeScript を試してみる 1

以前「CoffeeScript を試してみる」というネタを書きましたが CoffeeScript は node.js で使うことができるので node.js に入れて試してみます。

まずはグローバルインストール。

$ sudo npm install -g coffee-script

CoffeeScript のソースを書きます。

$ vi test.coffee
alert "hello"

こんな感じ。

CoffeeScript が 全然わからない、って人は 下のサイトが参考になると思います。

[参考]
CoffeeScriptってなんぞ?

コンパイルすると js ファイルができます。

$ coffee -c test.coffee

できた js ファイルを見てみます。

$ cat test.js
(function() {

  alert("hello");

}).call(this);

ちゃんと JavaScript になってました。

PHP5.4 の新機能『ビルトイン Web サーバ』を使ってみる 3

ビルドイン Web サーバには、ファイルを指定して起動すると そのファイルを Web サーバのルータースクリプトとして使うそうです。

ようするに、アクセスに対して常にそのファイルを呼び出してくれるわけです。

例えば、次のように起動します。

$ cd /var/www
$ /usr/local/php540/bin/php -S 0.0.0.0:3000 

この場合、次のファイルがルータスクリプトになります。

/var/www/test.php

ドキュメントルート以外のファイルを指定することもできます。

$ cd /var/www
$ /usr/local/php540/bin/php -S 0.0.0.0:3000 /tmp/test.php

このようにファイルを指定して起動した場合は、 次のように色々なアクセスをしても 常にそのファイルが呼び出されます。

http://127.0.0.1:3000/
http://127.0.0.1:3000/aaa.php
http://127.0.0.1:3000/a/b/c/d/e?a=1

処理を分岐させることもできますが、 そのファイルだけをテストしたいときも アクセスが簡単になるので便利です。

PHP5.4 の新機能『ビルトイン Web サーバ』を使ってみる 2

PHP5.4 の新機能『ビルトイン Web サーバ』の続きです。

ビルトイン Web サーバは、apache が持ってるような SSI などの機能は使えません。 あくまで PHP を試すためのものですね。

今回は $_ENV や $_SERVER の値を見てみます。

まず /var/www をドキュメントルートにして /usr/local/php540/bin/php を起動します。

$ cd /var/www
$ /usr/local/php540/bin/php -S 0.0.0.0:3000

次の URL でアクセスします。

http://127.0.0.1:3000/test.php/a/r/r?a=1

$_ENV は次のようになりました。

Array
(
    [TERM] => xterm
    [SHELL] => /bin/bash
    [XDG_SESSION_COOKIE] => e60d136e5f757051cf175ad04f5ec5ad-1333074947.75417-1176305813
    [SSH_CLIENT] => 192.168.1.123 4454 22
    [SSH_TTY] => /dev/pts/0
    [USER] => odin
    [LS_COLORS] => rs=0:di=01;34:ln=01;36:hl=44;37:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.lzma=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.dz=01;31:*.gz=01;31:*.bz2=01;31:*.bz=01;31:*.tbz2=01;31:*.tz=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.rar=01;31:*.ace=01;31:*.zoo=01;31:*.cpio=01;31:*.7z=01;31:*.rz=01;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.svg=01;35:*.svgz=01;35:*.mng=01;35:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.m2v=01;35:*.mkv=01;35:*.ogm=01;35:*.mp4=01;35:*.m4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.wmv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35:*.flc=01;35:*.avi=01;35:*.fli=01;35:*.flv=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.yuv=01;35:*.axv=01;35:*.anx=01;35:*.ogv=01;35:*.ogx=01;35:*.aac=00;36:*.au=00;36:*.flac=00;36:*.mid=00;36:*.midi=00;36:*.mka=00;36:*.mp3=00;36:*.mpc=00;36:*.ogg=00;36:*.ra=00;36:*.wav=00;36:*.axa=00;36:*.oga=00;36:*.spx=00;36:*.xspf=00;36:
    [MAIL] => /var/mail/odin
    [PATH] => /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games
    [PWD] => /var/www
    [LANG] => en_US.UTF-8
    [SHLVL] => 1
    [HOME] => /home/odin
    [LOGNAME] => odin
    [SSH_CONNECTION] => 192.168.1.123 4454 192.168.1.123 22
    [LESSOPEN] => | /usr/bin/lesspipe %s
    [LESSCLOSE] => /usr/bin/lesspipe %s %s
    [OLDPWD] => /var/www/php
    [_] => /usr/local/php540/bin/php
)

$_SERVER は次のようになりました。

Array
(
    [DOCUMENT_ROOT] => /var/www
    [REMOTE_ADDR] => 192.168.1.123
    [REMOTE_PORT] => 4509
    [SERVER_SOFTWARE] => PHP 5.4.0 Development Server
    [SERVER_PROTOCOL] => HTTP/1.1
    [SERVER_NAME] => 0.0.0.0
    [SERVER_PORT] => 3000
    [REQUEST_URI] => /test.php/a/r/r?a=1
    [REQUEST_METHOD] => GET
    [SCRIPT_NAME] => /test.php
    [SCRIPT_FILENAME] => /var/www/test.php
    [PATH_INFO] => /a/r/r
    [PHP_SELF] => /test.php/a/r/r
    [QUERY_STRING] => a=1
    [HTTP_HOST] => 192.168.1.123:3000
    [HTTP_USER_AGENT] => Mozilla/5.0 (Windows NT 5.1; rv:11.0) Gecko/20100101 Firefox/11.0
    [HTTP_ACCEPT] => text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
    [HTTP_ACCEPT_LANGUAGE] => ja,en-us;q=0.7,en;q=0.3
    [HTTP_ACCEPT_ENCODING] => gzip, deflate
    [HTTP_CONNECTION] => keep-alive
    [HTTP_COOKIE] => XXXXXXXXXXXXXX
    [REQUEST_TIME_FLOAT] => 1333192830.1065
    [REQUEST_TIME] => 1333192830
    [argv] => Array
        (
            [0] => a=1
        )

    [argc] => 1
)

ついでに $_GET 。 これは当然、次のようになりました。

Array
(
    [a] => 1
)

PHP5.4 の新機能『ビルトイン Web サーバ』を使ってみる 1

PHP5.4 には PHP だけで Web サービスを提供できる 『ビルトイン Web サーバ』という新機能があります。

PHP5.4 をインストールしたので さっそく試してみます。

[参考]
PHP: ビルトインウェブサーバー - Manual

ビルトイン Web サーバは、起動したディレクトリが ドキュメントルートになります。 (-t オプションで指定は可能)

PHP のスクリプトを書いて すぐに試したいときは非常に便利です。

とりあえず起動。
PHP5.4.0 は /usr/local/php540 に入れています。

$ cd /var/www
$ /usr/local/php540/bin/php -S 0.0.0.0:3000
PHP 5.4.0 Development Server started at Thu Mar 29 15:04:02 2012
Listening on 0.0.0.0:3000
Document root is /var/www
Press Ctrl-C to quit.
$ netstat -ant
tcp    0  0 0.0.0.0:3000        0.0.0.0:*           LISTEN

"-S" オプションで起動して LISTEN する IP アドレスとポートを指定します。

終了するときは [Ctrl]+[C] を送ります。

http://127.0.0.1:3000/

PHP のスクリプトファイルを指定していない場合(ディレクトリまでの指定の場合) index.php → index.html の順に探して 見つからなければ 404 を返します。

ログは、サーバを起動したコマンドのターミナルに出力されます。

$ /usr/local/php540/bin/php -S 0.0.0.0:3000
PHP 5.4.0 Development Server started at Thu Mar 29 15:04:02 2012
Listening on 0.0.0.0:3000
Document root is /var/www
Press Ctrl-C to quit.
[Thu Mar 29 23:04:04 2012] 192.168.1.100:2669 [200]: /
[Thu Mar 29 23:04:04 2012] 192.168.1.100:2670 [200]: /default.css
[Thu Mar 29 23:04:04 2012] 192.168.1.100:2674 [200]: /logo.gif

ちなみに、このビルトイン Web サーバは、開発用に設計されたもので 実運用に使ってはいけないそうです。

Google サイト内検索

Amazonアソシエイト