CentOS 7にApacheをインストールする方法
CentOS 7サーバーにApache 2.4をインストールする方法を説明します。安定したウェブサーバーを構築するための前提条件と手順を解説します。
この記事では、CentOS / RHEL 7.xシステムの起動プロセスについて説明します。RHEL 7では、以前のリリースと同様のままかもしれませんが、systemdが導入されています。起動プロセスに加えて、途中でトラブルシューティングのヒントとコツを提供します。
起動時の問題を積極的にトラブルシューティングする前に、起動プロセスを理解する必要があります。プロセスに慣れるまで、以下の手順を確認してください。
/sbin/init
、pid 1として実行します。/sysroot
)。/sysroot
)からシステムrootfs(/
)に切り替わり、systemdがシステムバージョンとして再実行されます。起動プロセスの詳細については、システムの公式OSのドキュメントを参照してください。
ターゲットは基本的に依存関係のチェックです。それらは、そのターゲットを満たすために必要なサービスを正確に「前」と「後」の構成にしています。例:arp.ethernet.service
、firewalld.service
などが開始されており、前に動作している必要がありますnetwork.target
。それは達していない場合は、などのサービスhttpd
、nfs
およびは、ldap
起動することはできません。RHEL / CentOS 7で設定できるターゲットは4つあります。
現在のデフォルトのブートターゲットを表示するには、以下を使用します。
systemctl get-default
ターゲットを分離することで、実行時にこれを変更できることに注意してください。これにより、新しいターゲットに関連付けられたすべてのサービスが開始/停止するため、注意してください(を参照systemctl isolate new.target
)。
オペレーティングシステムの問題を修正するために、シングルユーザーモードで起動する必要がある場合があります。この例rescue.target
では、RHEL / CentOS 7で「シングルユーザーモード」を使用する方法を示します。
systemd.unit=rescue.target
このプロセスは、以前のリリースで使用したものとは少し異なりますが、その単純なタスクであり、そのために必要な手順はほとんどありません。資格情報を回復する必要がある場合は、この方法を使用してVMにアクセスできます。ライブCDから起動し、ルートファイルシステムをマウントし、パスワードを編集することはできますが、その方法は古くなっており、より多くの労力が必要です。
rd.break
(引用符なし)すると、コントロールがinitramfsから実際のシステムに渡される直前にブートプロセスが中断されます。この時点で、ルートシェルは、に読み取り専用モードでマウントされたルートファイルシステムとともに表示されます/sysroot
。書き込み権限で再マウントする必要があります。
再マウント/sysroot
。
# mount -oremount,rw /sysroot
chroot jailに切り替えます。
# chroot /sysroot
資格情報が古くなっているユーザーのパスワードを変更します。
# passwd <username>
SElinuxを使用している場合は、ブートプロセスを続行する前に、すべてのファイルのラベルを付け直すことを検討してください。SElinuxを使用していない場合、この部分はスキップできます。
# touch /.autorelabel
2回終了すると、システムは中断したところからクリーンに起動します。
以前に失敗したブート試行のログを表示すると役立つ場合があります。journaldログが永続化されている場合(通常はメモリに保存され、起動時に解放されます)、これはjournalctl
ツールで実行できます。永続的なブートログを設定する必要がある場合は、次の手順に従ってください。
rootとして、この情報を保存するためのログファイルを作成します。
# mkdir -p 2775 /var/log/journal && chown :systemd-journal /var/log/journal
# systemctl restart systemd-journald
前回のブートのログを検査するには、-b
オプションをで使用しますjournalctl
。引数がない場合-b
、最後のブートに関連するメッセージのみに出力をフィルタリングします。この引数に負の数を指定すると、以前のブートでフィルタリングされます。例えば:
# journalctl -b-1 -p err
これにより、最新の前に発生したブートのエラーログが表示されます。表示する必要があるブートを反映するように数値を変更する必要があります。
最も一般的な起動時エラーの1つは、誤って構成された/etc/fstab
ファイルです。を使用してエラーを修正することはできません。これらの問題のほとんどは、「レスキュー」がより機能的なシステムを必要とするため、使用する必要があります。rescue.target
/etc/fstab
emergency.target
以下は、を必要とする問題の例ですemergency.target
。
/etc/fstab
ます。/etc/fstab
。/etc/fstab
。重要:/etc/fstab
緊急モードでファイルを編集した後、安全対策のために以下を実行する必要があります。
# systemctl daemon-reload
これはウォークスルーの例です。緊急モードで起動して、の誤ったエントリを削除します/etc/fstab
。
systemd.unit=emergency.target
/
を変更できるように再マウントしfstab
ます。# mount -oremount,rw /
mount
コマンドを使用して、エラーの原因となっているエントリを確認できます。# mount -a
fstab
ファイルから削除します。mount -a
再度使用して、エラーが解決されたことを確認します。systemctl daemon-reload
私はすべてのユニットファイルをリロードし、全体の依存関係ツリーを再作成するために前述したよう。緊急シェルを終了すると、システムは緊急ターゲットからの起動を完了し、その時点から通常どおり続行できます。この例は、緊急ターゲットを使用してシステム上のファイルに永続的な変更を加えるプロセスを示すために使用されました。
/boot/grub2/grub.cfg
ファイルには、メインの設定ファイルです。このファイルを手動で編集しないでください。代わりに、grub2-mkconfig
一連の異なる構成ファイルとインストールされたカーネルのリストを使用して、新しいgrub2 構成を生成するために使用します。このgrub2-mkconfig
コマンドは/etc/default/grub
、デフォルトのメニュータイムアウトや使用するカーネルコマンドラインなどのオプションを確認し、スクリプトセットを使用し/etc/grub.d/
て、結果の構成ファイルを生成します。
これは、この関係のテキスト図です。
/boot/grub2/grub.cfg
|
|__________________
| |
/etc/default/grub /etc/grub.d/*
重要:メインのgrub.cfgファイルを編集するには、次のコマンドを実行して、ファイルに必要な変更を加え、新しい/etc/default/grub
ファイルを/etc/grub.d/
作成する必要がありますgrub.cfg
。
# grub2-mkconfig > /boot/grub2/grub.cfg
/boot/grub2/grub.cfg
トラブルシューティングを行う前に、ファイルの構文を理解することが重要です。
linux16
、initrd16
行はディスクからロードされるカーネル(カーネルコマンドラインとともに)とロードされるinitramfsを指します。ブート時のインタラクティブな編集中に、これらの行を見つけるためにタブが使用されます。harddrive.partition
ここでhd0
、システムの最初のハードディスクドライブであり、hd1
第二あります。パーティションはmsdos1
、最初のMBRパーティションまたはgpt1
最初のGPTパーティションとして示されます。の例/boot/grub2/grub.cfg
:
### BEGIN /etc/grub.d/10_linux ###
menuentry 'CentOS Linux (3.10.0-514.26.2.el7.x86_64) 7 (Core)' --class centos --class gnu-linux --class gnu --class os --unrestricted $menuentry_id_option 'gnulinux-3.10.0-514.el7.x86_64-advanced-a2531d12-46f8-4a0f-8a5c-b48d6ef71275' {
load_video
set gfxpayload=keep
insmod gzio
insmod part_msdos
insmod ext2
set root='hd0,msdos1'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1' 123455ae-46f8-4a0f-8a5c-b48d6ef71275
else
search --no-floppy --fs-uuid --set=root 123455ae-46f8-4a0f-8a5c-b48d6ef71275
fi
デバイスにブートローダーを再インストールする必要がある場合は、次のコマンドを使用します。
# grub2-install <device>
システムがgrub2メニューに到達しても起動しない場合。
/
)を再度マウントする必要があります。# grub2-mkconfig
/boot/grub2/grub.cfg
ファイルを編集した可能性があります。このファイルは変更しないでください。次のコマンドで構成を再構築します。# grub2-mkconfig > /boot/grub2/grub.cfg
grub設定を再構築したら、問題なく再起動できるはずです。
CentOS 7サーバーにApache 2.4をインストールする方法を説明します。安定したウェブサーバーを構築するための前提条件と手順を解説します。
CentOS 7にSeafileサーバーをインストールする方法。Seafile(コミュニティバージョン)は、ownCloudに似た無料のオープンソースファイル同期および共有ソリューションです。
CentOS 7にGraylogサーバーをインストールし、ログ管理を行う方法を学びます。
別のシステムを使用していますか?はじめにCyberPanelは、オープンソースでありOpenLiteSpeedを使用する市場で最初のコントロールパネルの1つです。なんてこった
LinuxおよびUnixのシステム管理者の間では、sudoユーザーを使用してサーバーにアクセスし、コマンドをルートレベルで実行することは非常に一般的です。sudの使用
別のシステムを使用していますか?Netdataは、リアルタイムのシステムメトリックモニタリングの分野における新星です。同じ種類の他のツールと比較すると、Netdata:
このチュートリアルでは、Just Cause 2マルチプレイヤーサーバーのセットアップ方法をよく学びます。前提条件開始する前に、システムが完全に更新されていることを確認してください
別のシステムを使用していますか?このチュートリアルでは、CentOS 7でStarboundサーバーをセットアップする方法を説明します。前提条件このゲームを所有している必要があります。
Go(Golangとも呼ばれます)は、静的に型付けされ、コンパイルされた、Cのようなプログラミング言語で、Googleによって開発されました。シンプルさと多用途性により、b
Djangoは、Webアプリケーションを作成するための一般的なPythonフレームワークです。Djangoを使用すると、ホイールを再発明することなく、アプリケーションをより速く構築できます。あなたが望むなら
別のシステムを使用していますか?TextPattern CMS 4.6.2はシンプルで柔軟な無料のオープンソースコンテンツ管理システム(CMS)であり、Webデザイナーが
別のシステムを使用していますか?Elggはオープンソースのソーシャルネットワーキングエンジンであり、キャンパスのソーシャルネットワークや
Froxlorは、オープンソースの無料で軽量かつ強力なサーバー管理パネルであり、Webホスティングサービスの確立と管理に最適です。ティ
Matrixは、分散型リアルタイム通信用のオープンスタンダードの通信プロトコルです。マトリックスは、上記に分散されているホームサーバーとして実装されています
Vtiger CRMは、企業が売り上げを伸ばし、顧客サービスを提供し、利益を増やすのに役立つ人気の顧客関係管理アプリケーションです。私
はじめにこのチュートリアルでは、Vultr VPSにPufferPanelをインストールしてください。PufferPanelは、オープンソースで自由に使用できるコントロールパネルで、あなたを管理します
はじめにこのチュートリアルでは、NGINXまたはApacheを使用してPHP 5 *を7に更新する方法について説明します。前提条件始める前に、リポジトリを追加する必要があります
MoinMoinは、Pythonで書かれたオープンソースのファイルシステムベースのWikiエンジンです。今日、MoinMoinはオープンソースコミュニティで広く使用されています。多くのベンダー
別のシステムを使用していますか?SonarQubeは、品質システム開発のためのオープンソースツールです。Javaで書かれており、複数のデータベースをサポートしています。それは提供します
PritunlはOpenVPNのオープンソース管理インターフェイスです。プライベートネットワークが可能で、ネイティブIPv6サポートがあり、使用方法は比較的簡単です。ター
CentOS 7サーバーにApache 2.4をインストールする方法を説明します。安定したウェブサーバーを構築するための前提条件と手順を解説します。
FreeBSD 11.1におけるBlacklistdのインストール方法について詳しく解説します。この方法を通じて、強力なセキュリティ対策を実装できます。
サーバーマネージャーを使用して、Windows Serverの管理が向上します。セキュリティリスクを軽減し、効率的な管理を実現します。
CentOS 7にSeafileサーバーをインストールする方法。Seafile(コミュニティバージョン)は、ownCloudに似た無料のオープンソースファイル同期および共有ソリューションです。
Snortは無料のネットワーク侵入検知システムです。最新の方法で、SnortをDebianにインストールし、設定する手順を紹介します。ネットワークのセキュリティを強化しましょう。
CentOS 7にGraylogサーバーをインストールし、ログ管理を行う方法を学びます。
WindowsサーバーでWebサイトを実行している場合、電子メールも受信できるようにするためにhMailServerを使用する方法を解説します。
FiveMサーバーをUbuntu 19.04にインストールするための詳細なガイド。必要条件からインストール、起動、トラブルシューティングまで、すべてのステップを含みます。
Debian 10にWebDAVをデプロイする方法を学び、WsgiDAVとSSL証明書で安全な接続を実現しましょう。
ヘルスケアにおけるAIは、過去数十年から大きな飛躍を遂げました。したがって、ヘルスケアにおけるAIの未来は、日々成長を続けています。