1<?php
2/**
3 * @package Include/help/ja
4 */
5?>
6<h1>日時データソース</h1>
7
8<p>
9日時データソースに、システムの日時データかデータベースに記録されているデータかどちらをを利用するかを定義します。<br /><br />
10</p>
11<p>
12これは、データベースがウェブサーバや Pandora FMS サーバと異なるサーバで動作している場合で、時刻にずれが生じている場合に便利です。
13すべての Pandora サーバと MySQL サーバの時刻は NTP により同期すべきですが、この設定を利用することにより、必ずしもそうする必要がなくなります。
14</p>
15<p>
16注: データベースではクエリがキャッシュされますが、内部関数が呼ばれるかどうかに関わらずその時点のシステムタイムが返されますので、日時データは若干異なる場合があります。
17</p>
18<p>
19以下の例は、現在の日時を異なるデータソースから表示しています。
20<script type="text/javascript">
21var date = new Date; // Generic JS date object
22var unixtime_ms = date.getTime(); // Returns milliseconds since the epoch
23var unixtime = parseInt(unixtime_ms / 1000);
24</script>
25</p>
26<p>
27<?php
28$option = array ("prominent" => "timestamp");
29?>
30<b>現在のシステムの時刻:</b> <?php ui_print_timestamp (time (), false, $option); ?>
31<br />
32<b>現在のデータベースの時刻:</b>
33<?php
34global $config;
35
36switch ($config["dbtype"]) {
37	case "mysql":
38		$timestamp = db_process_sql("SELECT UNIX_TIMESTAMP();");
39		$timestamp = $timestamp[0]['UNIX_TIMESTAMP()'];
40		break;
41	case "postgresql":
42		$timestamp = db_get_value_sql("SELECT ceil(date_part('epoch', CURRENT_TIMESTAMP));");
43		break;
44	case "oracle":
45		$timestamp = db_process_sql("SELECT ceil((sysdate - to_date('19700101000000','YYYYMMDDHH24MISS')) * (86400)) as dt FROM dual");
46		$timestamp = $timestamp[0]['dt'];
47		break;
48}
49ui_print_timestamp ($timestamp, false, $option);
50?>
51<br />
52<b>あなたのブラウザの時刻:</b> <script type="text/javascript">document.write (date);</script>
53</p>
54