ホームページ >バックエンド開発 >PHPチュートリアル >click.simba.taobao.com PHP CLI を介したシンプルなリアルタイムデータベース監視とスケジューリング

click.simba.taobao.com PHP CLI を介したシンプルなリアルタイムデータベース監視とスケジューリング

WBOY
WBOYオリジナル
2016-07-29 08:40:212583ブラウズ

実装する機能: userテーブルを監視し、新規レコードが追加された場合はuser2テーブルに追加します。 (実際のアプリケーションは、データの関連処理など、より詳細なものになります)
以下は PHP コード (dbtest.php) です

コードをコピーします コードは次のとおりです:


!#/usr/local/php/ bin/php
mysql_connect('localhost', 'username', 'password');
mysql_select_db("test");
echo 'PID: '.posix_getpid( ).' '; //現在のプロセス PID (Linux の場合)
$old_id = 0;
{
$sql = "SELECT `id` FROM `user` ORDER BY `id` DESC LIMIT 1";
$result = mysql_query($sql);
$item = mysql_fetch_assoc($result);
$values_arr = array(); $ i>$old_id && $old_id!= 0; $i--)
{
$sql = "SELECT `name`,`age` FROM `user` WHERE `id`='{$i}' LIMIT 1";
$result = mysql_query($sql) ;
$item = mysql_fetch_assoc($result);
$age = $item['age']; "('{$name}', '{$age}')";
}
if (!emptyempty($values_arr))
{
$values_str = implode(',', $values_arr); "INSERT INTO `user2`(`name `, `age`) VALUES {$values_str}"; // 3 秒後に次のループに入る
}


ビジネス プロセスについては多くを語る必要はありませんが、注意が必要な点がいくつかあります:
最初の行は追加する必要があるコマンド パスです。 PHP CLI モードでは while(1) と sleep(3) があり、残りはすべて通常の PHP コードの記述方法です。
シェル コマンド php dbtest.php を使用して実行してください。通常の状況では、CPU 使用率は 0%、メモリは 1% です。
実際のアプリケーションでは、バックグラウンドで実行できます:
php dbtest.php &
bg 1
追記: & コマンドは多くの場所で不明瞭であったり、間違っていたりします。実際にプログラムを実行せずに、プログラムをバックグラウンドに置くだけです。
ところで、Linuxのフロントエンドとバックエンドの動作に関連するコマンドをまとめて復習してください

コマンド フロントエンドとバックエンドのステータスの使用法


&
バックグラウンド一時停止 コマンドの後に追加します

bg バックグラウンド実行の後にジョブ番号を付けます

fgフロントデスク実行に続いてジョブ番号

Ctrl + Z バックステージ一時停止 (キーの組み合わせ)

jobs (すべてのジョブ番号を表示) コマンド 上記では、PHP CLI を使用した click.simba.taabao.com の簡単なリアルタイム データベースの監視とスケジューリングを紹介します。これには、click.simba.taabao.com の内容も含まれており、PHP チュートリアルに興味のある友人に役立つことを願っています。 。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。