Linux のバックグラウンド操作の神秘的な世界を探索する
Linux オペレーティング システムの神秘的な世界、つまりバックグラウンド実行を探索してみましょう。日常的な使用では、現在の作業に影響を与えずにタスクをバックグラウンドでサイレントに実行させるために、バックグラウンド実行を使用する必要があることがよくあります。では、Linux でバックグラウンド操作を実装するにはどうすればよいでしょうか?
######考える######まず第一に、質問を検討する必要があります。なぜ端末を直接閉じるとバックグラウンド プログラムが終了するのでしょうか? それは、端末を直接閉じると、端末が SIGHUP シグナルを開始したバックグラウンド タスクに送信するためです。現在の環境が不安定になり、実行中のプログラムがハングアップする場合は、SIGHUP を無視してください。
nohup最も一般的に使用されるコマンドは [nohup] です。名前から、実行中のコマンドを一時停止しても、ターミナルを閉じても、アカウントからログアウトしても、プロセスは実行を継続することがわかります。 [&]記号と一緒に使用されます。 使用法: nohup コマンド [ Arg … ] [ & ]
rree上記からわかるように、実行している test.sh の親プロセスは [PID 1] となり、Linux のメインプロセスに引き継がれます。
setsid
nohup は SIGHUP シグナルを無視することを意味します。他にアイデアはありますか? setip コマンドは、セッションを再度開き、親プロセス グループの ID を継承し、親プロセスの制御をエスケープできます。下の図からわかるように、test.sh スクリプトの親プロセスはすでに init 1 になっています。この時点では、ターミナルを閉じるか終了するかに関係なく、バックグラウンド プログラムとは何の関係もありません。
リーリー setsid と nohup のもう 1 つの違いは、& 背景記号を使用する必要がないことです。######出口######
exit コマンドを使用してターミナルを終了しても、プログラムは引き続き実行されます。これはなぜですか?
これは、exit コマンドを使用して端末を終了するときに、端末が属するタスクに SIGHUP シグナルが送信されないためです。これは huponexit 構成項目によって制御されます。デフォルトはオフです。shopt を使用できます。それを表示するコマンド。
rree huponexit をオンに設定し、exit コマンドを再度使用して終了すると、対応するタスクもそれに応じて終了します。 リーリー ######トラップ######
トラップ コマンドは Linux の組み込みコマンドです。指定されたシグナルを受信したときに実行されるアクションと、その後に処理されるシグナルの名前が続きます。一般的なシグナルは次のとおりです:
スクリプトがバックグラウンドに移行し、ターミナルが終了してプログラムを閉じたくない場合は、スクリプトにトラップ コマンドを追加して、SIGHUP シグナルを無視する (プロセスをハングする) ことができます。
リーリー
rree
この例からわかるように、テスト スクリプトの親プロセスはスクリーン ターミナル プロセスであり、スクリーン ターミナルの親プロセスである PID1 もバックグラウンド プロセスの実行を完了しています。つまり、バックグラウンドでの実行は、Linux では非常に一般的で実用的なテクニックです。サーバー側でバックグラウンド サービスを実行する場合でも、パーソナル コンピューターで長時間実行されるタスクを完了する場合でも、バックグラウンド操作は効率を向上させ、日常業務を容易にするのに役立ちます。
以上がLinux のバックグラウンド操作の神秘的な世界を探索するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホット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)

ホットトピック









ルートとしてMySQLにログインできない主な理由は、許可の問題、構成ファイルエラー、一貫性のないパスワード、ソケットファイルの問題、またはファイアウォール傍受です。解決策には、構成ファイルのBind-Addressパラメーターが正しく構成されているかどうかを確認します。ルートユーザー許可が変更されているか削除されてリセットされているかを確認します。ケースや特殊文字を含むパスワードが正確であることを確認します。ソケットファイルの許可設定とパスを確認します。ファイアウォールがMySQLサーバーへの接続をブロックすることを確認します。

c言語条件付きコンパイルは、コンパイル時間条件に基づいてコードブロックを選択的にコンパイルするメカニズムです。導入方法には、#IFおよび#ELSEディレクティブを使用して、条件に基づいてコードブロックを選択します。一般的に使用される条件付き式には、STDC、_WIN32、Linuxが含まれます。実用的なケース:オペレーティングシステムに従って異なるメッセージを印刷します。システムの数字数に応じて異なるデータ型を使用します。コンパイラに応じて、異なるヘッダーファイルがサポートされています。条件付きコンパイルにより、コードの移植性と柔軟性が向上し、コンパイラ、オペレーティングシステム、CPUアーキテクチャの変更に適応できます。

1.0.1序文このプロジェクト(コードとコメントを含む)は、私の独学の錆の間に記録されました。不正確または不明確な声明があるかもしれませんが、謝罪してください。あなたがそれから利益を得るなら、それはさらに良いです。 1.0.2なぜRustrustは信頼性が高く効率的ですか? Rustは、CとCを同様のパフォーマンスであり、セキュリティが高くなり、CやCのようなエラーを確認するために頻繁な再コンパイルを必要としません。主な利点には、メモリセキュリティ(nullポインターの防止、ぶら下がりポインター、およびデータ競合の防止)が含まれます。スレッドセーフ(実行前にマルチスレッドコードが安全であることを確認してください)。未定義の動作を避けてください(例:境界のない配列、未知の変数、または解放されたメモリへのアクセス)。 Rustは、ジェネリックなどの最新の言語機能を提供します

Linuxの5つの基本コンポーネントは次のとおりです。1。カーネル、ハードウェアリソースの管理。 2。機能とサービスを提供するシステムライブラリ。 3.シェル、ユーザーがシステムと対話するインターフェイス。 4.ファイルシステム、データの保存と整理。 5。アプリケーション、システムリソースを使用して機能を実装します。

MySQLの起動が失敗する理由はたくさんあり、エラーログをチェックすることで診断できます。一般的な原因には、ポートの競合(ポート占有率をチェックして構成の変更)、許可の問題(ユーザー許可を実行するサービスを確認)、構成ファイルエラー(パラメーター設定のチェック)、データディレクトリの破損(テーブルスペースの復元)、INNODBテーブルスペースの問題(IBDATA1ファイルのチェック)、プラグインロード障害(エラーログのチェック)が含まれます。問題を解決するときは、エラーログに基づいてそれらを分析し、問題の根本原因を見つけ、問題を防ぐために定期的にデータをバックアップする習慣を開発する必要があります。

MySQLのインストールエラーのソリューションは次のとおりです。1。システム環境を慎重に確認して、MySQL依存関係ライブラリの要件が満たされていることを確認します。異なるオペレーティングシステムとバージョンの要件は異なります。 2.エラーメッセージを慎重に読み取り、依存関係のインストールやSUDOコマンドの使用など、プロンプト(ライブラリファイルの欠落やアクセス許可など)に従って対応する測定値を取得します。 3.必要に応じて、ソースコードをインストールし、コンパイルログを慎重に確認してみてください。これには、一定量のLinuxの知識と経験が必要です。最終的に問題を解決する鍵は、システム環境とエラー情報を慎重に確認し、公式の文書を参照することです。

MySQLはAndroidで直接実行できませんが、次の方法を使用して間接的に実装できます。Androidシステムに構築されたLightWeight Database SQLiteを使用して、別のサーバーを必要とせず、モバイルデバイスアプリケーションに非常に適したリソース使用量が少ない。 MySQLサーバーにリモートで接続し、データの読み取りと書き込みのためにネットワークを介してリモートサーバー上のMySQLデータベースに接続しますが、強力なネットワーク依存関係、セキュリティの問題、サーバーコストなどの短所があります。

MySQLのインストール障害の主な理由は次のとおりです。1。許可の問題、管理者として実行するか、SUDOコマンドを使用する必要があります。 2。依存関係が欠落しており、関連する開発パッケージをインストールする必要があります。 3.ポート競合では、ポート3306を占めるプログラムを閉じるか、構成ファイルを変更する必要があります。 4.インストールパッケージが破損しているため、整合性をダウンロードして検証する必要があります。 5.環境変数は誤って構成されており、環境変数はオペレーティングシステムに従って正しく構成する必要があります。これらの問題を解決し、各ステップを慎重に確認して、MySQLを正常にインストールします。
