記事ディレクトリ
前にチェン・ウェイリアンブログが共有しましたCentOSの 6 Monitのインストールと設定のチュートリアル ▼
ただし、CentOS 7 構成ではモニタリングの監視このプログラムは、CentOS 6 とは多少異なりますが、まったく同じではありません。
もしあなたのLinuxホストは CentOS 7 システムを使用します. Vesta CP パネルに Monit をインストールした後、このチュートリアルに従って Monit 監視プログラムを構成できます.
監視プロセス サービスの監視
以下は、Monit 監視プロセスのサービス構成の内容です (あまり使用されていない監視サービスをいくつか削除します)。
-
クラム - クローン
- 鳩小屋
- exim
- httpdの
-
memcached - mysqlの
- nginx
-
spamassassin - sshd
- ベスタ-nginx
- ベスタ-php
- vsftpdの
-
領域と inode を監視する -
システム リソースの監視 (RAM、スワップ、CPU、負荷)
監視構成の監視
CentOS 6 と 7 では、Monit 構成ファイルの名前が異なります。
- CentOS 6 の Monit 構成ファイルの名前は「monit.conf」です。
- CentOS7のMonit構成ファイルの名前は「monitrc」です。
SFTP で ソフトウェアLinux サーバーに入ったら、Monit 構成ファイルを編集します ▼
/etc/monitrc
この「monitrc」ファイルに以下の設定内容を追加▼
##
## 陈沩亮博客示例monit配置文件说明:
## 1. 域名以 www.etufo.org 为例。
## 2. 后面带xxx的均是举例用的名字,需要根据自己的需要修改。
##
################################################## #############################
## Monit control file
################################################## #############################
#
# 检查周期,默认为2分钟,对于网站来说有点长,可以根据需要自行调节,这改成30秒。
set daemon 30
include /etc/monit.d/*
# 日志文件
set logfile /var/log/monit.log
#
# 邮件通知服务器
#
#set mailserver mail.example.com
set mailserver localhost with timeout 30 seconds
#
# 通知邮件的格式设置,下面是默认格式供参考
#
## Monit by default uses the following alert mail format:
##
## --8<--
## From: monit@$HOST # sender
## Subject: monit alert -- $EVENT $SERVICE # subject
##
## $EVENT Service $SERVICE #
## #
## Date: $DATE #
## Action: $ACTION #
## Host: $HOST # body
## Description: $DESCRIPTION #
## #
## Your faithful employee, #
## monit #
## --8<--
##
## You can override the alert message format or its parts such as subject
## or sender using the MAIL-FORMAT statement. Macros such as $DATE, etc.
## are expanded on runtime. For example to override the sender:
#
# 简单的,这只改了一下发送人,有需要可以自己修改其它内容。
set mail-format { from: admin@xxxx }
# 设置邮件通知接收者。建议发到gmail,方便邮件过滤。
set alert xxx@xxxx
set httpd port 2812 and #设置http监控页面的端口
use address www.etufo.org # http监控页面的IP或域名
##allow localhost # 允许本地访问
##allow 203.82.90.239 # 允许指定IP访问
allow user:password # 访问用户名密码
################################################## #############################
## Services
################################################## #############################
#
# 系统整体运行状况监控,默认的就可以,可以自己去微调
#
# 系统名称,可以是IP或域名
#check system www.etufo.org
# if loadavg (1min) > 4 then alert
# if loadavg (5min) > 2 then alert
# if memory usage > 75% then alert
# if cpu usage (user) > 70% then alert
# if cpu usage (system) > 30% then alert
# if cpu usage (wait) > 20% then alert
# 可选的ssl端口的监控,如果有的话
# if failed port 443 type tcpssl protocol http
# with timeout 15 seconds
# then restart
# 监控mariadb
check process mysql with pidfile /var/run/mariadb/mariadb.pid
start program = "/usr/bin/systemctl start mariadb"
stop program = "/usr/bin/systemctl stop mariadb"
if failed host 127.0.0.1 port 3306 for 2 cycles then restart
if 2 restarts within 4 cycles then timeout
# 监控httpd
check process httpd with pidfile /var/run/httpd/httpd.pid
start program = "/usr/bin/systemctl start httpd"
stop program = "/usr/bin/systemctl stop httpd"
# if children > 120 for 2 cycles then restart
# if failed host localhost port 8080 protocol http for 2 cycles then restart
# if 4 restarts within 10 cycles then timeout
# 监控nginx
check process nginx with pidfile /var/run/nginx.pid
start program = "/usr/bin/systemctl start nginx"
stop program = "/usr/bin/systemctl stop nginx"
# if failed host localhost port 443 protocol http for 2 cycles then restart
# if 4 restarts within 10 cycles then timeout
# 监控sshd
check process sshd with pidfile /var/run/sshd.pid
start program = "/usr/bin/systemctl start sshd"
stop program = "/usr/bin/systemctl stop sshd"
if failed host localhost port 22 protocol ssh for 2 cycles then restart
if 4 restarts within 10 cycles then timeout
# 监控vesta-nginx
check process vesta-nginx with pidfile /var/run/vesta-nginx.pid
start program = "/usr/bin/systemctl start vesta"
stop program = "/usr/bin/systemctl stop vesta"
if failed host localhost port 8083 protocol https for 2 cycles then restart
if 4 restarts within 10 cycles then timeout
# 监控vesta-php
check process vesta-php with pidfile /var/run/vesta-php.pid
start program = "/usr/bin/systemctl start vesta"
stop program = "/usr/bin/systemctl stop vesta"
if failed host localhost port 8083 protocol https for 2 cycles then restart
if 4 restarts within 10 cycles then timeout
# 监控vsftpd
check process vsftpd with match vsftpd
start program = "/usr/bin/systemctl start vsftpd"
stop program = "/usr/bin/systemctl stop vsftpd"
if failed host localhost port 21 protocol ftp for 2 cycles then restart
if 4 restarts within 10 cycles then timeout
#监控crond
check process crond with pidfile /var/run/crond.pid
start program = "/usr/bin/systemctl start crond"
stop program = "/usr/bin/systemctl stop crond"
if 5 restarts within 5 cycles then timeout
#监控dovecot
check process dovecot with pidfile /var/run/dovecot/master.pid
start program = "/usr/bin/systemctl start dovecot"
stop program = "/usr/bin/systemctl stop dovecot"
if failed host localhost port 143 protocol imap for 2 cycles then restart
if 4 restarts within 10 cycles then timeout
#监控exim
check process exim with pidfile /var/run/exim.pid
start program "/usr/bin/systemctl start exim"
stop program "/usr/bin/systemctl stop exim"
if failed host localhost port 25 protocol smtp for 2 cycles then restart
if 4 restarts within 10 cycles then timeoutMONIT 構成の内容を変更した場合は、Monit サービスを再起動して有効にする必要があります▼
systemctl restart monit
2018年5月26日の更新:
- 上記の構成内容を使用することをお勧めします▲
- 以下の SSH コマンドは、Monit モニタリング サービス用のファイルを生成するために推奨されません。
cd /etc/monit.d/
git clone https://github.com/infinitnet/vesta-centos7-monit.git ./ && rm -f README.md
myip=1.2.3.4
sed -i 's/host localhost/host '$myip'/g' /etc/monit.d/*.conf
systemctl restart monit- 共有 IP に置き換えます1.2.3.4。
エラーが発生する可能性があるため、git bashコマンドが見つかりませんでした▼
このコマンドを入力した後、 ▼
sed -i 's/host localhost/host '$myip'/g' /etc/monit.d/*.conf
以下のエラーメッセージが表示される ▼
sed: can't read /etc/monit.d/*.conf: No such file or directory
ログ表示エラーの監視
SSH view monit.log ログファイルコマンド▼
tailf /var/log/monit.log
- SSH を使用して monit.log ファイルを表示します。ログの最後の 10 行のみを表示できます。
SFTP ログインを推奨 /var/log/monit.log 以前の monit.log ログ ファイルのステータスを完全に表示します。
メール送信エラー
Monitメールを送信できない場合、以下のエラーメッセージが表示されます▼
error : Cannot open a connection to the mailserver localhost:25 -- Operation now in progress error : Mail: Delivery failed -- no mail server is available
メール送信エラーを修正する
チェン・ウェイリアン使用をお勧めしますGmailの SMTP ▼
set mailserver smtp.gmail.com port 587 username "[email protected]" password "password" using tlsv1 with timeout 30 seconds
解決策は、Monit 構成ファイルで設定されているメールサーバーを置き換えることです。詳細については、このチュートリアルを確認してください ▼
ファイルシステム統計エラー
monit.log ログファイルに以下のエラーが見つかった場合 ▼
filesystem statistic error: cannot read /proc/diskstats -- No such file or directory
- おそらく、Linux がデフォルトで最小インストールになっているためです。 VestaCPパネル、存在しません
/proc/diskstatsディスク状態監視ファイル。
ファイルシステムの統計エラーを解決する
ステップ1:SSH で /etc/monit.d カタログ▼
cd /etc/monit.d
ステップ2:Monitor監視サービスファイル「root-space.conf」を削除▼
rm -rf root-space.conf
ステップ3:SSH再起動 監視監視 ▼
systemctl restart monit.service
Monitコマンド(CentOS 7専用)
Monitの起動ステータスを表示する▼
systemctl status monit.service
モニターサービス開始 ▼
systemctl start monit.service
監視サービスを閉じる▼
systemctl stop monit.service
Monit サービスを再起動する ▼
systemctl restart monit
起動時にMonitサービスを開始 ▼
systemctl enable monit.service
Monit サービスのオンとオフを切り替える ▼
systemctl disable monit.service
Hope Chen Weiliang ブログ ( https://www.chenweiliang.com/ ) 共有 "CentOS 7 システムの Vesta CP パネルで Monit プロセスを構成する方法は? 、 あなたを助けること。
この記事のリンクを共有することを歓迎します。https://www.chenweiliang.com/cwl-730.html
さらに多くの隠されたトリックのロックを解除するには、Telegram チャンネルにぜひご参加ください。
気に入ったらシェアして「いいね!」してください!あなたのシェアと「いいね!」が私たちの継続的なモチベーションです。
