Linux vps 6.8.0-39-generic #39-Ubuntu SMP PREEMPT_DYNAMIC Fri Jul 5 21:49:14 UTC 2024 x86_64
nginx/1.26.1
Server IP : 91.227.41.192 & Your IP : 172.69.58.176
Domains :
Cant Read [ /etc/named.conf ]
User : clp
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Lock Shell
Lock File++
Readme
/
usr /
sbin /
Delete
Unzip
Name
Size
Permission
Date
Action
NetworkManager
4.98
MB
-rwxrwxr-x
2024-04-05 16:36
aa-load
38.75
KB
-rwxr-xr-x
2024-07-15 00:25
aa-remove-unknown
3.15
KB
-rwxr-xr-x
2024-07-15 00:25
aa-status
39.06
KB
-rwxr-xr-x
2024-07-15 00:25
aa-teardown
137
B
-rwxr-xr-x
2024-03-17 08:55
add-shell
1.03
KB
-rwxr-xr-x
2024-03-31 10:47
addgnupghome
3
KB
-rwxr-xr-x
2024-04-06 18:25
addgroup
53.9
KB
-rwxr-xr-x
2023-07-05 19:42
adduser
53.9
KB
-rwxr-xr-x
2023-07-05 19:42
agetty
59.56
KB
-rwxr-xr-x
2024-04-09 16:02
apparmor_parser
1.55
MB
-rwxr-xr-x
2024-07-15 00:25
apparmor_status
39.06
KB
-rwxr-xr-x
2024-07-15 00:25
applygnupgdefaults
2.17
KB
-rwxr-xr-x
2024-04-06 18:25
argdist-bpfcc
36
KB
-rwxr-xr-x
2024-04-16 07:52
arp
61.61
KB
-rwxr-xr-x
2024-04-08 18:14
arpd
26.33
KB
-rwxr-xr-x
2024-03-31 11:00
arptables
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
arptables-nft
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
arptables-nft-restore
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
arptables-nft-save
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
arptables-restore
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
arptables-save
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
auth-otp
18.54
KB
-rwxr-xr-x
2024-05-09 09:08
badblocks
34.32
KB
-rwxr-xr-x
2024-04-08 16:38
bashreadline-bpfcc
2.32
KB
-rwxr-xr-x
2024-04-16 07:52
bashreadline.bt
698
B
-rwxr-xr-x
2024-03-07 23:14
bcache-super-show
14.3
KB
-rwxr-xr-x
2024-04-08 17:54
bindsnoop-bpfcc
15.96
KB
-rwxr-xr-x
2024-04-16 07:52
biolatency-bpfcc
11.1
KB
-rwxr-xr-x
2024-04-16 07:52
biolatency-kp.bt
664
B
-rwxr-xr-x
2024-03-07 23:14
biolatency.bt
681
B
-rwxr-xr-x
2024-03-07 23:14
biolatpcts-bpfcc
10.01
KB
-rwxr-xr-x
2024-04-16 07:52
biopattern-bpfcc
3.86
KB
-rwxr-xr-x
2024-04-16 07:52
biosnoop-bpfcc
10.58
KB
-rwxr-xr-x
2024-04-16 07:52
biosnoop.bt
1.12
KB
-rwxr-xr-x
2024-03-07 23:14
biostacks.bt
915
B
-rwxr-xr-x
2024-03-07 23:14
biotop-bpfcc
9.34
KB
-rwxr-xr-x
2024-04-16 07:52
bitesize-bpfcc
1.14
KB
-rwxr-xr-x
2024-04-16 07:52
bitesize.bt
567
B
-rwxr-xr-x
2024-03-07 23:14
blkdeactivate
15.97
KB
-rwxr-xr-x
2024-03-31 10:03
blkdiscard
22.38
KB
-rwxr-xr-x
2024-04-09 16:02
blkid
54.41
KB
-rwxr-xr-x
2024-04-09 16:02
blkzone
34.38
KB
-rwxr-xr-x
2024-04-09 16:02
blockdev
34.38
KB
-rwxr-xr-x
2024-04-09 16:02
bpflist-bpfcc
2.54
KB
-rwxr-xr-x
2024-04-16 07:52
bpftool
1.58
KB
-rwxr-xr-x
2024-07-05 17:04
bridge
108.49
KB
-rwxr-xr-x
2024-03-31 11:00
btrfsdist-bpfcc
6.47
KB
-rwxr-xr-x
2024-04-16 07:52
btrfsslower-bpfcc
9.75
KB
-rwxr-xr-x
2024-04-16 07:52
cache_check
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
cache_dump
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
cache_metadata_size
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
cache_repair
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
cache_restore
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
cache_writeback
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
cachestat-bpfcc
6.38
KB
-rwxr-xr-x
2024-04-16 07:52
cachetop-bpfcc
9.15
KB
-rwxr-xr-x
2024-04-16 07:52
capable-bpfcc
8.28
KB
-rwxr-xr-x
2024-04-16 07:52
capable.bt
1.88
KB
-rwxr-xr-x
2024-03-07 23:14
capsh
57.09
KB
-rwxr-xr-x
2024-04-08 18:01
cfdisk
94.73
KB
-rwxr-xr-x
2024-04-09 16:02
cgdisk
166.48
KB
-rwxr-xr-x
2024-03-31 07:38
chcpu
30.38
KB
-rwxr-xr-x
2024-04-09 16:02
check_forensic
952
B
-rwxr-xr-x
2011-04-26 17:10
chgpasswd
58.32
KB
-rwxr-xr-x
2024-04-09 09:01
chmem
34.38
KB
-rwxr-xr-x
2024-04-09 16:02
chpasswd
54.43
KB
-rwxr-xr-x
2024-04-09 09:01
chronyd
299.05
KB
-rwxr-xr-x
2024-07-02 22:22
chroot
38.51
KB
-rwxr-xr-x
2024-04-05 16:36
clp-agent
11.03
MB
-rwxr-xr-x
2024-07-29 11:48
cobjnew-bpfcc
53
B
-rwxr-xr-x
2024-04-16 07:52
compactsnoop-bpfcc
11.1
KB
-rwxr-xr-x
2024-04-16 07:52
cpgr
48.45
KB
-rwxr-xr-x
2024-04-09 09:01
cppw
48.45
KB
-rwxr-xr-x
2024-04-09 09:01
cpudist-bpfcc
6.85
KB
-rwxr-xr-x
2024-04-16 07:52
cpuunclaimed-bpfcc
14.59
KB
-rwxr-xr-x
2024-04-16 07:52
cpuwalk.bt
497
B
-rwxr-xr-x
2024-03-07 23:14
criticalstat-bpfcc
8.41
KB
-rwxr-xr-x
2024-04-16 07:52
cron
58.67
KB
-rwxr-xr-x
2024-03-31 01:06
cryptdisks_start
1.51
KB
-rwxr-xr-x
2024-02-26 12:50
cryptdisks_stop
844
B
-rwxr-xr-x
2024-02-26 12:50
cryptsetup
225.9
KB
-rwxr-xr-x
2024-04-08 16:37
ctrlaltdel
14.38
KB
-rwxr-xr-x
2024-04-09 16:02
dbslower-bpfcc
7.22
KB
-rwxr-xr-x
2024-04-16 07:52
dbstat-bpfcc
3.7
KB
-rwxr-xr-x
2024-04-16 07:52
dcb
80.52
KB
-rwxr-xr-x
2024-03-31 11:00
dcsnoop-bpfcc
4.03
KB
-rwxr-xr-x
2024-04-16 07:52
dcsnoop.bt
1.23
KB
-rwxr-xr-x
2024-03-07 23:14
dcstat-bpfcc
3.77
KB
-rwxr-xr-x
2024-04-16 07:52
deadlock-bpfcc
20.45
KB
-rwxr-xr-x
2024-04-16 07:52
debugfs
225.87
KB
-rwxr-xr-x
2024-04-08 16:38
delgroup
18.53
KB
-rwxr-xr-x
2023-07-05 19:42
deluser
18.53
KB
-rwxr-xr-x
2023-07-05 19:42
depmod
170.24
KB
-rwxr-xr-x
2024-04-18 12:06
devlink
150.86
KB
-rwxr-xr-x
2024-03-31 11:00
dhcpcd
395.4
KB
-rwxr-xr-x
2024-05-07 12:12
dirtop-bpfcc
8.37
KB
-rwxr-xr-x
2024-04-16 07:52
dmeventd
50.38
KB
-rwxr-xr-x
2024-03-31 10:03
dmsetup
171.05
KB
-rwxr-xr-x
2024-03-31 10:03
dmstats
171.05
KB
-rwxr-xr-x
2024-03-31 10:03
dphys-swapfile
7.76
KB
-rwxr-xr-x
2022-10-15 12:01
dpkg-preconfigure
4.25
KB
-rwxr-xr-x
2024-04-12 14:40
dpkg-reconfigure
4.43
KB
-rwxr-xr-x
2024-04-12 14:40
drsnoop-bpfcc
6.73
KB
-rwxr-xr-x
2024-04-16 07:52
dumpe2fs
34.31
KB
-rwxr-xr-x
2024-04-08 16:38
e2freefrag
18.3
KB
-rwxr-xr-x
2024-04-08 16:38
e2fsck
364.34
KB
-rwxr-xr-x
2024-04-08 16:38
e2image
42.31
KB
-rwxr-xr-x
2024-04-08 16:38
e2label
110.56
KB
-rwxr-xr-x
2024-04-08 16:38
e2mmpstatus
34.31
KB
-rwxr-xr-x
2024-04-08 16:38
e2scrub
7.12
KB
-rwxr-xr-x
2024-04-08 16:38
e2scrub_all
5.27
KB
-rwxr-xr-x
2024-04-08 16:38
e2undo
22.3
KB
-rwxr-xr-x
2024-04-08 16:38
e4crypt
30.38
KB
-rwxr-xr-x
2024-04-08 16:38
e4defrag
34.3
KB
-rwxr-xr-x
2024-04-08 16:38
ebtables
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ebtables-nft
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ebtables-nft-restore
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ebtables-nft-save
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ebtables-restore
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ebtables-save
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ebtables-translate
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
era_check
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
era_dump
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
era_invalidate
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
era_restore
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
execsnoop-bpfcc
9.82
KB
-rwxr-xr-x
2024-04-16 07:52
execsnoop.bt
928
B
-rwxr-xr-x
2024-03-07 23:14
exitsnoop-bpfcc
9.42
KB
-rwxr-xr-x
2024-04-16 07:52
ext4dist-bpfcc
6.53
KB
-rwxr-xr-x
2024-04-16 07:52
ext4slower-bpfcc
9.71
KB
-rwxr-xr-x
2024-04-16 07:52
faillock
22.31
KB
-rwxr-xr-x
2024-05-03 00:20
fdisk
114.42
KB
-rwxr-xr-x
2024-04-09 16:02
filefrag
18.32
KB
-rwxr-xr-x
2024-04-08 16:38
filegone-bpfcc
5.64
KB
-rwxr-xr-x
2024-04-16 07:52
filelife-bpfcc
6.38
KB
-rwxr-xr-x
2024-04-16 07:52
fileslower-bpfcc
7.2
KB
-rwxr-xr-x
2024-04-16 07:52
filetop-bpfcc
6.35
KB
-rwxr-xr-x
2024-04-16 07:52
findfs
14.38
KB
-rwxr-xr-x
2024-04-09 16:02
fixparts
58.48
KB
-rwxr-xr-x
2024-03-31 07:38
fsadm
24
KB
-rwxr-xr-x
2024-03-31 10:03
fsck
42.42
KB
-rwxr-xr-x
2024-04-09 16:02
fsck.btrfs
1.16
KB
-rwxr-xr-x
2024-03-31 10:43
fsck.cramfs
30.44
KB
-rwxr-xr-x
2024-04-09 16:02
fsck.ext2
364.34
KB
-rwxr-xr-x
2024-04-08 16:38
fsck.ext3
364.34
KB
-rwxr-xr-x
2024-04-08 16:38
fsck.ext4
364.34
KB
-rwxr-xr-x
2024-04-08 16:38
fsck.minix
54.41
KB
-rwxr-xr-x
2024-04-09 16:02
fsck.xfs
2.53
KB
-rwxr-xr-x
2024-03-31 19:31
fsfreeze
14.38
KB
-rwxr-xr-x
2024-04-09 16:02
fstab-decode
14.3
KB
-rwxr-xr-x
2024-04-08 18:20
fstrim
42.38
KB
-rwxr-xr-x
2024-04-09 16:02
ftpasswd
37
KB
-rwxr-xr-x
2024-05-09 09:08
ftpmail
13.63
KB
-rwxr-xr-x
2024-05-09 09:08
ftpquota
32.2
KB
-rwxr-xr-x
2024-05-09 09:08
ftpscrub
23.66
KB
-rwxr-xr-x
2024-05-09 09:08
ftpshut
14.3
KB
-rwxr-xr-x
2024-05-09 09:08
ftpstats
12.16
KB
-rwxr-xr-x
2024-05-09 09:08
funccount-bpfcc
12.68
KB
-rwxr-xr-x
2024-04-16 07:52
funcinterval-bpfcc
5.46
KB
-rwxr-xr-x
2024-04-16 07:52
funclatency-bpfcc
11.28
KB
-rwxr-xr-x
2024-04-16 07:52
funcslower-bpfcc
10.38
KB
-rwxr-xr-x
2024-04-16 07:52
gdisk
198.48
KB
-rwxr-xr-x
2024-03-31 07:38
genl
120.58
KB
-rwxr-xr-x
2024-03-31 11:00
getcap
14.3
KB
-rwxr-xr-x
2024-04-08 18:01
gethostlatency-bpfcc
3.82
KB
-rwxr-xr-x
2024-04-16 07:52
gethostlatency.bt
1.19
KB
-rwxr-xr-x
2024-03-07 23:14
getpcaps
14.3
KB
-rwxr-xr-x
2024-04-08 18:01
getty
59.56
KB
-rwxr-xr-x
2024-04-09 16:02
groupadd
71.13
KB
-rwxr-xr-x
2024-04-09 09:01
groupdel
62.91
KB
-rwxr-xr-x
2024-04-09 09:01
groupmems
58.34
KB
-rwxr-xr-x
2024-04-09 09:01
groupmod
71.04
KB
-rwxr-xr-x
2024-04-09 09:01
grpck
58.32
KB
-rwxr-xr-x
2024-04-09 09:01
grpconv
50.16
KB
-rwxr-xr-x
2024-04-09 09:01
grpunconv
50.16
KB
-rwxr-xr-x
2024-04-09 09:01
grub-bios-setup
953.33
KB
-rwxr-xr-x
2024-04-04 12:12
grub-install
1.16
MB
-rwxr-xr-x
2024-04-04 12:12
grub-macbless
941.2
KB
-rwxr-xr-x
2024-04-04 12:12
grub-mkconfig
8.63
KB
-rwxr-xr-x
2024-04-04 12:12
grub-mkdevicemap
70.69
KB
-rwxr-xr-x
2024-04-04 12:12
grub-probe
949.45
KB
-rwxr-xr-x
2024-04-04 12:12
grub-reboot
4.73
KB
-rwxr-xr-x
2024-04-04 12:12
grub-set-default
3.47
KB
-rwxr-xr-x
2024-04-04 12:12
halt
1.43
MB
-rwxr-xr-x
2024-06-14 23:03
hardirqs-bpfcc
6.85
KB
-rwxr-xr-x
2024-04-16 07:52
httxt2dbm
14.3
KB
-rwxr-xr-x
2024-07-17 20:55
iconvconfig
34.47
KB
-rwxr-xr-x
2024-04-30 20:02
ifconfig
77.17
KB
-rwxr-xr-x
2024-04-08 18:14
ifdown
93.58
KB
-rwxr-xr-x
2024-02-14 15:14
ifquery
93.58
KB
-rwxr-xr-x
2024-02-14 15:14
ifup
93.58
KB
-rwxr-xr-x
2024-02-14 15:14
in.proftpd
1.18
MB
-rwxr-xr-x
2024-05-09 09:08
init
98.45
KB
-rwxr-xr-x
2024-06-14 23:03
inject-bpfcc
16.06
KB
-rwxr-xr-x
2024-04-16 07:52
insmod
170.24
KB
-rwxr-xr-x
2024-04-18 12:06
install-sgmlcatalog
4.44
KB
-rwxr-xr-x
2022-10-06 20:03
installkernel
2.6
KB
-rwxr-xr-x
2024-03-31 10:47
integritysetup
67.06
KB
-rwxr-xr-x
2024-04-08 16:37
invoke-rc.d
16.13
KB
-rwxr-xr-x
2023-12-06 08:46
iotop
496
B
-rwxr-xr-x
2024-04-01 07:56
iotop-py
496
B
-rwxr-xr-x
2024-04-01 07:56
ip
754.74
KB
-rwxr-xr-x
2024-03-31 11:00
ip6tables
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ip6tables-apply
6.89
KB
-rwxr-xr-x
2023-08-13 00:33
ip6tables-legacy
92.95
KB
-rwxr-xr-x
2024-04-08 17:59
ip6tables-legacy-restore
92.95
KB
-rwxr-xr-x
2024-04-08 17:59
ip6tables-legacy-save
92.95
KB
-rwxr-xr-x
2024-04-08 17:59
ip6tables-nft
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ip6tables-nft-restore
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ip6tables-nft-save
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ip6tables-restore
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ip6tables-restore-translate
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ip6tables-save
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ip6tables-translate
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
ipmaddr
18.3
KB
-rwxr-xr-x
2024-04-08 18:14
iptables
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
iptables-apply
6.89
KB
-rwxr-xr-x
2023-08-13 00:33
iptables-legacy
92.95
KB
-rwxr-xr-x
2024-04-08 17:59
iptables-legacy-restore
92.95
KB
-rwxr-xr-x
2024-04-08 17:59
iptables-legacy-save
92.95
KB
-rwxr-xr-x
2024-04-08 17:59
iptables-nft
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
iptables-nft-restore
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
iptables-nft-save
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
iptables-restore
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
iptables-restore-translate
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
iptables-save
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
iptables-translate
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
iptunnel
18.3
KB
-rwxr-xr-x
2024-04-08 18:14
iscsi-iname
18.3
KB
-rwxr-xr-x
2024-04-08 16:46
iscsi_discovery
5.17
KB
-rwxr-xr-x
2024-04-08 16:46
iscsiadm
370.43
KB
-rwxr-xr-x
2024-04-08 16:46
iscsid
286.55
KB
-rwxr-xr-x
2024-04-08 16:46
iscsistart
274.49
KB
-rwxr-xr-x
2024-04-08 16:46
isosize
14.38
KB
-rwxr-xr-x
2024-04-09 16:02
iucode-tool
54.34
KB
-rwxr-xr-x
2024-04-08 18:00
iucode_tool
54.34
KB
-rwxr-xr-x
2024-04-08 18:00
javacalls-bpfcc
55
B
-rwxr-xr-x
2024-04-16 07:52
javaflow-bpfcc
54
B
-rwxr-xr-x
2024-04-16 07:52
javagc-bpfcc
52
B
-rwxr-xr-x
2024-04-16 07:52
javaobjnew-bpfcc
56
B
-rwxr-xr-x
2024-04-16 07:52
javastat-bpfcc
54
B
-rwxr-xr-x
2024-04-16 07:52
javathreads-bpfcc
57
B
-rwxr-xr-x
2024-04-16 07:52
journactl-inithook
4.98
MB
-rwxr-xr-x
2024-04-05 16:36
kbdrate
18.31
KB
-rwxr-xr-x
2024-03-31 11:02
killall5
26.23
KB
-rwxr-xr-x
2024-04-08 18:20
killsnoop-bpfcc
4.45
KB
-rwxr-xr-x
2024-04-16 07:52
killsnoop.bt
873
B
-rwxr-xr-x
2024-03-07 23:14
klockstat-bpfcc
13.04
KB
-rwxr-xr-x
2024-04-16 07:52
kpartx
42.16
KB
-rwxr-xr-x
2024-04-07 02:31
kvmexit-bpfcc
11.19
KB
-rwxr-xr-x
2024-04-16 07:52
ldattach
26.38
KB
-rwxr-xr-x
2024-04-09 16:02
ldconfig
387
B
-rwxr-xr-x
2024-04-30 20:02
ldconfig.real
1
MB
-rwxr-xr-x
2024-04-30 20:02
llcstat-bpfcc
4.48
KB
-rwxr-xr-x
2024-04-16 07:52
loads.bt
1.1
KB
-rwxr-xr-x
2024-03-07 23:14
locale-gen
4.21
KB
-rwxr-xr-x
2023-12-06 10:19
logrotate
94.24
KB
-rwxr-xr-x
2024-04-08 18:11
logsave
14.16
KB
-rwxr-xr-x
2024-04-08 16:38
losetup
74.52
KB
-rwxr-xr-x
2024-04-09 16:02
lsmod
170.24
KB
-rwxr-xr-x
2024-04-18 12:06
luksformat
3.32
KB
-rwxr-xr-x
2024-02-26 12:50
lvchange
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvconvert
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvcreate
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvdisplay
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvextend
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvm
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvmconfig
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvmdiskscan
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvmdump
10.12
KB
-rwxr-xr-x
2024-03-31 10:03
lvmpolld
235.97
KB
-rwxr-xr-x
2024-03-31 10:03
lvmsadc
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvmsar
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvreduce
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvremove
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvrename
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvresize
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvs
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lvscan
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
lxc
589
B
-rwxr-xr-x
2024-05-08 01:33
lxd
589
B
-rwxr-xr-x
2024-05-08 01:33
make-bcache
22.38
KB
-rwxr-xr-x
2024-04-08 17:54
make-ssl-cert
6.65
KB
-rwxr-xr-x
2023-10-01 06:19
mdadm
622.21
KB
-rwxr-xr-x
2024-03-31 11:17
mdflush-bpfcc
2.24
KB
-rwxr-xr-x
2024-04-16 07:52
mdflush.bt
775
B
-rwxr-xr-x
2024-03-07 23:14
mdmon
258.8
KB
-rwxr-xr-x
2024-03-31 11:17
memleak-bpfcc
20.8
KB
-rwxr-xr-x
2024-04-16 07:52
mii-tool
26.73
KB
-rwxr-xr-x
2024-04-08 18:14
mke2fs
130.62
KB
-rwxr-xr-x
2024-04-08 16:38
mkfs
14.38
KB
-rwxr-xr-x
2024-04-09 16:02
mkfs.bfs
22.38
KB
-rwxr-xr-x
2024-04-09 16:02
mkfs.btrfs
560.3
KB
-rwxr-xr-x
2024-03-31 10:43
mkfs.cramfs
34.32
KB
-rwxr-xr-x
2024-04-09 16:02
mkfs.ext2
130.62
KB
-rwxr-xr-x
2024-04-08 16:38
mkfs.ext3
130.62
KB
-rwxr-xr-x
2024-04-08 16:38
mkfs.ext4
130.62
KB
-rwxr-xr-x
2024-04-08 16:38
mkfs.minix
42.39
KB
-rwxr-xr-x
2024-04-09 16:02
mkfs.xfs
438.99
KB
-rwxr-xr-x
2024-03-31 19:31
mkhomedir_helper
22.34
KB
-rwxr-xr-x
2024-05-03 00:20
mkinitramfs
15.13
KB
-rwxr-xr-x
2024-05-10 15:03
mklost+found
14.3
KB
-rwxr-xr-x
2024-04-08 16:38
mkswap
50.38
KB
-rwxr-xr-x
2024-04-09 16:02
modinfo
170.24
KB
-rwxr-xr-x
2024-04-18 12:06
modprobe
170.24
KB
-rwxr-xr-x
2024-04-18 12:06
mount.fuse
18.3
KB
-rwxr-xr-x
2024-04-08 17:57
mount.fuse3
18.3
KB
-rwxr-xr-x
2024-04-08 17:57
mountsnoop-bpfcc
14.62
KB
-rwxr-xr-x
2024-04-16 07:52
mpathpersist
31.21
KB
-rwxr-xr-x
2024-04-07 02:31
multipath
34.3
KB
-rwxr-xr-x
2024-04-07 02:31
multipathc
18.3
KB
-rwxr-xr-x
2024-04-07 02:31
multipathd
142.46
KB
-rwxr-xr-x
2024-04-07 02:31
mysqld
68.16
MB
-rwxr-xr-x
2024-05-09 09:08
mysqld-debug
145.21
MB
-rwxr-xr-x
2024-05-09 09:08
mysqld_qslower-bpfcc
3.05
KB
-rwxr-xr-x
2024-04-16 07:52
nameif
14.39
KB
-rwxr-xr-x
2024-04-08 18:14
naptime.bt
1.01
KB
-rwxr-xr-x
2024-03-07 23:14
needrestart
38.88
KB
-rwxr-xr-x
2024-03-27 23:51
netplan
802
B
-rwxr-xr-x
2024-02-29 09:41
netqtop-bpfcc
5.59
KB
-rwxr-xr-x
2024-04-16 07:52
newusers
86.96
KB
-rwxr-xr-x
2024-04-09 09:01
nfnl_osf
18.3
KB
-rwxr-xr-x
2024-04-08 17:59
nfsdist-bpfcc
4.95
KB
-rwxr-xr-x
2024-04-16 07:52
nfsslower-bpfcc
13.61
KB
-rwxr-xr-x
2024-04-16 07:52
nft
26.23
KB
-rwxr-xr-x
2024-04-08 18:14
nginx
1.29
MB
-rwxr-xr-x
2024-06-06 09:08
nodegc-bpfcc
52
B
-rwxr-xr-x
2024-04-16 07:52
nodestat-bpfcc
54
B
-rwxr-xr-x
2024-04-16 07:52
nologin
14.3
KB
-rwxr-xr-x
2024-04-09 09:01
offcputime-bpfcc
13.46
KB
-rwxr-xr-x
2024-04-16 07:52
offwaketime-bpfcc
15.31
KB
-rwxr-xr-x
2024-04-16 07:52
oomkill-bpfcc
2.04
KB
-rwxr-xr-x
2024-04-16 07:52
oomkill.bt
1.17
KB
-rwxr-xr-x
2024-03-07 23:14
opensnoop-bpfcc
14.24
KB
-rwxr-xr-x
2024-04-16 07:52
opensnoop.bt
953
B
-rwxr-xr-x
2024-03-07 23:14
pam-auth-update
20.96
KB
-rwxr-xr-x
2024-04-30 22:54
pam_extrausers_chkpwd
26.31
KB
-rwxr-sr-x
2024-05-03 00:20
pam_extrausers_update
34.31
KB
-rwxr-xr-x
2024-05-03 00:20
pam_getenv
2.82
KB
-rwxr-xr-x
2024-04-30 22:47
pam_namespace_helper
467
B
-rwxr-xr-x
2024-05-03 00:20
pam_timestamp_check
14.31
KB
-rwxr-xr-x
2024-05-03 00:20
paperconfig
4.07
KB
-rwxr-xr-x
2024-04-08 18:06
pdata_tools
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
perlcalls-bpfcc
55
B
-rwxr-xr-x
2024-04-16 07:52
perlflow-bpfcc
54
B
-rwxr-xr-x
2024-04-16 07:52
perlstat-bpfcc
54
B
-rwxr-xr-x
2024-04-16 07:52
php-fpm7.1
4.4
MB
-rwxr-xr-x
2024-05-09 09:08
php-fpm7.2
4.66
MB
-rwxr-xr-x
2024-05-08 09:08
php-fpm7.3
4.58
MB
-rwxr-xr-x
2024-05-08 09:08
php-fpm7.4
4.58
MB
-rwxr-xr-x
2024-05-08 09:08
php-fpm8.0
4.76
MB
-rwxr-xr-x
2024-05-08 09:08
php-fpm8.1
5.28
MB
-rwxr-xr-x
2024-06-11 09:08
php-fpm8.2
5.39
MB
-rwxr-xr-x
2024-07-12 09:08
php-fpm8.3
5.49
MB
-rwxr-xr-x
2024-07-12 09:08
phpcalls-bpfcc
54
B
-rwxr-xr-x
2024-04-16 07:52
phpdismod
7.11
KB
-rwxr-xr-x
2022-07-13 10:19
phpenmod
7.11
KB
-rwxr-xr-x
2022-07-13 10:19
phpflow-bpfcc
53
B
-rwxr-xr-x
2024-04-16 07:52
phpquery
6.24
KB
-rwxr-xr-x
2022-07-13 10:19
phpstat-bpfcc
53
B
-rwxr-xr-x
2024-04-16 07:52
pidpersec-bpfcc
1.08
KB
-rwxr-xr-x
2024-04-16 07:52
pidpersec.bt
628
B
-rwxr-xr-x
2024-03-07 23:14
pivot_root
14.38
KB
-rwxr-xr-x
2024-04-09 16:02
plipconfig
14.3
KB
-rwxr-xr-x
2024-04-08 18:14
plymouthd
146.57
KB
-rwxr-xr-x
2024-03-31 10:14
postalias
22.3
KB
-rwxr-xr-x
2024-04-08 16:48
postcat
22.37
KB
-rwxr-xr-x
2024-04-08 16:48
postconf
195.8
KB
-rwxr-xr-x
2024-04-08 16:48
postdrop
22.42
KB
-r-xr-sr-x
2024-04-08 16:48
postfix
18.38
KB
-rwxr-xr-x
2024-04-08 16:48
postfix-add-filter
4.84
KB
-rwxr-xr-x
2024-04-08 16:48
postfix-add-policy
3.77
KB
-rwxr-xr-x
2024-04-08 16:48
postfix-collate
3.17
KB
-rwxr-xr-x
2024-04-08 16:48
postkick
14.3
KB
-rwxr-xr-x
2024-04-08 16:48
postlock
14.3
KB
-rwxr-xr-x
2024-04-08 16:48
postlog
14.45
KB
-rwxr-xr-x
2024-04-08 16:48
postmap
22.3
KB
-rwxr-xr-x
2024-04-08 16:48
postmulti
30.69
KB
-rwxr-xr-x
2024-04-08 16:48
postqueue
22.38
KB
-r-xr-sr-x
2024-04-08 16:48
postsuper
30.59
KB
-rwxr-xr-x
2024-04-08 16:48
posttls-finger
42.38
KB
-rwxr-xr-x
2024-04-08 16:48
poweroff
1.43
MB
-rwxr-xr-x
2024-06-14 23:03
ppchcalls-bpfcc
13.89
KB
-rwxr-xr-x
2024-04-16 07:52
profile-bpfcc
14.41
KB
-rwxr-xr-x
2024-04-16 07:52
proftpd
1.18
MB
-rwxr-xr-x
2024-05-09 09:08
proftpd-gencert
1.64
KB
-rwxr-xr-x
2024-05-09 09:08
pvchange
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
pvck
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
pvcreate
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
pvdisplay
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
pvmove
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
pvremove
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
pvresize
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
pvs
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
pvscan
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
pwck
54.29
KB
-rwxr-xr-x
2024-04-09 09:01
pwconv
46.16
KB
-rwxr-xr-x
2024-04-09 09:01
pwhistory_helper
22.31
KB
-rwxr-xr-x
2024-05-03 00:20
pwunconv
46.16
KB
-rwxr-xr-x
2024-04-09 09:01
pythoncalls-bpfcc
57
B
-rwxr-xr-x
2024-04-16 07:52
pythonflow-bpfcc
56
B
-rwxr-xr-x
2024-04-16 07:52
pythongc-bpfcc
54
B
-rwxr-xr-x
2024-04-16 07:52
pythonstat-bpfcc
56
B
-rwxr-xr-x
2024-04-16 07:52
qemu-ga
1.01
MB
-rwxr-xr-x
2024-04-13 00:13
qmqp-sink
18.3
KB
-rwxr-xr-x
2024-04-08 16:48
qmqp-source
22.31
KB
-rwxr-xr-x
2024-04-08 16:48
qshape
12.54
KB
-rwxr-xr-x
2024-04-08 16:48
rarp
32.33
KB
-rwxr-xr-x
2024-04-08 18:14
rdmaucma-bpfcc
4.95
KB
-rwxr-xr-x
2024-04-16 07:52
readahead-bpfcc
6.54
KB
-rwxr-xr-x
2024-04-16 07:52
readprofile
22.41
KB
-rwxr-xr-x
2024-04-09 16:02
reboot
1.43
MB
-rwxr-xr-x
2024-06-14 23:03
remove-shell
1.08
KB
-rwxr-xr-x
2024-03-31 10:47
reset-trace-bpfcc
3.42
KB
-rwxr-xr-x
2024-04-16 07:52
resize2fs
70.3
KB
-rwxr-xr-x
2024-04-08 16:38
resolvconf
158.67
KB
-rwxr-xr-x
2024-06-14 23:03
rmail
18.38
KB
-rwxr-xr-x
2024-04-08 16:48
rmmod
170.24
KB
-rwxr-xr-x
2024-04-18 12:06
rmt
54.71
KB
-rwxr-xr-x
2024-04-08 18:20
rmt-tar
54.71
KB
-rwxr-xr-x
2024-04-08 18:20
route
68.27
KB
-rwxr-xr-x
2024-04-08 18:14
rsyslogd
4.98
MB
-rwxrwxr-x
2024-04-05 16:36
rtacct
28.31
KB
-rwxr-xr-x
2024-03-31 11:00
rtcwake
34.38
KB
-rwxr-xr-x
2024-04-09 16:02
rtmon
116.52
KB
-rwxr-xr-x
2024-03-31 11:00
rubycalls-bpfcc
55
B
-rwxr-xr-x
2024-04-16 07:52
rubyflow-bpfcc
54
B
-rwxr-xr-x
2024-04-16 07:52
rubygc-bpfcc
52
B
-rwxr-xr-x
2024-04-16 07:52
rubyobjnew-bpfcc
56
B
-rwxr-xr-x
2024-04-16 07:52
rubystat-bpfcc
54
B
-rwxr-xr-x
2024-04-16 07:52
runlevel
1.43
MB
-rwxr-xr-x
2024-06-14 23:03
runqlat-bpfcc
9.3
KB
-rwxr-xr-x
2024-04-16 07:52
runqlat.bt
788
B
-rwxr-xr-x
2024-03-07 23:14
runqlen-bpfcc
8.05
KB
-rwxr-xr-x
2024-04-16 07:52
runqlen.bt
1.01
KB
-rwxr-xr-x
2024-03-07 23:14
runqslower-bpfcc
9.01
KB
-rwxr-xr-x
2024-04-16 07:52
runuser
54.38
KB
-rwxr-xr-x
2024-04-09 16:02
sendmail
30.45
KB
-rwxr-xr-x
2024-04-08 16:48
service
8.89
KB
-rwxr-xr-x
2023-12-06 08:50
setcap
14.3
KB
-rwxr-xr-x
2024-04-08 18:01
setuids.bt
1.76
KB
-rwxr-xr-x
2024-03-07 23:14
setvesablank
14.37
KB
-rwxr-xr-x
2024-03-31 11:02
setvtrgb
14.43
KB
-rwxr-xr-x
2024-03-31 11:02
sfdisk
106.38
KB
-rwxr-xr-x
2024-04-09 16:02
sgdisk
178.48
KB
-rwxr-xr-x
2024-03-31 07:38
shadowconfig
2.22
KB
-rwxr-xr-x
2024-02-22 13:30
shmsnoop-bpfcc
7.8
KB
-rwxr-xr-x
2024-04-16 07:52
shutdown
1.43
MB
-rwxr-xr-x
2024-06-14 23:03
slabratetop-bpfcc
6.38
KB
-rwxr-xr-x
2024-04-16 07:52
slattach
36.08
KB
-rwxr-xr-x
2024-04-08 18:14
smtp-sink
35.27
KB
-rwxr-xr-x
2024-04-08 16:48
smtp-source
30.32
KB
-rwxr-xr-x
2024-04-08 16:48
sofdsnoop-bpfcc
8.06
KB
-rwxr-xr-x
2024-04-16 07:52
softirqs-bpfcc
5.59
KB
-rwxr-xr-x
2024-04-16 07:52
solisten-bpfcc
5.96
KB
-rwxr-xr-x
2024-04-16 07:52
split-logfile
2.36
KB
-rwxr-xr-x
2024-07-17 20:55
sshd
895.82
KB
-rwxr-xr-x
2024-07-09 13:31
ssllatency.bt
2.08
KB
-rwxr-xr-x
2024-03-07 23:14
sslsniff-bpfcc
13.68
KB
-rwxr-xr-x
2024-04-16 07:52
sslsnoop.bt
1.99
KB
-rwxr-xr-x
2024-03-07 23:14
stackcount-bpfcc
16.26
KB
-rwxr-xr-x
2024-04-16 07:52
start-stop-daemon
47.49
KB
-rwxr-xr-x
2024-03-31 00:51
statsnoop-bpfcc
4.92
KB
-rwxr-xr-x
2024-04-16 07:52
statsnoop.bt
1.26
KB
-rwxr-xr-x
2024-03-07 23:14
sudo_logsrvd
248.5
KB
-rwxr-xr-x
2024-04-08 16:50
sudo_sendlog
131.67
KB
-rwxr-xr-x
2024-04-08 16:50
sulogin
42.38
KB
-rwxr-xr-x
2024-04-09 16:02
swapin.bt
600
B
-rwxr-xr-x
2024-03-07 23:14
swaplabel
18.38
KB
-rwxr-xr-x
2024-04-09 16:02
swapoff
22.38
KB
-rwxr-xr-x
2024-04-09 16:02
swapon
42.38
KB
-rwxr-xr-x
2024-04-09 16:02
switch_root
22.38
KB
-rwxr-xr-x
2024-04-09 16:02
syncsnoop-bpfcc
1.27
KB
-rwxr-xr-x
2024-04-16 07:52
syncsnoop.bt
839
B
-rwxr-xr-x
2024-03-07 23:14
syscount-bpfcc
8.57
KB
-rwxr-xr-x
2024-04-16 07:52
syscount.bt
872
B
-rwxr-xr-x
2024-03-07 23:14
sysctl
30.38
KB
-rwxr-xr-x
2024-03-31 10:16
tarcat
936
B
-rwxr-xr-x
2024-01-01 22:15
tc
630.08
KB
-rwxr-xr-x
2024-03-31 11:00
tclcalls-bpfcc
54
B
-rwxr-xr-x
2024-04-16 07:52
tclflow-bpfcc
53
B
-rwxr-xr-x
2024-04-16 07:52
tclobjnew-bpfcc
55
B
-rwxr-xr-x
2024-04-16 07:52
tclstat-bpfcc
53
B
-rwxr-xr-x
2024-04-16 07:52
tcpaccept-bpfcc
9
KB
-rwxr-xr-x
2024-04-16 07:52
tcpaccept.bt
1.71
KB
-rwxr-xr-x
2024-03-07 23:14
tcpcong-bpfcc
20.11
KB
-rwxr-xr-x
2024-04-16 07:52
tcpconnect-bpfcc
18.46
KB
-rwxr-xr-x
2024-04-16 07:52
tcpconnect.bt
1.58
KB
-rwxr-xr-x
2024-03-07 23:14
tcpconnlat-bpfcc
9.07
KB
-rwxr-xr-x
2024-04-16 07:52
tcpdrop-bpfcc
7.44
KB
-rwxr-xr-x
2024-04-16 07:52
tcpdrop.bt
2.41
KB
-rwxr-xr-x
2024-03-07 23:14
tcplife-bpfcc
16.55
KB
-rwxr-xr-x
2024-04-16 07:52
tcplife.bt
2.72
KB
-rwxr-xr-x
2024-03-07 23:14
tcpretrans-bpfcc
13.77
KB
-rwxr-xr-x
2024-04-16 07:52
tcpretrans.bt
2.07
KB
-rwxr-xr-x
2024-03-07 23:14
tcprtt-bpfcc
8.7
KB
-rwxr-xr-x
2024-04-16 07:52
tcpstates-bpfcc
13.73
KB
-rwxr-xr-x
2024-04-16 07:52
tcpsubnet-bpfcc
7.63
KB
-rwxr-xr-x
2024-04-16 07:52
tcpsynbl-bpfcc
2.12
KB
-rwxr-xr-x
2024-04-16 07:52
tcpsynbl.bt
962
B
-rwxr-xr-x
2024-03-07 23:14
tcptop-bpfcc
12.64
KB
-rwxr-xr-x
2024-04-16 07:52
tcptracer-bpfcc
17.71
KB
-rwxr-xr-x
2024-04-16 07:52
telinit
1.43
MB
-rwxr-xr-x
2024-06-14 23:03
thermald
526.73
KB
-rwxr-xr-x
2024-03-31 19:19
thin_check
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
thin_delta
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
thin_dump
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
thin_ls
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
thin_metadata_size
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
thin_repair
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
thin_restore
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
thin_rmap
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
thin_trim
1.36
MB
-rwxr-xr-x
2024-04-03 22:32
threadsnoop-bpfcc
1.81
KB
-rwxr-xr-x
2024-04-16 07:52
threadsnoop.bt
712
B
-rwxr-xr-x
2024-03-07 23:14
tipc
90.52
KB
-rwxr-xr-x
2024-03-31 11:00
tplist-bpfcc
4.06
KB
-rwxr-xr-x
2024-04-16 07:52
trace-bpfcc
42.86
KB
-rwxr-xr-x
2024-04-16 07:52
ttysnoop-bpfcc
7.51
KB
-rwxr-xr-x
2024-04-16 07:52
tune2fs
110.56
KB
-rwxr-xr-x
2024-04-08 16:38
u-d-c-print-pci-ids
517
B
-rwxr-xr-x
2022-01-11 13:16
ucalls
11.69
KB
-rwxr-xr-x
2024-04-16 07:52
uflow
7.92
KB
-rwxr-xr-x
2024-04-16 07:52
ufw
4.84
KB
-rwxr-xr-x
2024-03-11 14:18
ugc
7.64
KB
-rwxr-xr-x
2024-04-16 07:52
undump.bt
789
B
-rwxr-xr-x
2024-03-07 23:14
unix_chkpwd
30.31
KB
-rwxr-sr-x
2024-05-03 00:20
unix_update
34.31
KB
-rwxr-xr-x
2024-05-03 00:20
uobjnew
6.04
KB
-rwxr-xr-x
2024-04-16 07:52
update-ca-certificates
5.32
KB
-rwxr-xr-x
2024-02-04 10:41
update-catalog
9.17
KB
-rwxr-xr-x
2022-10-06 20:03
update-fonts-alias
5.71
KB
-rwxr-xr-x
2016-08-21 18:54
update-fonts-dir
3.98
KB
-rwxr-xr-x
2016-08-21 18:54
update-fonts-scale
6.1
KB
-rwxr-xr-x
2016-08-21 18:54
update-grub
64
B
-rwxr-xr-x
2024-02-23 17:55
update-grub-gfxpayload
301
B
-rwxr-xr-x
2015-03-27 18:50
update-grub2
64
B
-rwxr-xr-x
2024-02-23 17:55
update-gsfontmap
390
B
-rwxr-xr-x
2024-07-11 18:07
update-ieee-data
3.41
KB
-rwxr-xr-x
2022-08-27 22:16
update-initramfs
6.75
KB
-rwxr-xr-x
2023-07-31 20:14
update-locale
2.99
KB
-rwxr-xr-x
2023-12-06 10:19
update-passwd
34.56
KB
-rwxr-xr-x
2024-04-08 17:54
update-pciids
1.74
KB
-rwxr-xr-x
2024-04-08 18:15
update-rc.d
17.72
KB
-rwxr-xr-x
2023-12-06 08:47
update-shells
3.89
KB
-rwxr-xr-x
2024-03-31 10:47
update-xmlcatalog
16.88
KB
-rwxr-xr-x
2023-12-12 03:01
upgrade-from-grub-legacy
1.56
KB
-rwxr-xr-x
2024-03-21 14:16
usbmuxd
90.6
KB
-rwxr-xr-x
2024-03-31 19:24
useradd
139.88
KB
-rwxr-xr-x
2024-04-09 09:01
userdel
91.01
KB
-rwxr-xr-x
2024-04-09 09:01
usermod
127.65
KB
-rwxr-xr-x
2024-04-09 09:01
ustat
12.12
KB
-rwxr-xr-x
2024-04-16 07:52
uthreads
4
KB
-rwxr-xr-x
2024-04-16 07:52
validlocale
1.73
KB
-rwxr-xr-x
2022-08-02 17:34
varnishd
5.29
MB
-rwxr-xr-x
2024-05-09 12:06
varnishreload
6.33
KB
-rwxr-xr-x
2024-05-09 12:06
vcstime
14.3
KB
-rwxr-xr-x
2024-03-31 11:02
vdpa
34.56
KB
-rwxr-xr-x
2024-03-31 11:00
veritysetup
43.94
KB
-rwxr-xr-x
2024-04-08 16:37
vfscount-bpfcc
1.36
KB
-rwxr-xr-x
2024-04-16 07:52
vfscount.bt
515
B
-rwxr-xr-x
2024-03-07 23:14
vfsstat-bpfcc
4.06
KB
-rwxr-xr-x
2024-04-16 07:52
vfsstat.bt
721
B
-rwxr-xr-x
2024-03-07 23:14
vgcfgbackup
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgcfgrestore
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgchange
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgck
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgconvert
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgcreate
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgdisplay
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgexport
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgextend
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgimport
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgimportclone
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgmerge
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgmknodes
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgreduce
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgremove
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgrename
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgs
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgscan
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vgsplit
3.01
MB
-rwxr-xr-x
2024-03-31 10:03
vigr
60.69
KB
-rwxr-xr-x
2024-04-09 09:01
vipw
60.69
KB
-rwxr-xr-x
2024-04-09 09:01
virtiostat-bpfcc
8.69
KB
-rwxr-xr-x
2024-04-16 07:52
visudo
248.71
KB
-rwxr-xr-x
2024-04-08 16:50
wakeuptime-bpfcc
8.1
KB
-rwxr-xr-x
2024-04-16 07:52
wipefs
38.38
KB
-rwxr-xr-x
2024-04-09 16:02
writeback.bt
1.66
KB
-rwxr-xr-x
2024-03-07 23:14
xfs_admin
2.12
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_bmap
695
B
-rwxr-xr-x
2024-03-31 19:31
xfs_copy
90.44
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_db
688.56
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_estimate
14.16
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_freeze
800
B
-rwxr-xr-x
2024-03-31 19:31
xfs_fsr
42.18
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_growfs
38.23
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_info
1.26
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_io
203.65
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_logprint
78.27
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_mdrestore
34.23
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_metadump
816
B
-rwxr-xr-x
2024-03-31 19:31
xfs_mkfile
1.02
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_ncheck
685
B
-rwxr-xr-x
2024-03-31 19:31
xfs_quota
90.16
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_repair
643.32
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_rtcp
18.15
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_scrub
106.27
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_scrub_all
7.66
KB
-rwxr-xr-x
2024-03-31 19:31
xfs_spaceman
42.3
KB
-rwxr-xr-x
2024-03-31 19:31
xfsdist-bpfcc
4.61
KB
-rwxr-xr-x
2024-04-16 07:52
xfsdist.bt
972
B
-rwxr-xr-x
2024-03-07 23:14
xfsslower-bpfcc
7.78
KB
-rwxr-xr-x
2024-04-16 07:52
xtables-legacy-multi
92.95
KB
-rwxr-xr-x
2024-04-08 17:59
xtables-monitor
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
xtables-nft-multi
219.16
KB
-rwxr-xr-x
2024-04-08 17:59
zfsdist-bpfcc
5.3
KB
-rwxr-xr-x
2024-04-16 07:52
zfsslower-bpfcc
8.45
KB
-rwxr-xr-x
2024-04-16 07:52
zic
66.39
KB
-rwxr-xr-x
2024-04-30 20:02
zramctl
54.52
KB
-rwxr-xr-x
2024-04-09 16:02
Save
Rename
#!/usr/bin/perl # nagios: -epn # needrestart - Restart daemons after library updates. # # Authors: # Thomas Liske <thomas@fiasko-nw.net> # # Copyright Holder: # 2013 - 2022 (C) Thomas Liske [http://fiasko-nw.net/~thomas/] # # License: # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this package; if not, write to the Free Software # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA # use Cwd qw(realpath); use Getopt::Std; use NeedRestart; use NeedRestart::UI; use NeedRestart::Interp; use NeedRestart::Kernel; use NeedRestart::uCode; use NeedRestart::Utils; use Sort::Naturally; use Locale::TextDomain 'needrestart'; use List::Util qw(sum); use warnings; use strict; $|++; $Getopt::Std::STANDARD_HELP_VERSION++; my $LOGPREF = '[main]'; my $is_systemd = -d q(/run/systemd/system); my $is_runit = -e q(/run/runit.stopit); my $is_tty = (-t *STDERR || -t *STDOUT || -t *STDIN); my $is_vm; my $is_container; if($is_systemd && -x q(/usr/bin/systemd-detect-virt)) { # check if we are inside of a vm my $ret = system(qw(/usr/bin/systemd-detect-virt --vm --quiet)); unless($? == -1 || $? & 127) { $is_vm = ($? >> 8) == 0; } # check if we are inside of a container $ret = system(qw(/usr/bin/systemd-detect-virt --container --quiet)); unless($? == -1 || $? & 127) { $is_container = ($? >> 8) == 0; } } elsif(eval "use ImVirt; 1;") { require ImVirt; ImVirt->import(); my $imvirt = ImVirt::imv_get(ImVirt->IMV_PROB_DEFAULT); $is_vm = $imvirt ne ImVirt->IMV_PHYSICAL; $is_container = $imvirt eq ImVirt->IMV_CONTAINER; } elsif (-r "/proc/1/environ") { # check if we are inside of a container (fallback) local $/; open(HENV, '<', '/proc/1/environ'); $is_container = scalar(grep {/^container=/;} unpack("(Z*)*", <HENV>)); close(HENV) } sub HELP_MESSAGE { print <<USG; Usage: needrestart [-vn] [-c <cfg>] [-r <mode>] [-f <fe>] [-u <ui>] [-bkl] -v be more verbose -q be quiet -m <mode> set detail level e (e)asy mode a (a)dvanced mode -n set default answer to 'no' -c <cfg> config filename -r <mode> set restart mode l (l)ist only i (i)nteractive restart a (a)utomatically restart -b enable batch mode -p enable nagios plugin mode -f <fe> override debconf frontend (DEBIAN_FRONTEND, debconf(7)) -t <seconds> tolerate interpreter process start times within this value -u <ui> use preferred UI package (-u ? shows available packages) By using the following options only the specified checks are performed: -k check for obsolete kernel -l check for obsolete libraries -w check for obsolete CPU microcode --help show this help --version show version information USG } sub VERSION_MESSAGE { print <<LIC; needrestart $NeedRestart::VERSION - Restart daemons after library updates. Authors: Thomas Liske <thomas\@fiasko-nw.net> Copyright Holder: 2013 - 2022 (C) Thomas Liske [http://fiasko-nw.net/~thomas/] Upstream: https://github.com/liske/needrestart This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. LIC #/ } our %nrconf = ( verbosity => 1, hook_d => '/etc/needrestart/hook.d', notify_d => '/etc/needrestart/notify.d', restart_d => '/etc/needrestart/restart.d', sendnotify => 1, restart => 'i', defno => 0, ui_mode => 'a', systemctl_combine => 0, blacklist => [], blacklist_interp => [], blacklist_rc => [], blacklist_mappings => [], override_rc => {}, override_cont => {}, skip_mapfiles => -1, interpscan => 1, kernelhints => 1, kernelfilter => qr(.), ucodehints => 1, q(nagios-status) => { services => 1, kernel => 2, ucode => 2, sessions => 2, containers => 1, }, has_pam_systemd => 1, tolerance => 2, ); # backup ARGV (required for Debconf) my @argv = @ARGV; our $opt_c = '/etc/needrestart/needrestart.conf'; our $opt_v; our $opt_r; our $opt_n; our $opt_m; our $opt_b; our $opt_f; our $opt_k; our $opt_l; our $opt_p; our $opt_q; our $opt_t; our $opt_u; our $opt_w; unless(getopts('c:vr:nm:bf:klpqt:u:w')) { HELP_MESSAGE; exit 1; } # disable exiting and STDOUT in Getopt::Std for further use of getopts $Getopt::Std::STANDARD_HELP_VERSION = undef; # restore ARGV @ARGV = @argv; die "ERROR: Could not read config file '$opt_c'!\n" unless(-r $opt_c || $opt_b); # override debconf frontend $ENV{DEBIAN_FRONTEND} = $opt_f if($opt_f); my $debian_noninteractive = (exists($ENV{DEBIAN_FRONTEND}) && $ENV{DEBIAN_FRONTEND} eq 'noninteractive'); # be quiet if($opt_q) { $nrconf{verbosity} = 0; } # be verbose elsif($opt_v) { $nrconf{verbosity} = 2; } # slurp config file print STDERR "$LOGPREF eval $opt_c\n" if($nrconf{verbosity} > 1); eval do { local $/; open my $fh, $opt_c or die "ERROR: $!\n"; my $cfg = <$fh>; close($fh); $cfg; }; die "Error parsing $opt_c: $@" if($@); # fallback to stdio on verbose mode $nrconf{ui} = qq(NeedRestart::UI::stdio) if($nrconf{verbosity} > 1); die "Hook directory '$nrconf{hook_d}' is invalid!\n" unless(-d $nrconf{hook_d} || $opt_b); $opt_r = $ENV{NEEDRESTART_MODE} if(!defined($opt_r) && exists($ENV{NEEDRESTART_MODE})); $opt_r = $nrconf{restart} unless(defined($opt_r)); die "ERROR: Unknown restart option '$opt_r'!\n" unless($opt_r =~ /^(l|i|a)$/); $is_tty = 0 if($opt_r eq 'i' && $debian_noninteractive); $opt_r = 'l' if(!$is_tty && $opt_r eq 'i'); $opt_m = $nrconf{ui_mode} unless(defined($opt_m)); die "ERROR: Unknown UI mode '$opt_m'!\n" unless($opt_m =~ /^(e|a|u)$/); $opt_r = 'l' if($opt_m eq 'e'); $opt_t = $nrconf{tolerance} unless(defined($opt_t)); $nrconf{defno}++ if($opt_n); $opt_b++ if($opt_p); # print version in verbose mode print STDERR "$LOGPREF needrestart v$NeedRestart::VERSION\n" if($nrconf{verbosity} > 1); # running mode (user or root) my $uid = $<; if($uid) { if($opt_p) { print "UNKN - This plugin needs to be run as root!\n"; exit 3; } print STDERR "$LOGPREF running in user mode\n" if($nrconf{verbosity} > 1); } else { print STDERR "$LOGPREF running in root mode\n" if($nrconf{verbosity} > 1); } # get current runlevel, fallback to '2' my $runlevel = `who -r` || ''; chomp($runlevel); $runlevel = 2 unless($runlevel =~ s/^.+run-level (\S)\s.+$/$1/); # get UI if(defined($opt_u)) { if ($opt_u eq '?') { print STDERR join("\n\t", __(q(Available UI packages:)), needrestart_ui_list($nrconf{verbosity}, $nrconf{ui}))."\n"; exit 0; } else { $nrconf{ui} = $opt_u; } } elsif (exists($ENV{NEEDRESTART_UI})) { $nrconf{ui} = $ENV{NEEDRESTART_UI}; } # We only force automatic restart if there isn't a user-defined UI yet. $opt_r = 'a' if($opt_m eq 'u' && !defined($nrconf{ui})); if ($opt_m eq 'u') { $nrconf{ui} = 'NeedRestart::UI::Ubuntu' unless defined($nrconf{ui}); } elsif (!$is_tty) { $nrconf{ui} = 'NeedRestart::UI::Stdio'; } my $ui = ($opt_b ? NeedRestart::UI->new(0) : needrestart_ui($nrconf{verbosity}, $nrconf{ui})); die "Error: no UI class available!\n" unless(defined($ui)); # Disable UI interactiveness $ui->interactive(0) if ($ui->can("interactive") && $debian_noninteractive); # enable/disable checks unless(defined($opt_k) || defined($opt_l) || defined($opt_w)) { $opt_k = ($uid ? undef : 1); $opt_l = 1; $opt_w = ($uid ? undef : $nrconf{ucodehints}); } sub parse_lsbinit($) { my $rc = '/etc/init.d/'.shift; # ignore upstart-job magic if(-l $rc && readlink($rc) eq '/lib/init/upstart-job') { print STDERR "$LOGPREF ignoring $rc since it is a converted upstart job\n" if($nrconf{verbosity} > 1); return (); } open(HLSB, '<', $rc) || die "Can't open $rc: $!\n"; my %lsb; my $found_lsb; my %chkconfig; my $found_chkconfig; while(my $line = <HLSB>) { chomp($line); unless($found_chkconfig) { if($line =~ /^# chkconfig: (\d+) /) { $chkconfig{runlevels} = $1; $found_chkconfig++ } } elsif($line =~ /^# (\S+): (.+)$/) { $chkconfig{lc($1)} = $2; } unless($found_lsb) { $found_lsb++ if($line =~ /^### BEGIN INIT INFO/); next; } elsif($line =~ /^### END INIT INFO/) { last; } $lsb{lc($1)} = $2 if($line =~ /^# ([^:]+):\s+(.+)$/); } # convert chkconfig tags to LSB tags if($found_chkconfig && !$found_lsb) { print STDERR "$LOGPREF $rc is missing LSB tags, found chkconfig tags instead\n" if($nrconf{verbosity} > 1); $found_lsb++; $lsb{pidfiles} = [$chkconfig{pidfile}]; $lsb{q(default-start)} = $chkconfig{runlevels}; } unless($found_lsb) { print STDERR "WARNING: $rc has no LSB tags!\n" unless(%lsb); return (); } # pid file heuristic unless(exists($lsb{pidfiles})) { my $found = 0; my %pidfiles; while(my $line = <HLSB>) { if($line =~ m@(\S*/run/[^/]+.pid)@ && -r $1) { $pidfiles{$1}++; $found++; } } $lsb{pidfiles} = [keys %pidfiles] if($found); } close(HLSB); return %lsb; } print STDERR "$LOGPREF systemd detected\n" if($nrconf{verbosity} > 1 && $is_systemd); print STDERR "$LOGPREF vm detected\n" if($nrconf{verbosity} > 1 && $is_vm); print STDERR "$LOGPREF container detected\n" if($nrconf{verbosity} > 1 && $is_container); sub systemd_refuse_restart { my $svc = shift; my $systemctl = nr_fork_pipe($nrconf{verbosity} > 1, qq(systemctl), qq(show), qq(--property=RefuseManualStop), $svc); my $ret = <$systemctl>; close($systemctl); if($ret && $ret =~ /^RefuseManualStop=yes/) { print STDERR "$LOGPREF systemd refuses restarts of $svc\n" if($nrconf{verbosity} > 1); return 1; } return 0; } my @systemd_restart; sub restart_cmd($) { my $rc = shift; my $restcmd = "$nrconf{restart_d}/$rc"; if(-x $restcmd) { print STDERR "$LOGPREF using restart.d file $rc\n" if($nrconf{verbosity} > 1); ($restcmd); } elsif($rc =~ /.+\.service$/) { if($nrconf{systemctl_combine}) { push(@systemd_restart, $rc); (); } else { (qw(systemctl restart), $rc); } } else { if($is_systemd) { if($nrconf{systemctl_combine}) { push(@systemd_restart, qq($rc.service)); (); } else { (qw(systemctl restart), qq($rc.service)); } } elsif($is_runit && -d qq(/etc/sv/$rc)) { if(-e qq(/etc/service/$rc)) { (qw(sv restart), $rc); } else { (q(service), $rc, q(restart)); } } else { (q(invoke-rc.d), $rc, q(restart)); } } } # map UID to username (cached) my %uidcache; sub uid2name($) { my $uid = shift; return $uidcache{$uid} if(exists($uidcache{$uid})); return $uidcache{$uid} = getpwuid($uid) || $uid; } my %nagios = ( # kernel kstr => q(unknown), kret => 3, kperf => q(U), # uCode mstr => q(unknown), mret => 3, mperf => q(U), # services sstr => q(unknown), sret => 3, sperf => q(U), # sessions ustr => q(unknown), uret => 3, uperf => q(U), ); print "NEEDRESTART-VER: $NeedRestart::VERSION\n" if($opt_b && !$opt_p); my %restart; my %sessions; my @guests; my @easy_hints; if(defined($opt_l)) { my @ign_pids=($$, getppid()); # inspect only pids my $ptable = nr_ptable(); # find session parent sub findppid($@) { my $uid = shift; my ($pid, @pids) = @_; if($ptable->{$pid}->{ppid} == 1) { return $pid if($ptable->{$pid}->{uid} == $uid); return undef; } foreach my $pid (@pids) { my $ppid = &findppid($uid, $pid); return $ppid if($ppid); } return $pid; } $ui->progress_prep(scalar keys %$ptable, __ 'Scanning processes...'); my %stage2; for my $pid (sort {$a <=> $b} keys %$ptable) { $ui->progress_step; # user-mode: skip foreign processes next if($uid && $ptable->{$pid}->{uid} != $uid); # skip myself next if(grep {$pid == $_} @ign_pids); my $restart = 0; my $exe = nr_readlink($pid); # ignore kernel threads next unless(defined($exe)); # orphaned binary $restart++ if (defined($exe) && $exe =~ s/ \(deleted\)$//); # Linux $restart++ if (defined($exe) && $exe =~ s/^\(deleted\)//); # Linux VServer print STDERR "$LOGPREF #$pid uses obsolete binary $exe\n" if($restart && $nrconf{verbosity} > 1); # ignore blacklisted binaries next if(grep { $exe =~ /$_/; } @{$nrconf{blacklist}}); # read file mappings (Linux 2.0+) unless($restart) { if(open(HMAP, '<', "/proc/$pid/maps")) { while(<HMAP>) { chomp; my ($maddr, $mperm, $moffset, $mdev, $minode, $path) = split(/\s+/, $_, 6); # skip special handles and non-executable mappings next unless(defined($path) && $minode != 0 && $path ne '' && $mperm =~ /x/); # skip special device paths next if(scalar grep { $path =~ /$_/; } @{$nrconf{blacklist_mappings}}); # removed executable mapped files if($path =~ s/ \(deleted\)$// || # Linux $path =~ s/^\(deleted\)//) { # Linux VServer print STDERR "$LOGPREF #$pid uses deleted $path\n" if($nrconf{verbosity} > 1); $restart++; last; } # check for outdated lib mappings unless($nrconf{skip_mapfiles} == 1) { $maddr =~ s/^0+([^-])/$1/; $maddr =~ s/-0+(.)/-$1/; my @paths = ("/proc/$pid/map_files/$maddr", "/proc/$pid/root/$path"); my ($testp) = grep { -e $_; } @paths; unless($testp) { unless($nrconf{skip_mapfiles} == -1) { print STDERR "$LOGPREF #$pid uses non-existing $path\n" if($nrconf{verbosity} > 1); $restart++; last; } next; } # get on-disk info my ($sdev, $sinode) = stat($testp); my @sdevs = ( # glibc gnu_dev_* definition from sysmacros.h sprintf("%02x:%02x", (($sdev >> 8) & 0xfff) | (($sdev >> 32) & ~0xfff), (($sdev & 0xff) | (($sdev >> 12) & ~0xff))), # Traditional definition of major(3) and minor(3) sprintf("%02x:%02x", $sdev >> 8, $sdev & 0xff), # kFreeBSD: /proc/<pid>/maps does not contain device IDs qq(00:00) ); # Don't compare device numbers on anon filesystems # w/o a backing device (like OpenVZ's simfs). my $major = (($sdev >> 8) & 0xfff) | (($sdev >> 32) & ~0xfff); $mdev = "00:00" if ($major == 0 || $major == 144 || $major == 145 || $major == 146); # compare maps content vs. on-disk unless($minode eq $sinode && ((grep {$mdev eq $_} @sdevs) || # BTRFS breaks device ID mapping completely... # ignoring unnamed device IDs for now $mdev =~ /^00:/)) { print STDERR "$LOGPREF #$pid uses obsolete $path\n" if($nrconf{verbosity} > 1); $restart++; last; } } } close(HMAP); } else { print STDERR "$LOGPREF #$pid could not open maps: $!\n" if($nrconf{verbosity} > 1); } } unless($restart || !$nrconf{interpscan}) { $restart++ if(needrestart_interp_check($nrconf{verbosity} > 1, $pid, $exe, $nrconf{blacklist_interp}, $opt_t)); } # handle containers (LXC, docker, etc.) next if($restart && needrestart_cont_check($nrconf{verbosity} > 1, $pid, $exe, $opt_t)); # restart needed? next unless($restart); # handle user sessions if($ptable->{$pid}->{ttydev} ne '' && (!$is_systemd || !$nrconf{has_pam_systemd})) { my $ttydev = realpath( $ptable->{$pid}->{ttydev} ); print STDERR "$LOGPREF #$pid part of user session: uid=$ptable->{$pid}->{uid} sess=$ttydev\n" if($nrconf{verbosity} > 1); push(@{ $sessions{ $ptable->{$pid}->{uid} }->{ $ttydev }->{ $ptable->{$pid}->{fname} } }, $pid); # add session processes to stage2 only in user mode $stage2{$pid} = $exe if($uid); next; } # find parent process my $ppid = $ptable->{$pid}->{ppid}; if($ppid != $pid && $ppid > 1 && !$uid) { print STDERR "$LOGPREF #$pid is a child of #$ppid\n" if($nrconf{verbosity} > 1); if($uid && $ptable->{$ppid}->{uid} != $uid) { print STDERR "$LOGPREF #$ppid is a foreign process\n" if($nrconf{verbosity} > 1); $stage2{$pid} = $exe; } else { unless(exists($stage2{$ppid})) { my $pexe = nr_readlink($ppid); # ignore kernel threads next unless(defined($pexe)); $stage2{$ppid} = $pexe; } } } else { print STDERR "$LOGPREF #$pid is not a child\n" if($nrconf{verbosity} > 1 && !$uid); $stage2{$pid} = $exe; } } $ui->progress_fin; if(scalar keys %stage2 && !$uid) { $ui->progress_prep(scalar keys %stage2, __ 'Scanning candidates...'); PIDLOOP: foreach my $pid (sort {$a <=> $b} keys %stage2) { $ui->progress_step; # skip myself next if(grep {$pid == $_} @ign_pids); my $exe = nr_readlink($pid); $exe =~ s/ \(deleted\)$//; # Linux $exe =~ s/^\(deleted\)//; # Linux VServer print STDERR "$LOGPREF #$pid exe => $exe\n" if($nrconf{verbosity} > 1); # try to find interpreter source file ($exe) = (needrestart_interp_source($nrconf{verbosity} > 1, $pid, $exe), $exe); # ignore blacklisted binaries next if(grep { $exe =~ /$_/; } @{$nrconf{blacklist}}); if($is_systemd) { # systemd manager if($pid == 1 && $exe =~ m@^(/usr)?/lib/systemd/systemd@) { print STDERR "$LOGPREF #$pid is systemd manager\n" if($nrconf{verbosity} > 1); $restart{q(systemd-manager)}++; next; } # get unit name from /proc/<pid>/cgroup if(open(HCGROUP, qq(/proc/$pid/cgroup))) { my ($rc) = map { chomp; my ($id, $type, $value) = split(/:/); if($id != 0 && $type ne q(name=systemd)) { (); } else { if($value =~ m@/user-(\d+)\.slice/session-(\d+)\.scope@) { print STDERR "$LOGPREF #$pid part of user session: uid=$1 sess=$2\n" if($nrconf{verbosity} > 1); push(@{ $sessions{$1}->{"session #$2"}->{ $ptable->{$pid}->{fname} } }, $pid); next; } if($value =~ m@/user\@(\d+)\.service@) { print STDERR "$LOGPREF #$pid part of user manager service: uid=$1\n" if($nrconf{verbosity} > 1); push(@{ $sessions{$1}->{'user manager service'}->{ $ptable->{$pid}->{fname} } }, $pid); next; } if($value =~ m@/machine.slice/machine.qemu(.*).scope@) { for my $cmdlineidx (0 .. $#{$ptable->{$pid}->{cmdline}} ) { if ( ${$ptable->{$pid}->{cmdline}}[$cmdlineidx] eq "-name") { foreach ( split(/,/, ${$ptable->{$pid}->{cmdline}}[$cmdlineidx+1]) ) { if ( index($_, "guest=") == 0 ) { my @namearg = split(/=/, $_, 2); if ($#{namearg} == 1) { print STDERR "$LOGPREF #$pid detected as VM guest '$namearg[1]' in group '$value'\n" if($nrconf{verbosity} > 1); push(@guests, __x("'{name}' with pid {pid}", name => $namearg[1], pid=>$pid) ); } next PIDLOOP; } } } } print STDERR "$LOGPREF #$pid detected as VM guest with unknown name in group '$value'\n" if($nrconf{verbosity} > 1); push(@guests, __x("'Unkown VM' with pid {pid}", pid=>$pid) ); next; } elsif($value =~ m@/([^/]+\.service)$@) { ($1); } else { print STDERR "$LOGPREF #$pid unexpected cgroup '$value'\n" if($nrconf{verbosity} > 1); (); } } } <HCGROUP>; close(HCGROUP); if($rc) { print STDERR "$LOGPREF #$pid is $rc\n" if($nrconf{verbosity} > 1); $restart{$rc}++; next; } } # did not get the unit name, yet - try systemctl status print STDERR "$LOGPREF /proc/$pid/cgroup: $!\n" if($nrconf{verbosity} > 1 && $!); print STDERR "$LOGPREF trying systemctl status\n" if($nrconf{verbosity} > 1); my $systemctl = nr_fork_pipe($nrconf{verbosity} > 1, qq(systemctl), qq(-n), qq(0), qq(--full), qq(status), $pid); my $ret = <$systemctl>; close($systemctl); if(defined($ret) && $ret =~ /([^\s]+\.service)( |$)/) { my $s = $1; print STDERR "$LOGPREF #$pid is $s\n" if($nrconf{verbosity} > 1); $restart{$s}++; $s =~ s/\.service$//; delete($restart{$s}); next; } } else { # sysv init if($pid == 1 && $exe =~ m@^/sbin/init@) { print STDERR "$LOGPREF #$pid is sysv init\n" if($nrconf{verbosity} > 1); $restart{q(sysv-init)}++; next; } } my $pkg; foreach my $hook (nsort <$nrconf{hook_d}/*>) { print STDERR "$LOGPREF #$pid running $hook\n" if($nrconf{verbosity} > 1); my $found = 0; my $prun = nr_fork_pipe($nrconf{verbosity} > 1, $hook, ($nrconf{verbosity} > 1 ? qw(-v) : ()), $exe); my @nopids; while(<$prun>) { chomp; my @v = split(/\|/); if($v[0] eq 'PACKAGE' && $v[1]) { $pkg = $v[1]; print STDERR "$LOGPREF #$pid package: $v[1]\n" if($nrconf{verbosity} > 1); next; } if($v[0] eq 'RC') { my %lsb = parse_lsbinit($v[1]); unless(%lsb && exists($lsb{'default-start'})) { # If the script has no LSB tags we consider to call it later - they # are broken anyway. print STDERR "$LOGPREF no LSB headers found at $v[1]\n" if($nrconf{verbosity} > 1); push(@nopids, $v[1]); } # In the run-levels S and 1 no daemons are being started (normally). # We don't call any rc.d script not started in the current run-level. elsif($lsb{'default-start'} =~ /$runlevel/) { # If a pidfile has been found, try to look for the daemon and ignore # any forked/detached childs (just a heuristic due Debian Bug#721810). if(exists($lsb{pidfiles})) { foreach my $pidfile (@{ $lsb{pidfiles} }) { open(HPID, '<', "$pidfile") || next; my $p = <HPID>; close(HPID); if(int($p) == $pid) { print STDERR "$LOGPREF #$pid has been started by $v[1] - triggering\n" if($nrconf{verbosity} > 1); $restart{$v[1]}++; $found++; last; } } } else { print STDERR "$LOGPREF no pidfile reference found at $v[1]\n" if($nrconf{verbosity} > 1); push(@nopids, $v[1]); } } else { print STDERR "$LOGPREF #$pid rc.d script $v[1] should not start in the current run-level($runlevel)\n" if($nrconf{verbosity} > 1); } } } # No perfect hit - call any rc scripts instead. print STDERR "$LOGPREF #$pid running $hook no perfect hit found $found pids $#nopids\n" if($nrconf{verbosity} > 1); if(!$found && $#nopids > -1) { foreach my $rc (@nopids) { if($is_systemd && exists($restart{"$rc.service"})) { print STDERR "$LOGPREF #$pid rc.d script $rc seems to be superseded by $rc.service\n" if($nrconf{verbosity} > 1); } else { $restart{$rc}++; } } $found++; } last if($found); } } $ui->progress_fin; } # List user's processes in user-mode if($uid && scalar %stage2) { my %fnames; foreach my $pid (keys %stage2) { push(@{$fnames{ $ptable->{$pid}->{fname} }}, $pid); } if($opt_b) { print map { "NEEDRESTART-PID: $_=".join(',', @{ $fnames{$_} })."\n"; } nsort keys %fnames; } else { $ui->notice(__ 'Your outdated processes:'); $ui->notice(join(', ',map { $_.'['.join(', ', @{ $fnames{$_} }).']'; } nsort keys %fnames)); } } } # Apply rc/service blacklist foreach my $rc (keys %restart) { next unless(scalar grep { $rc =~ /$_/; } @{$nrconf{blacklist_rc}}); print STDERR "$LOGPREF $rc is blacklisted -> ignored\n" if($nrconf{verbosity} > 1); delete($restart{$rc}); } # Skip kernel stuff within container if($is_container || needrestart_cont_check($nrconf{verbosity} > 1, 1, nr_readlink(1), 1)) { print STDERR "$LOGPREF inside container, skipping kernel checks\n" if($nrconf{verbosity} > 1); $opt_k = undef; } # Skip uCode stuff within container or vm if($is_container || $is_vm || needrestart_cont_check($nrconf{verbosity} > 1, 1, nr_readlink(1), 1)) { print STDERR "$LOGPREF inside container or vm, skipping microcode checks\n" if($nrconf{verbosity} > 1); $opt_w = undef; } my ($ucode_result, %ucode_vars) = (NRM_UNKNOWN); if(defined($opt_w)) { ($ucode_result, %ucode_vars) = ($nrconf{ucodehints} || $opt_w ? nr_ucode_check($nrconf{verbosity} > 1, $ui) : ()); } if(defined($opt_k)) { my ($kresult, %kvars) = ($nrconf{kernelhints} || $opt_b ? nr_kernel_check($nrconf{verbosity} > 1, $nrconf{kernelfilter}, $ui) : ()); if(defined($kresult)) { if($opt_b) { unless($opt_p) { print "NEEDRESTART-KCUR: $kvars{KVERSION}\n"; print "NEEDRESTART-KEXP: $kvars{EVERSION}\n" if(defined($kvars{EVERSION})); print "NEEDRESTART-KSTA: $kresult\n"; } else { $nagios{kstr} = $kvars{KVERSION}; if($kresult == NRK_VERUPGRADE) { $nagios{kstr} .= "!=$kvars{EVERSION}"; $nagios{kret} = $nrconf{q(nagios-status)}->{kernel}; $nagios{kperf} = 2; } elsif($kresult == NRK_ABIUPGRADE) { $nagios{kret} = $nrconf{q(nagios-status)}->{kernel}; $nagios{kperf} = 1; } elsif($kresult == NRK_NOUPGRADE) { $nagios{kret} = 0; $nagios{kperf} = 0; } if($nagios{kret} == 1) { $nagios{kstr} .= " (!)"; } elsif($nagios{kret} == 2) { $nagios{kstr} .= " (!!)"; } } } else { if($kresult == NRK_NOUPGRADE) { unless($opt_m eq 'e') { $ui->vspace(); $ui->notice(($kvars{ABIDETECT} ? __('Running kernel seems to be up-to-date.') : __('Running kernel seems to be up-to-date (ABI upgrades are not detected).'))) } } elsif($kresult == NRK_ABIUPGRADE) { push(@easy_hints, __ 'an outdated kernel image') if($opt_m eq 'e'); if($nrconf{kernelhints} < 0) { $ui->vspace(); $ui->notice(__x( 'The currently running kernel version is {kversion} and there is an ABI compatible upgrade pending.', kversion => $kvars{KVERSION}, )); } else { $ui->announce_abi(%kvars); } } elsif($kresult == NRK_VERUPGRADE) { push(@easy_hints, __ 'an outdated kernel image') if($opt_m eq 'e'); if($nrconf{kernelhints} < 0) { $ui->vspace(); $ui->notice(__x( 'The currently running kernel version is {kversion} which is not the expected kernel version {eversion}.', kversion => $kvars{KVERSION}, eversion => $kvars{EVERSION}, )); } else { $ui->announce_ver(%kvars); } } else { $ui->vspace(); $ui->notice(__ 'Failed to retrieve available kernel versions.'); } } } } if($opt_w) { if($opt_b) { unless($opt_p) { print "NEEDRESTART-UCSTA: $ucode_result\n"; if($ucode_result != NRM_UNKNOWN) { print "NEEDRESTART-UCCUR: $ucode_vars{CURRENT}\n"; print "NEEDRESTART-UCEXP: $ucode_vars{AVAIL}\n"; } } else { if($ucode_result == NRM_OBSOLETE) { $nagios{mstr} = "OBSOLETE"; $nagios{mret} = $nrconf{q(nagios-status)}->{ucode}; $nagios{mperf} = 1; } elsif($ucode_result == NRM_CURRENT) { $nagios{mstr} = "CURRENT"; $nagios{mret} = 0; $nagios{mperf} = 0; } if($nagios{mret} == 1) { $nagios{mstr} .= " (!)"; } elsif($nagios{mret} == 2) { $nagios{mstr} .= " (!!)"; } } } else { if($ucode_result == NRM_CURRENT) { unless($opt_m eq 'e') { $ui->vspace(); $ui->notice(__('The processor microcode seems to be up-to-date.')); } } elsif($ucode_result == NRM_OBSOLETE) { push(@easy_hints, __ 'outdated processor microcode') if($opt_m eq 'e'); if($nrconf{ucodehints}) { $ui->announce_ucode(%ucode_vars); } } else { $ui->vspace(); $ui->notice(__ 'Failed to check for processor microcode upgrades.'); } } } if(defined($opt_l) && !$uid) { ## SERVICES $ui->vspace(); unless(scalar %restart) { $ui->notice(__ 'No services need to be restarted.') unless($opt_b || $opt_m eq 'e'); if($opt_p) { $nagios{sstr} = q(none); $nagios{sret} = 0; $nagios{sperf} = 0; } } else { if($opt_m eq 'e' && $opt_r ne 'i') { push(@easy_hints, __ 'outdated binaries'); } elsif($opt_b || $opt_r ne 'i') { my @skipped_services; my @refused_services; $ui->notice(__ 'Services to be restarted:') if($opt_r eq 'l'); $ui->notice(__ 'Restarting services...') if($opt_r eq 'a'); if($opt_p) { $nagios{sstr} = (scalar keys %restart); $nagios{sret} = $nrconf{q(nagios-status)}->{services}; $nagios{sperf} = (scalar keys %restart); if($nagios{sret} == 1) { $nagios{sstr} .= " (!)"; } elsif($nagios{sret} == 2) { $nagios{sstr} .= " (!!)"; } } foreach my $rc (sort { lc($a) cmp lc($b) } keys %restart) { # always combine restarts in one systemctl command local $nrconf{systemctl_combine} = 1 unless($opt_r eq 'l'); if($opt_b) { print "NEEDRESTART-SVC: $rc\n" unless($opt_p); next; } # record service which can not be restarted if($is_systemd && systemd_refuse_restart($rc)) { push(@refused_services, $rc); next; } # don't restart greylisted services... my $restart = !$nrconf{defno}; foreach my $re (keys %{$nrconf{override_rc}}) { next unless($rc =~ /$re/); $restart = $nrconf{override_rc}->{$re}; last; } # ...but complain about them unless($restart) { push(@skipped_services, $rc); next; } my @cmd = restart_cmd($rc); next unless($#cmd > -1); $ui->command(join(' ', '', @cmd)); $ui->runcmd(sub { system(@cmd) if($opt_r eq 'a'); }); } unless($#systemd_restart == -1) { my @cmd = (qq(systemctl), qq(restart), @systemd_restart); $ui->command(join(' ', '', @cmd)); $ui->runcmd(sub { system(@cmd) if($opt_r eq 'a'); }); } @systemd_restart = (); if($#skipped_services > -1) { $ui->vspace(); $ui->notice(__ 'Service restarts being deferred:'); foreach my $rc (sort @skipped_services) { my @cmd = restart_cmd($rc); $ui->command(join(' ', '', @cmd)) if($#cmd > -1); } unless($#systemd_restart == -1) { my @cmd = (qq(systemctl), qq(restart), @systemd_restart); $ui->command(join(' ', '', @cmd)); } } # report services restarts refused by systemd if($#refused_services > -1) { $ui->vspace(); $ui->notice(__ 'Service restarts being refused by systemd:'); foreach my $rc (sort @refused_services) { $ui->command(qq( $rc)); } } } else { my $o = 0; my @skipped_services = keys %restart; # filter service units which are refused to be restarted my @refused_services; my %rs = map { my $rc = $_; if($is_systemd) { if(systemd_refuse_restart($rc)) { push(@refused_services, $rc); @skipped_services = grep { $_ ne $rc; } @skipped_services; (); } else { ($rc => 1); } } else { ($rc => 1); } } keys %restart; $ui->notice(__ 'Restarting services...'); $ui->query_pkgs(__('Services to be restarted:'), $nrconf{defno}, \%rs, $nrconf{override_rc}, sub { # always combine restarts in one systemctl command local $nrconf{systemctl_combine} = 1; my $rc = shift; @skipped_services = grep { $_ ne $rc; } @skipped_services; my @cmd = restart_cmd($rc); return unless($#cmd > -1); $ui->command(join(' ', '', @cmd)); system(@cmd); }); if($#systemd_restart > -1) { my @cmd = (qw(systemctl restart), @systemd_restart); $ui->command(join(' ', '', @cmd)); $ui->runcmd(sub { system(@cmd); }); } @systemd_restart = (); if($#skipped_services > -1) { $ui->notice(__ 'Service restarts being deferred:'); foreach my $rc (sort @skipped_services) { my @cmd = restart_cmd($rc); $ui->command(join(' ', '', @cmd)) if($#cmd > -1); } unless($#systemd_restart == -1) { my @cmd = (qq(systemctl), qq(restart), @systemd_restart); $ui->command(join(' ', '', @cmd)); } } # report services restarts refused by systemd if($#refused_services > -1) { $ui->notice(__ 'Service restarts being refused by systemd:'); foreach my $rc (sort @refused_services) { $ui->command(qq( $rc)); } } } } ## CONTAINERS $ui->vspace(); @systemd_restart = (); my %conts = needrestart_cont_get($nrconf{verbosity} > 1); unless(scalar %conts) { $ui->notice(__ 'No containers need to be restarted.') unless($opt_b || $opt_m eq 'e'); if($opt_p) { $nagios{cstr} = q(none); $nagios{cret} = 0; $nagios{cperf} = 0; } } else { if($opt_m eq 'e' && $opt_r ne 'i') { push(@easy_hints, __ 'outdated containers'); } elsif($opt_b || $opt_r ne 'i') { my @skipped_containers; $ui->notice(__ 'Containers to be restarted:') if($opt_r eq 'l'); $ui->notice(__ 'Restarting containers...') if($opt_r eq 'a'); if($opt_p) { $nagios{cstr} = (scalar keys %conts); $nagios{cret} = $nrconf{q(nagios-status)}->{containers}; $nagios{cperf} = (scalar keys %conts); if($nagios{cret} == 1) { $nagios{cstr} .= " (!)"; } elsif($nagios{cret} == 2) { $nagios{cstr} .= " (!!)"; } } foreach my $cont (sort { lc($a) cmp lc($b) } keys %conts) { if($opt_b) { print "NEEDRESTART-CONT: $cont\n" unless($opt_p); next; } # don't restart greylisted containers... my $restart = !$nrconf{defno}; foreach my $re (keys %{$nrconf{override_cont}}) { next unless($cont =~ /$re/); $restart = $nrconf{override_cont}->{$re}; last; } # ...but complain about them unless($restart) { push(@skipped_containers, $cont); next; } $ui->command(join(' ', '', @{ $conts{$cont} })); $ui->runcmd(sub { system(@{ $conts{$cont} }) if($opt_r eq 'a'); }); } if($#skipped_containers > -1) { $ui->notice(__ 'Container restarts being deferred:'); foreach my $cont (sort @skipped_containers) { $ui->command(join(' ', '', @{ $conts{$cont} })); } } } else { my $o = 0; $ui->notice(__ 'Restarting containers...'); $ui->query_conts(__('Containers to be restarted:'), $nrconf{defno}, \%conts, $nrconf{override_cont}, sub { my $cont = shift; $ui->command(join(' ', '', @{ $conts{$cont} })); system(@{ $conts{$cont} }); }); } } ## SESSIONS $ui->vspace(); # list and notify user sessions unless(scalar keys %sessions) { $ui->notice(__ 'No user sessions are running outdated binaries.') unless($opt_b || $opt_m eq 'e'); if($opt_p) { $nagios{ustr} = 'none'; $nagios{uret} = 0; $nagios{uperf} = 0; } } else { if($opt_m eq 'e') { push(@easy_hints, __ 'outdated sessions'); } else { $ui->notice(__ 'User sessions running outdated binaries:'); } if($opt_p) { my $count = sum map { scalar keys %{ $sessions{$_} } } keys %sessions; $nagios{ustr} = $count; $nagios{uret} = $nrconf{q(nagios-status)}->{sessions}; $nagios{uperf} = $count; if($nagios{uret} == 1) { $nagios{ustr} .= " (!)"; } elsif($nagios{uret} == 2) { $nagios{ustr} .= " (!!)"; } } unless($opt_p || $opt_b) { foreach my $uid (sort { ncmp(uid2name($a), uid2name($b)); } keys %sessions) { foreach my $sess (sort keys %{ $sessions{$uid} }) { my $fnames = join(', ',map { $_.'['.join(',', @{ $sessions{$uid}->{$sess}->{$_} }).']'; } nsort keys %{ $sessions{$uid}->{$sess} }); $ui->notice(' '.uid2name($uid)." @ $sess: $fnames") unless($opt_m eq 'e'); if($nrconf{sendnotify}) { local %ENV; $ENV{NR_UID} = $uid; $ENV{NR_USERNAME} = uid2name($uid); $ENV{NR_SESSION} = $sess; $ENV{NR_SESSPPID} = findppid($uid, sort map { @$_; } values %{ $sessions{$uid}->{$sess} }); foreach my $bin (nsort <$nrconf{notify_d}/*>) { next unless(-x $bin); next if($bin =~ /(~|\.dpkg-[^.]+)$/); print STDERR "$LOGPREF run $bin\n" if($nrconf{verbosity} > 1); my $pipe = nr_fork_pipew($nrconf{verbosity} > 1, $bin); print $pipe "$fnames\n"; last if(close($pipe)); } } } } } } ## GUESTS $ui->vspace(); if (! @guests) { $ui->notice(__ 'No VM guests are running outdated hypervisor (qemu) binaries on this host.') unless($opt_b || $opt_m eq 'e'); } else { if($opt_m eq 'e') { push(@easy_hints, __ 'outdated VM guests'); } else { unless($opt_p || $opt_b) { $ui->notice(__ 'VM guests are running outdated hypervisor (qemu) binaries on this host:'); foreach ( @guests ) { $ui->notice(" $_"); } } } } } # easy mode: print hint on outdated stuff if(scalar @easy_hints) { my $t = pop(@easy_hints); my $h = join(', ', @easy_hints); $ui->announce_ehint(EHINT => ($h ? join(' ', $h, __ 'and', '') : '') . $t); } my @sessions_list; if(scalar %sessions) { # build a sorted list of user @ session strings # # used in the nagios and batch outputs below @sessions_list = map { my $uid = $_; my $user = uid2name($uid); my @ret; foreach my $sess (sort keys %{ $sessions{$uid} }) { push(@ret, "$user \@ $sess"); } @ret; } sort { ncmp(uid2name($a), uid2name($b)); } keys %sessions } # nagios plugin output if($opt_p) { my %states = ( 0 => q(OK), 1 => q(WARN), 2 => q(CRIT), 3 => q(UNKN), ); my ($ret) = reverse sort (($opt_k ? $nagios{kret} : ()), ($opt_w ? $nagios{mret} : ()), ($opt_l ? ($nagios{sret}, $nagios{cret}, $nagios{uret}) : ())); print "$states{$ret} - ", join(', ', ($opt_k ? "Kernel: $nagios{kstr}" : ()), ($opt_w ? "Microcode: $nagios{mstr}" : ()), ($opt_l ? "Services: $nagios{sstr}" : ()), ($opt_l ? "Containers: $nagios{cstr}" : ()), ($opt_l ? "Sessions: $nagios{ustr}" : ()), ), '|', join(' ', ( ($opt_k && $nagios{kret} != 3) ? "Kernel=$nagios{kperf};0;;0;2" : ()), ( ($opt_w && $nagios{mret} != 3) ? "Microcode=$nagios{mperf};0;;0;1" : ()), ( ($opt_l && $nagios{sret} != 3) ? "Services=$nagios{sperf};;0;0" : ()), ( ($opt_l && $nagios{cret} != 3) ? "Containers=$nagios{cperf};;0;0" : ()), ( ($opt_l && $nagios{uret} != 3) ? "Sessions=$nagios{uperf};0;;0" : ()), ), "\n"; if(scalar %restart) { print "Services:", join("\n- ", '', sort keys %restart), "\n"; } my %conts = needrestart_cont_get($nrconf{verbosity} > 1); if(scalar %conts) { print "Containers:", join("\n- ", '', sort keys %conts), "\n"; } if(scalar %sessions) { print "Sessions:", join("\n- ", '', @sessions_list), "\n"; } exit $ret; } if ($opt_b and scalar %sessions) { for my $sess (@sessions_list) { print "NEEDRESTART-SESS: $sess\n"; } }