ncc.zabbix_fbsd_templates
10:8e4f72f0be61
Go to Latest
ncc.zabbix_fbsd_templates/src/aw.fbsd-mon-helper/lib/pkg.sh
+ Мониторим не только сами активные сетевые сервисы, но и их зависимости, #1
+ Версия, для отслеживания состояния набора скиптов через zabbix, #3
+ Возможность мониторинга дополнительных пакетов, задаётся в конфиге, #2
+ Не позволяем запиститься с отсутствующей директорией состояний, #4
2 # Различная статистика по пакетам
4 v_pkg_detail_status="$STATE_ROOT/pkg_detail"
5 v_pkg_update_status="$STATE_ROOT/pkg_update"
6 v_pkg_detail_status_list="${TMP_ROOT}/pkg_detail_status_list"
9 if !
[ -d
"$v_pkg_detail_status" ]; then
10 mkdir
-p
"$v_pkg_detail_status"
12 # Удаляем старые директории, в которые давно не не пишутся данные по пакетам
13 log
"Clean old detail pakages"
14 find
"$v_pkg_detail_status" -type
f
-ctime
+1
-print0
| xargs
-0n
1 rm
-frv
2>
&1 | log
18 # Обновление базы аудита происходит на получении общих данных по пакетам
20 touch
"${v_pkg_detail_status_list}"
23 pkg_get_detail_pkg_list
() {
27 cat
"${USER_MON_PKG_LIST}" | while read vl_buf
; do
28 vl_pkg_fullname=$(pkg
query
'%n-%v' "${vl_buf}")
29 [ -n
"${vl_pkg_fullname}" ] && echo "${vl_pkg_fullname}" >>
"${v_pkg_detail_status_list}"
32 service
-e
| awk
'$1 ~ "^/usr/local" {print $1}' | while read vl_buf
; do
33 if !
[ -f
"$vl_buf" ] ; then
37 vl_pkg_fullname="$(pkg
which
"$vl_buf" | awk
'$0 ~ "was installed by package" {print $6}')"
39 if [ -z
"$vl_pkg_fullname" ] ; then
40 log
"$vl_buf have no matched pkg"
45 echo "${vl_pkg_fullname}"
46 pkg
query
'%rn' "${vl_pkg_fullname}"
47 pkg
query
'%dn' "${vl_pkg_fullname}"
48 } >>
"${v_pkg_detail_status_list}"
60 pkg_get_detail_pkg_list
61 cat
"${v_pkg_detail_status_list}" | sort
| uniq
| while read vl_pkg_fullname
; do
62 log
"Working with $vl_pkg_fullname"
64 vl_pkg_name="$(pkg
query
'%n' "$vl_pkg_fullname")"
65 vl_pkg_repo="$(pkg
query
'%R' "$vl_pkg_fullname")"
66 vl_pkg_ver="$(pkg
query
'%v' "$vl_pkg_fullname")"
67 vl_pkg_status="$(pkg
version
-r
"$vl_pkg_repo" -qUn
"$vl_pkg_name" | awk
'{print $2}')"
69 case "$vl_pkg_status" in
75 vl_pkg_status="NEED UPDATE"
79 vl_pkg_status="REPO VERSION LOWER"
83 vl_pkg_status="NO PACKAGE IN REPO"
88 log_err
-s
"${vl_pkg_name}: pkg can not compare version of package"
92 log_err
-s
"${vl_pkg_name}: unknown status ${vl_pkg_status}"
98 vl_status_file="${v_pkg_detail_status}/${vl_pkg_name}"
99 pkg
query
'installed=%t\nmainteiner=%m\nsize=%sb\nlocked=%k' "$vl_pkg_fullname" \
100 >
"${vl_status_file}"
102 printf 'ver=%s\nrepo=%s\nstatus=%s\n' "${vl_pkg_ver}" "${vl_pkg_repo}" "${vl_pkg_status}" >>
"$vl_status_file"
103 pkg
audit
"$vl_pkg_fullname" \
104 | awk
'!($0 ~ "[0-9]* problem\\(s\\) in [0-9]* installed package\\(s\\) found") {print $0}' \
105 >
"${vl_status_file}.audit"
110 pkg_check_up_status
() {
111 # Проверка статуса наличия обновления для пакета
115 cat
/dev/null
>
"$v_pkg_update_status"
116 pkg
version
-qUL
= | awk
'$2 != ">" {print $1}' | while read _pkg
; do
117 vl_pkg_name="$(pkg
query
'%n' "${_pkg}")"
118 vl_pkg_repo="$(pkg
query
'%R' "${_pkg}")"
119 log
"Check update for ${vl_pkg_name} in ${vl_pkg_repo}"
120 pkg
version
-Ur
"${vl_pkg_repo}" -n
"${vl_pkg_name}" \
121 | awk
'$2 != ">" && $2 != "=" {print $1}' \
122 | tee
-a
"$v_pkg_update_status" \
123 | awk
'$0 != "" {print "UPDATE STATUS:", $0}' | log
126 pkg
upgrade
-Uqn
| tee
-a
"$v_pkg_update_status" | awk
'$0 != "" {print "PKG UPGRADE:", $0}' | log
135 pkg
audit
-qF
>
"${v_pkg_update_status}.audit"