/usr/share/sysdig/chisels/v_procs_errors.lua is in sysdig 0.8.0-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 | --[[
Copyright (C) 2013-2015 Draios inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License version 2 as
published by the Free Software Foundation.
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 program. If not, see <http://www.gnu.org/licenses/>.
--]]
view_info =
{
id = "procs_errors",
name = "Processes Errors",
description = "This view shows system error counters for processes. Errors are grouped into 4 categories: file I/O, network I/O, memory allocation and 'other'.",
tips = {
"If you click 'enter' on a selection in this chart, you will be able to see the specific errors that the process is generating.",
"Digging into a process by clicking on F6 will let you explore the system calls for that specific process and see the full details about what's causing the errors."
},
tags = {"Default"},
filter = "evt.type!=switch",
view_type = "table",
applies_to = {"", "container.id", "fd.name", "fd.sport", "fd.sproto", "evt.type", "fd.directory", "k8s.pod.id", "k8s.rc.id", "k8s.svc.id", "k8s.ns.id"},
drilldown_target = "errors",
use_defaults = true,
columns =
{
{
name = "NA",
field = "proc.pid",
is_key = true
},
{
name = "FILE",
field = "evt.count.error.file",
description = "Number of file I/O errors generated by the process during the sample interval. On trace files, this is the total for the whole file.",
colsize = 8,
aggregation = "SUM"
},
{
name = "NET",
field = "evt.count.error.net",
description = "Number of network I/O errors generated by the process during the sample interval. On trace files, this is the total for the whole file.",
colsize = 8,
aggregation = "SUM"
},
{
name = "MEMORY",
field = "evt.count.error.memory",
description = "Number of memory allocation/release related errors generated by the process during the sample interval. On trace files, this is the total for the whole file.",
colsize = 8,
aggregation = "SUM"
},
{
name = "OTHER",
field = "evt.count.error.other",
description = "Number of errors generated by the process that don't fall in any of the previous categories. E.g. signal or event related errors. On trace files, this is the total for the whole file.",
colsize = 8,
aggregation = "SUM"
},
{
name = "PID",
description = "Process PID.",
field = "proc.pid",
colsize = 8,
},
{
tags = {"containers"},
name = "Container",
field = "container.name",
description = "Name of the container. What this field contains depends on the containerization technology. For example, for docker this is the content of the 'NAMES' column in 'docker ps'",
colsize = 20
},
{
name = "Command",
description = "Full command line of the process.",
field = "proc.exeline",
aggregation = "MAX",
colsize = 0
}
},
actions =
{
{
hotkey = "9",
command = "kill -9 %proc.pid",
description = "kill -9",
ask_confirmation = true,
wait_finish = false
},
{
hotkey = "c",
command = "gcore %proc.pid",
description = "generate core",
},
{
hotkey = "g",
command = "gdb -p %proc.pid",
description = "gdb attach",
wait_finish = false
},
{
hotkey = "k",
command = "kill %proc.pid",
description = "kill",
ask_confirmation = true,
wait_finish = false
},
{
hotkey = "l",
command = "ltrace -p %proc.pid",
description = "ltrace",
},
{
hotkey = "s",
command = "gdb -p %proc.pid --batch --quiet -ex \"thread apply all bt full\" -ex \"quit\"",
description = "print stack",
},
},
}
|