いつも Apache のログは logrotate でローテーションさせてるんですが PostgreSQL のように単体?でできないかなと思っていたら ちゃんとそういうコマンドがあるようです。
さっそく設定してみます。 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.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 が好きなので次のようなループを よく書きます。
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 が出力されます。
以前「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 になってました。
ビルドイン 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 サーバ』の続きです。
ビルトイン 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 には 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 サーバは、開発用に設計されたもので 実運用に使ってはいけないそうです。