PHP スクリプトがハングアップしないようにするため、シェル スクリプトはデーモンの例として共有されます_PHP チュートリアル
数日前にデータリストの実行を開始しました。リストにはユーザー名、携帯電話番号の有無、メールアドレスの有無が必要ですが、ユーザーリストは 2,000 万人もいます。また、ユーザーが携帯電話番号を持っているかどうか、メールボックスがあるかどうかも、外部に公開された安全なインターフェイスを通じてユーザーが 1 つずつ要求する必要があり、その戻り値を分析することで知ることができます。
以下は私の解決策です:
1. 2000w リストを一時データテーブルに保存します
2. PHP プログラムを使用してテーブルから毎回 500 ユーザーを取得し、検出後に SQL 更新元レコードを生成します
3 . PHP プログラムが突然切断されるのを防ぐために、PHP がハングした場合はシェル スクリプトを使用して再起動します。これは、モバイル間の検出インターフェイスをデーモンとして使用するためです。電話とメールボックスが遅く、100万〜2,000万人のユーザーを2日間でテストしました。
計画の詳細:
1. ユーザーリストテーブル users を一時的に保存します。テーブル構造は次のとおりです:
`account` varchar(50 ) COMMENT 'username',
`has_phone` tinyint(3) unsigned NOT NULL デフォルト '0' COMMENT '携帯電話番号をお持ちですか',
`has_email` tinyint( 3) unsigned NOT NULL デフォルト '0' COMMENT 'メールアドレスをお持ちですか? ',
`flag` tinyint(3) unsigned NOT NULL デフォルト '0' COMMENT 'flag',
PRIMARY KEY (`account`),
KEY `flag` (`flag`)
) ENGINE=InnoDB DEFAULT CHARSET= utf8 COMMENT='list table';
以下はテーブル データの一部です:
9873aaa,0,0,0adddwwwd876222,0,0,0
testalexlee,0,0,0
codejia.net,0,0,0
haohdouywaa21,0 ,0, 0
2. PHP スクリプト check_users.php
ユーザー リストをテーブルにインポートした後、簡単な PHP スクリプトを作成します。アイデアは次のとおりです。各ループはテーブルから flag=0 の 500 人のユーザーを取得します。インターフェイスは、ユーザーが携帯電話番号と電子メール アドレスを持っているかどうかを判断し、SQL を生成して SQLS 配列に保存します。500 人のユーザーがすべて検出された後、SQLS 配列をループして、その 500 個のリストを更新します。テーブルを参照し、フラグ flag を 1 に設定します。 は、検出が完了したため、次回取得されないことを意味します。 PHP スクリプト コードは長いため、ここに簡単なコードの説明を示します:
private $data; sqls;
private $nums; // ユーザーが 500 人いるかどうかを確認します
private $total_nums; // 現在検出されているユーザーの数
// 毎回 500 人のユーザーを取得します
関数 getUsers(){... }
これらの 500 人のユーザーと SQL を生成します
プライベート関数 checkUserInfo(){...}
//これらの 500 人のユーザーを更新します
プライベート関数 updateUserInfo(){...} //
パブリック関数 run() を実行します{ $ FLAG = TRUE;
While ($ FLAG) {
IF ($ this- & gt; nums! = 500) {$ flag = false;}
($ This- &nums == 10000) {
EXIT (
EXIT) ( 0); //10,000 ユーザーを実行した後に終了し、デーモン プロセスを開始します
updateUserInfo(); // 1 秒間休憩します。ユーザー検出インターフェースを保護するために 500 人のユーザーを実行しています
}
}
}
$user = 新しいユーザー();
$user->run();
上記は PHP スクリプトの簡潔なバージョンです。おそらく、最初のバージョンには $total_nums 変数がなかったことがわかりました。後で確認すると、データベースへの接続が確立されておらず、スクリプトがハングし続けているためです。この変数を追加してもこの問題は解決できませんが、毎回 10,000 ユーザーを実行すると、PHP スクリプトは終了し、次のシェル スクリプトによって再起動されます。
3. デーモンとしてのシェルスクリプト
このシェルスクリプトを crontab に追加し、1 分ごとに実行します。このシェルスクリプトは、check_users.php のプロセス ID が存在するかどうかを検出します。 PHP スクリプトがまだ実行中であり、シェル スクリプトが存在しない場合は、PHP スクリプトが exit(0) を終了し、10,000 人のユーザーが終了したことを意味し、シェル スクリプトがスクリプトを開始します。そして、次の 1,000 ユーザー リストの検出に入ります。
上で述べたように、接続時に PHP スクリプトがデータベースに接続できない場合、PHP は常にそこにボールを保持し、終了できません。シェルスクリプトに時間検出を追加しました。PHP スクリプトのプロセスが存在する場合、それが予想した時間を超えた場合は、PHP スクリプトを強制終了して再起動します。
で始まるデータの場合、結果は次のようになります:
testalexlee,1,0,1
codejia.net,0,0,1
haohdouywaa21,1,1,1
9873aaa,0,1,1
adddwwwd876222,1,0 ,1
最後に: 上記のユーザーリストのデータは単なる例です。2,000 万のデータでは、検出インターフェースが比較的遅いため、時間がかかると予想されます。リクエストを受信した後にテーブルに接続します。テーブルを検索して戻ります。実際、最良の方法は、インターフェイスによって要求されたテーブルからリストを直接取得し、シェル コマンドを使用してそれを処理することで、結果がすぐに得られます。ただし、これは会社の場合であり、一部の場合はそうではありません。開けてください~~~

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

CakePHP はオープンソースの MVC フレームワークです。これにより、アプリケーションの開発、展開、保守がはるかに簡単になります。 CakePHP には、最も一般的なタスクの過負荷を軽減するためのライブラリが多数あります。

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます
