検索
ホームページphp教程php手册PHP CLI を介したシンプルなリアルタイムデータベースの監視とスケジューリング

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

Jun 13, 2016 pm 12:22 PM
cliphpuser関数増加リアルタイム成し遂げるデータベースモニター単純表面欲しいスケジュール設定合格

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

以下は PHP コード (dbtest.php) です。

コピーcode コードは次のとおりです:


!#/usr/local/php/bin/php
mysql_connect('localhost', 'username', 'password') ;
mysql_select_db("test");
echo 'PID: '.posix_getpid().' //現在のプロセス PID (Linux の場合)
$old_id = 0;
while (1 )
{
$sql = "SELECT `id` FROM `user` ORDER BY `id` DESC LIMIT 1";
$item = mysql_fetch_assoc( $result);
$new_id = $item['id'];
$values_arr = array();
for ($i=$new_id; $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);
$name = $item['name'];
$age = $item['年齢'];
$ value_arr[] = "('{$name}', '{$age}')"
}
if (!emptyempty($values_arr))
{
$values_str = implode( ',', $values_arr);
$sql = "`user2`(`name`, `age`) VALUES {$values_str}";
}
$old_id = max($old_id, $new_id);
sleep(3); // 3 秒後に次のサイクルに入る
}


ビジネス プロセスについては何も言う必要はありませんが、注意すべき点がいくつかあります:

最初の行は PHP CLI モードで追加する必要があるコマンド パスであり、while(1) があります。とsleep(3)、その他は通常のPHPコードの記述方法です。
シェル コマンド php dbtest.php を通じて実行できます。通常の状況では、CPU 使用率は 0%、メモリは 1% でした。
実際のアプリケーションでは、バックグラウンドで実行できます:
php dbtest.php &
bg 1
追記: & コマンドは多くの場所で不明瞭であったり、間違っていたりします。実際にプログラムを実行せずに、プログラムをバックグラウンドに置くだけです。
ところで、Linux のフロントエンドとバックエンドの実行に関連するコマンドをまとめて確認してみましょう


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

&

コマンド

の後にバックグラウンド一時停止が追加されます バックグラウンド実行の後にジョブ番号が続く

fg フロントデスクの実行に続いてジョブ番号が続きます

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

jobs (すべてのジョブ番号を表示) コマンド

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール