検索
ホームページ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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。