Linux の環境変数には、システム レベルとユーザー レベルが含まれます。システム レベルの環境変数は、システムにログインするすべてのユーザーが読み取る必要があるシステム変数ですが、ユーザー レベルの環境変数は、システム レベルの環境変数です。ユーザーはシステムを使用します。したがって、次の記事では、Linux の環境変数設定に関する関連情報を主に紹介します。必要な方は参考にしてください。
はじめに
私たちが普段 Linux を使用するとき、いくつかの環境変数を設定する必要があることがよくありますが、このとき、通常はネットで検索するだけで、誰かがその経験を紹介します。しかし、問題は、設定が /etc/profile にあるという人もいれば、/etc/environment に設定されているという人も、~/.bash_profile に設定されているという人も、~ に設定されているという人もいます。 /.bashrc で構成されているという人もいますが、~/.bash_login で構成されているという人もいます。また、~/.profile で構成されているという人もいます。 。 。これは実に公平かつ合理的です。 。 。そこで問題は、Linux が設定ファイルをどのように読み取るのか、そしてその根拠は何なのかということです。以下の記事で詳しく紹介していますので、見ていきましょう。
Documentation
私は、出典を言わずに結論だけを言うという、「なぜ信じなければならないのか」という印象を与える行為がいつも大嫌いです。そして実際、ソースのない何気ない議論から導き出される結論は、基本的に他人の発言に基づいています。実際、他の人に質問するのではなく、ドキュメントに質問してください。 しばらく検索したところ、環境変数の設定に関する関連ドキュメントが実際には bash コマンドの man ドキュメントにあることがわかりました。結局のところ、これは私たちがよく使用するシェルです。
$man bash で、次のテキストを見つけました:
INVOCATION A login shell is one whose first character of argument zero is a -, or one started with the --login option. An interactive shell is one started without non-option arguments and without the -c option whose standard input and error are both connected to terminals (as determined by isatty(3)), or one started with the -i option. PS1 is set and $- includes i if bash is interactive, allowing a shell script or a startup file to test this state. The following paragraphs describe how bash executes its startup files. If any of the files exist but cannot be read, bash reports an error. Tildes are expanded in filenames as described below under Tilde Expan‐ sion in the EXPANSION section. When bash is invoked as an interactive login shell, or as a non-inter‐ active shell with the --login option, it first reads and executes com‐ mands from the file /etc/profile, if that file exists. After reading that file, it looks for ~/.bash_profile, ~/.bash_login, and ~/.profile, in that order, and reads and executes commands from the first one that exists and is readable. The --noprofile option may be used when the shell is started to inhibit this behavior. When a login shell exits, bash reads and executes commands from the file ~/.bash_logout, if it exists. When an interactive shell that is not a login shell is started, bash reads and executes commands from /etc/bash.bashrc and ~/.bashrc, if these files exist. This may be inhibited by using the --norc option. The --rcfile file option will force bash to read and execute commands from file instead of /etc/bash.bashrc and ~/.bashrc. When bash is started non-interactively, to run a shell script, for example, it looks for the variable BASH_ENV in the environment, expands its value if it appears there, and uses the expanded value as the name of a file to read and execute. Bash behaves as if the following com‐ mand were executed: if [ -n "$BASH_ENV" ]; then . "$BASH_ENV"; fi but the value of the PATH variable is not used to search for the file‐ name.
このテキストを通じて、いわゆる環境変数設定ファイルは、シェルのログイン時に自動的にロードされるファイルであることがわかりました。ただし、彼が定義したログインは、
ログイン シェル ログインの 2 つのタイプに分類されます。
対話型シェルログイン。
ログインシェルログイン
いわゆるログインシェルログインは、実際にはパスワードの入力を必要とするログインを指します。具体的には、起動、ssh ログイン、bash --login と入力して「パスワードを入力してログインするふり」をすることが含まれます。 このログイン方法では、システムは最初に /etc/profile ファイルを読み取り、次に 3 つのファイル ~/.bash_profile、~/.bash_login、および ~/.profile を順番に検索し、最初のファイルのみを実行します。そのうちの 1 つが存在します。 特に、最後の 3 つのファイル間の「論理 OR」関係に注意する必要があります。多くの場合、~/.profile ファイルが変更されていることがわかりますが、再度ログインしても設定が有効にならないのはなぜですか?これは、最初の 2 つのファイルのうち 1 つがシステムに存在し、残りのファイルが読み取られない可能性があるためです。
以下の 3 つの図は、この問題を非常によく示しています:
対話型シェル ログイン
いわゆる対話型シェル ログインは、実際にはログイン シェル ログインに関連しています。の条件。通常、ログイン後に右クリックしてターミナルを開くか、CTRL+ALT+T を押してターミナルを開きます (対話型シェル ログイン)。 このログイン方法では、システムは /etc/bash.bashrc と ~/.bashrc を順番に読み込んで実行します。 通常の状況では、一部の定数と一部のエイリアスは、デフォルトで ~/.bashrc ファイルに記録されます。特に $PS1 変数は、bash プロンプトの形式、スタイル、色を決定します。
注:
これら 2 つのログイン方法は異なる設定ファイルを読み取り、相互に重複がないことに注意してください。したがって、環境変数を設定する必要がある場合は、独自の環境変数に従って設定する必要があります。ログイン メソッドは、必要な変数を別のファイルに設定します。 たとえば、次のような古典的な質問です。
典型的な問題
異常な環境設定ファイルの設定の例としては、SSH を使用してサーバーにログインすると、次のようなプロンプトが表示されることが挙げられます:
bash-4.3$
はい、3 番目と同じです。上の画像 画像の bash と同様に、プロンプトは非常に奇妙で、ls を入力したときにファイルとフォルダーの色の区別がありません。 この問題は明らかに、$PS1 環境変数が設定されていないためにデフォルト値が使用されていることが原因ですが、.bashrc ファイルをチェックすると、$PS1 変数が定義されていることがわかります。 , しかし、sshはログインシェルに属しているため、ログイン時に読み込む設定ファイルは/etc/profileなどのファイルであり、.bashrcは読み込まれません。 この問題の原因は通常、/etc/profile 内のデフォルト設定ファイルを誤って削除したことであるため、解決策も非常に簡単です。 。 。 .bashrc 内のいくつかのファイルを /etc/profile にコピーするだけです。
この質問が私たちに与える啓発は、サーバーの変数を構成するときは、/etc/profile または ~/.bash_profile で構成するようにしてください。ssh を使用してサーバーにログインする場合、.bashrc ファイルは基本的に使用されないためです。自分のコンピュータの環境変数を構成するときは、.bashrc で環境変数を構成するようにしてください。そうすれば、ターミナルを開いている限りこのファイルが読み取られるため、ログアウトせずに構成を適用できます (/etc/ はログアウトして再度ログインしたプロファイルに適用されます)。
概要
以上がLinux で環境変数を構成する手順を共有する (写真)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Linux操作をマスターする理由は、幅広いアプリケーションシナリオと強力な機能です。 1)Linuxは、開発者、システム管理者、テクノロジー愛好家に適しており、サーバー管理、組み込みシステム、コンテナ化テクノロジーで使用されています。 2)Linuxの学習は、ファイルシステム構造、シェルの使用、ユーザー許可管理、プロセス管理から始めることができます。 3)Linuxコマンドラインは、LS、MKDIR、CDなどのシェルを介してコマンドを実行し、リダイレクトおよびパイプライン操作をサポートするコアツールです。 4)高度な使用法には、バックアップスクリプトなどの自動化されたスクリプトの書き込み、TARコマンド、条件付き判断が含まれます。 5)一般的なエラーには、エコー、セットX、$?を介してデバッグできます。 6)パフォーマンス最適化の提案

Linuxシステムの5つの柱は次のとおりです。1。Kernel、2。SystemLibrary、3。Shell、4。FileSystem、5。SystemTools。カーネルはハードウェアリソースを管理し、基本的なサービスを提供します。システムライブラリは、アプリケーション用の事前コンパイルされた機能を提供します。シェルは、ユーザーがシステムと対話するインターフェイスです。ファイルシステムはデータを整理して保存します。また、システムツールはシステム管理とメンテナンスに使用されます。

Linux Systemsでは、起動時に特定のキーを押すか、「sudosystemctlrescue」などのコマンドを使用することにより、メンテナンスモードを入力できます。メンテナンスモードを使用すると、管理者は、ファイルシステムの修復、パスワードのリセット、セキュリティの脆弱性など、干渉なしにシステムメンテナンスとトラブルシューティングを実行できます。

Linuxの初心者は、ファイル管理、ユーザー管理、ネットワーク構成などの基本操作をマスターする必要があります。 1)文件管理:使用mkdir、タッチ、ls rm 3)ネットワーク構成:ifconfig、echo、およびufwコマンドを使用します。これらの操作はLinuxシステム管理の基礎であり、それらをマスターすることでシステムを効果的に管理できます。

この記事では、LinuxのSudo特権を管理する方法について説明します。重要な焦点は、 /etc /sudoersの安全性とアクセスを制限することです。

この記事では、Google Authenticatorを使用してLinux上のSSH用の2要素認証(2FA)のセットアップ、インストール、構成、およびトラブルシューティング手順の詳細に関するガイドを提供します。 Enhanced Secなど、2FAのセキュリティ利益を強調しています

この記事では、Linuxシステムのパフォーマンスを監視するためにTop、HTOP、およびVMSTATを使用して、効果的なシステム管理のための独自の機能とカスタマイズオプションを詳述することについて説明します。

記事では、APT、Yum、およびDNFを使用してLinuxでソフトウェアパッケージの管理を行い、インストール、更新、および削除をカバーしています。さまざまな分布に対する機能と適合性を比較します。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

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