レンタルサーバー・自宅サーバー設定・構築のヒント
レンタルサーバー・自宅サーバー設定・構築のヒント - レンタルサーバー・自宅サーバーの設定・構築情報を公開しています。

WordPressだけが php-fpm のログのタイムゾーンがおかしいので対応してみた

2012年11月20日 2015年5月14日
timezone

php-fpm のLogWatchの設定を行ってみる で php-fpmのLogWatchについて解説してみました。
今回は、その記事のおまけ的な内容で、先の記事で書いたように

php 5.3.8 から phpのログ出力時の日時に タイムゾーンが出力されるようになりました。

php 5.3系では、デフォルトのタイムゾーンを設定しないと警告メッセージが出力されるようになったのは、非常に有名な話で いろんな記事で書かれています。

でも、案外、先のログ情報の日時表記にタイムゾーンが出力されるようになったことについての記事は少ないようです。

php.ini および www.conf にちゃんとデフォルトタイムゾーンを‘Asia/Tokyo’と設定しているのに、Wordpresの php エラーのログ情報では、必ず‘UTC’となってしまいます。

php.iniの設定イメージ

...
[Date]
date.timezone = 'Asia/Tokyo'
...

www.confの設定イメージ

...
php_admin_value[date.timezone]= 'Asia/Tokyo'

今回は、この問題に対処してみます。

WordPressだけが php-fpm のログのタイムゾーンがおかしいので対応してみた

一応、そもそもの問題の現象から順を追って対処までを以下に解説してみます。

[現象]

この問題の現象は、以下のphpエラーログの日時+タイムゾーンを見てください。

[19-Nov-2012 01:08:10 UTC] PHP Notice:  Use of undefined constant aaa - assumed 'aaa' in /var/www/html/wordpress/wp-content/plugins/test.php on line 2
[19-Nov-2012 10:10:09 Asia/Tokyo] PHP Notice:  Use of undefined constant aaa - assumed 'aaa' in /var/www/html/example/test.php on line 2

上記は、全く同じエラーが発生するtest.php onを実行した例です。あまり変わらない時間にそれぞれ順番に実行したものです。

上が、Wordpresで実行した例です。
下が、通常のサイトでphpを実行した例です。

2つのログに9時間の差があります。一方がUTCで、他方が9時間差の日本(Tokyo)になっている点が問題です。

[原因]

この問題の原因は、至極簡単でした。Wordpressのインストール先ディレクトリに wp-settings.php というファイル名でWordpressの設定情報が記述されたphpファイルがあります。 その中で、デフォルトタイムゾーンを‘UTC’に設定しているためです。
以下は、その wp-settings.php での‘UTC’設定箇所の抜粋です。

30
31
32
33
34
35
36
37
38
39
// Disable magic quotes at runtime. Magic quotes are added using wpdb later in wp-settings.php.
@ini_set( 'magic_quotes_runtime', 0 );
@ini_set( 'magic_quotes_sybase',  0 );

// Set default timezone in PHP 5.
if ( function_exists( 'date_default_timezone_set' ) )
	date_default_timezone_set( 'UTC' );

// Turn register_globals off.
wp_unregister_GLOBALS();
  • 37行目: ここで無条件にデフォルトタイムゾーンをUTCに設定しているので、 Wordpressで発生したエラーのログ情報は、全てタイムゾーン表記がUTCとなっていたんですね。

[対処]

原因がわかれば対処は簡単です。先の wp-settings.php で、デフォルトタイムゾーンを‘UTC’に設定している箇所を、‘Asia/Tokyo’に変更するだけで良いはずです。
以下は、その wp-settings.php での変更イメージです。

30
31
32
33
34
35
36
37
38
39
// Disable magic quotes at runtime. Magic quotes are added using wpdb later in wp-settings.php.
@ini_set( 'magic_quotes_runtime', 0 );
@ini_set( 'magic_quotes_sybase',  0 );

// Set default timezone in PHP 5.
if ( function_exists( 'date_default_timezone_set' ) )
	date_default_timezone_set( 'Asia/Tokyo' );

// Turn register_globals off.
wp_unregister_GLOBALS();
  • 37行目: 先の ‘UTC’‘Asia/Tokyo’に変更しただけです。

ただ、この対処では、Wordpressの更新時に、毎回、編集する必要があります。 Wordpressの更新時に、対処を忘れることもありますから、できれば、それは避けたいですね。

そういう場合は、テーマのfunctions.php の先頭に以下のように記述すると良いでしょう。

<?php
date_default_timezone_set( 'Asia/Tokyo' );
...

ちょっと、仰々しい記事になっちゃいましたね。大した内容も無いのに・・・。

一応、ちゃんと問題と原因を明確にしておくと、あとで何でこんな対処が必要だったかなぁ・・・なんてならなくなりますからね、備忘録です、備忘録。

それはそうとして、
あまりにも単純だったので、これって‘Asia/Tokyo’へ変更してしまうと何か問題があるのかも?と思わなくもないですが、 おそらくは、サーバーのphp環境に依存するので、デフォルトUTCになっているのでしょうね、たぶん。

ひょっとすると、プラグインのいくつかは、この時間制御に関してうまく対応できていないかもしれません。
個人的に色々と試してみましたが、問題はありませんでした。 インストールしているプラグインに時間関連が少なかったので、そうだったのかもしれません・・・、しっかり確認しましょうね。
ご利用のブラウザは、広告ブロック(AdBlockなど) が適用となっていませんか?
このサイトでは、コンテンツの一部が非表示、あるいは、コメント、お問い合わせの投稿ができない検索ができないことがあります。


関連記事 :

mysqlのレプリケーションを使う(4) Wordpressでレプリケーションを使う

以前に mysqlのレプリケーションを使う mysqlのレプリケーションを使う(2) バイナリログを削除する mysqlのレ ...

php および APC の設定を行う

前回までの あえてphp5.2系をインストールする(CentOS 5,CentOS 6,Scientific Linux 6) ...

php-fpm のLogWatchの設定を行ってみる

LogWatchを使ってみる ( nginxの設定例 ) でLogWatchのインストールとnginxのLogWatchの設定を行ってみました。 ...

ConoHa の API を使ってみる、ついでに、ISOイメージを使って Ubuntu Server 14.04 をインストールしてみる。

評価の高い 新 ConoHa VPS と さくらのVPS の特徴とUnixBenchを含めたパフォーマンスを比較してみました。 で Cono ...

FreeBSDでphpをインストール

さて、今回は、phpのインストール手順です。 これができれば、mysqlもインストールできていますから、スクリプトからデータベースを操作できる ...



コメントを投稿 :

お名前 *

メールアドレス *
( メールアドレスが公開されることはありません。)

サイトアドレス

コメント *

* 印の項目は、入力が必要な項目です。




最近投稿の記事

[ 画像提供元 : Amazon ] 先日、1TBのディスクの入れ替え時にバックアップをとろうとディスクコピーを行いました。 その際 ...

Windows で Linux ファイルシステム Ext4 のディスクをマウントするには? Ext3Fsd が、おそらく、最も簡単なツール ...

今回は、Windows で Compass を使ってみました。 Compass とは、 Sass(サス、Syntactica ...

今回は、Anti Adblock を使ってみました。 Anti Adblock とは、 そもそも Adblock という ウェブ ...

デスクトップ環境でない サーバーで、Webページのキャプチャー画像をコマンドで撮る には、wkhtmltoimage, CutyCapt ...


さくらのVPS 全プラン リニューアルです。(石狩(北海道)も選択可)


root権限ありで ¥685 / 月 ~ と非常にリーズナブルな CPU 1(core)の 512 プランから、 最高 CPU 10(core), メモリ 32(GB), SSD容量 800(GB) までとプランが充実。
ディスクは、SSDとHDDの選択が可能になった他、データセンターは人気の東京、石狩(北海道)となりました。

また、どのプランでも好きなOSが選べます
( CentOS, Fedora, Scientific Linux, FreeBSD, Ubutu, Debian )

管理人もおすすめのVPSです。
試用期間がありますから、一度、お試しを!!

詳しくは、http://vps.sakura.ad.jp/さくらのVPSのサイトへ へどうぞ!!

カテゴリ


Serverman@VPS 完全1ヶ月無料 キャンペーン実施中です。


Serverman@VPS 完全1ヶ月無料 キャンペーン実施中です。
最近、スワップにも対応した Serverman@VPS は、かなりリーズナブルかもです。

  • メモリ1GB~2GBのEntryプラン :月額:490円
  • メモリ2MB~4GBのStandardプラン :月額:980円
  • メモリ4GB~8GBのProプラン :月額:1,980円

新規申し込みで1ヶ月間完全無料となるキャンペーンを実施中です。
Serverman@VPSの特徴は、安さとIPv6対応です。また、初期設定費0円もポイントです。

IPv6でちょっと遊んでみたい方には、おすすめかもしれませんね。最低利用期間もありませんから、気に入らないときは即解約もできます。

Serverman@VPSの詳細については、 http://dream.jp/vps/ Serverman@VPSのサイトへへどうぞ。



KVM採用 ConoHa VPSは、時間単位で借りれる便利なVPSです。


ConoHa VPS は、初期設定費0円最低利用期間無し時間単位で清算可能、 さらに、Web APIを使って自動化を図ることもできる便利なVPSです。

海外サーバー設置も可能で、ローカル接続にも対応と、かなり、機能豊富なサーバーです。

新規ユーザ登録で、クーポンもらえますから、まずは、お試しですね。

ConoHa VPSの詳細については、
http://www.conoha.jp/ へどうぞ。

KVM採用 お名前.com VPS(KVM) 2G プラン 初期設定費無料 キャンペーン 実施です。


メモリ2GBプラン CPU:3core、Disk:200GB
月額:1,153円から (初期設定:1,680円0円)

さくらのVPSがリニューアルされてもなんのその。
1GBメモリ / 2Core を ¥834 – の格安価格で提供中です!
間違いなくスペックからすると割安感ありです。
年間割引時の途中解約で返金がないのは、 ちょっと残念ですが、それでもこの割安感は魅力です。

まずは、お試しですね。

お名前.com VPS(KVM)の詳細については、
http://www.onamae-server.com/vps/ へどうぞ。(お試し期間が15日あります。)



  • ソーシャルブックマーク

  • はてなブックマークへ追加するはてな登録数
ページトップへ
Time : 0.2220 [s]