სტატიების დირექტორია
ადრეჩენ ვეილიანგიბლოგმა გააზიარაCentOS 6 სახელმძღვანელო Monit ▼-ის ინსტალაციისა და კონფიგურაციისთვის
თუმცა, CentOS 7 კონფიგურაციაშიმონიტორინგის მონიტორინგიპროგრამა, გარკვეული განსხვავებებით CentOS 6-ისგან, არ არის ზუსტად იგივე.
თუ შენიLinuxჰოსტი იყენებს CentOS 7 სისტემას. ვესტას CP პანელზე Monit-ის დაყენების შემდეგ, შეგიძლიათ მიჰყვეთ ამ სახელმძღვანელოს Monit-ის მონიტორინგის პროგრამის კონფიგურაციისთვის.
მონიტორინგის პროცესის მონიტორინგს
ქვემოთ მოცემულია Monit-ის მონიტორინგის პროცესის სერვისის კონფიგურაციის შინაარსი (წაშალეთ ზოგიერთი ნაკლებად გამოყენებული მონიტორინგის სერვისი):
-
მოჭედილი - კრონდი
- მტრედი
- ექსიმ
- httpd
-
memcached - mysql
- nginx
-
სპამასასი - სშდ
- ვესტა-ნგინქსი
- vesta-php
- vsftpd
-
ჩართულია სივრცისა და ინოდების მონიტორინგი -
სისტემის რესურსების მონიტორინგი (RAM, swap, CPU, დატვირთვა)
მონიტორინგის კონფიგურაციის მონიტორინგი
Monit კონფიგურაციის ფაილის სახელები განსხვავებულია CentOS 6 და 7-ისთვის:
- CentOS 6-ისთვის Monit კონფიგურაციის ფაილის სახელია "monit.conf"
- CentOS 7-ისთვის 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 timeout
თუ თქვენ შეცვალეთ MONIT კონფიგურაციის კონტენტი, უნდა გადატვირთოთ Monit სერვისი, რომ ძალაში შევიდეს ▼
systemctl restart monit
განახლება 2018 წლის 5 ივლისს:
- რეკომენდირებულია გამოიყენოთ ზემოაღნიშნული კონფიგურაციის შინაარსი ▲
- შემდეგი 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 ხედვა monit.log 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:წაშალეთ Monit-ის მონიტორინგის სერვისის ფაილი "root-space.conf" ▼
rm -rf root-space.conf
ნაბიჯი 3:SSH გადატვირთვა მონიტორის მონიტორინგი ▼
systemctl restart monit.service
Monit Command (სპეციფიკური CentOS 7)
იხილეთ Monit-ის გაშვების სტატუსი ▼
systemctl status monit.service
გაუშვით Monit სერვისი ▼
systemctl start monit.service
დახურეთ Monit სერვისი ▼
systemctl stop monit.service
გადატვირთეთ Monit სერვისი ▼
systemctl restart monit
გაუშვით Monit სერვისი ჩატვირთვისას ▼
systemctl enable monit.service
ჩართეთ და გამორთეთ Monit სერვისი ▼
systemctl disable monit.service
იმედი ჩენ ვეილიანგის ბლოგი ( https://www.chenweiliang.com/ ) გააზიარა „როგორ დავაკონფიგურიროთ Monit პროცესი CentOS 7 სისტემის Vesta CP პანელზე? , რომ დაგეხმარო.
კეთილი იყოს თქვენი მობრძანება ამ სტატიის ბმულის გასაზიარებლად:https://www.chenweiliang.com/cwl-730.html
კეთილი იყოს თქვენი მობრძანება Chen Weiliang-ის ბლოგის ტელეგრამის არხზე, რომ მიიღოთ უახლესი განახლებები!
📚 ეს სახელმძღვანელო შეიცავს უზარმაზარ ღირებულებას, 🌟ეს იშვიათი შესაძლებლობაა, არ გამოტოვოთ! ⏰⌛💨
გააზიარეთ და მოიწონეთ თუ მოგეწონათ!
თქვენი გაზიარება და მოწონებები ჩვენი უწყვეტი მოტივაციაა!