Bobcares

Kill Commands In Linux – The perfect guide on how to use it

PDF Header PDF Footer

Kill Commands in Linux is to terminate any unresponsive process.

As part of our Server Management Services, we assist our customers with several Linux queries.

Today, let us focus on how to simply kill the process when it becomes unresponsive or fails to respond.

 

What Is Process?

A process is the working mechanism of a program that is currently in execution. Upon its creation, every process automatically assigns to a unique process identification number, also known as a PID.

When a process dies, its PID returns to the pool of available PIDs, and another process can then reuse it.

We can use multiple commands on a server to find a specific PID of a process. We can use the top command, to find the PID of a process along with other useful system information.

Another way to find the PID is with the

ps
command:

[root@host ~]# ps faux | grep systemd
Root 1 0.0 0.6 96656 11260 ? Ss Jan24 0:08 /usr/lib/systemd/systemd –switched-root –system –deserialize 18
Root 533 0.0 1.3 125588 22832 ? Ss Jan24 0:25 /usr/lib/systemd/systemd-journald
Root 564 0.0 0.5 107440 9248 ? Ss Jan24 0:00 /usr/lib/systemd/systemd-udevd
Dbus 684 0.0 0.3 73540 5524 ? Ss Jan24 0:06 /usr/bin/dbus-daemon –system –address=systemd: –nofork –nopidfile –systemd-activation –syslog-only
Root 743 0.0 0.4 95736 7760 ? Ss Jan24 0:01 /usr/lib/systemd/systemd-logind
Root 66199 0.0 0.0 12108 1060 pts/0 S+ 08:28 0:00 \_ grep –color=auto systemd
Root 66153 0.0 0.5 93212 9472 ? Ss 08:27 0:00 /usr/lib/systemd/systemd –user
[root@host ~]# ps -eo user,pid,command | grep systemd
[root@host ~]# ps -eo user,pid,command | grep systemd
root 1 /usr/lib/systemd/systemd –switched-root –system –deserialize 18
root 533 /usr/lib/systemd/systemd-journald
root 564 /usr/lib/systemd/systemd-udevd
dbus 684 /usr/bin/dbus-daemon –system –address=systemd: –nofork –nopidfile –systemd-activation –syslog-only
root 743 /usr/lib/systemd/systemd-logind
root 66153 /usr/lib/systemd/systemd –user
root 66213 grep –color=auto systemd

We can also use the

pidof
process_name, and the
pgrep
process_name commands to find out the corresponding PIDs of that process.

[root@host ~]# pidof systemd
66156 66153 1
[root@host ~]# pgrep systemd
1
533
564
743
66153

To terminate a process, we can use the kill commands in Linux. This is a built-in command that sends a signal to a specified process, which terminates the process in question.

 

What Are Signals?

Signals are a form of a dialogue between the processes that can come from other processes, the kernel, or the process itself.

Each process has a current behavior, of which there are five dispositions:

  • Term
  • Ign
  • Core
  • Stop
  • Cont

The Term’s default action is to terminate the process, and it is the one primarily used by the kill command.

There are a total of sixty-four (64) signals. The one we send will depend on the result that we want, as different signals have different effects and outcomes.

Out of these sixty-four signals, the first thirty-one are standard signals and the last thirty-three are real-time signals.

We can see a full list of available signals with the command

kill -l
:

[root@host ~]# kill -l
1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5) SIGTRAP 6) SIGABRT
7) SIGBUS 8) SIGFPE 9) SIGKILL 10) SIGUSR1 11) SIGSEGV 12) SIGUSR2
13) SIGPIPE 14) SIGALRM 15) SIGTERM 16) SIGSTKFLT 17) SIGCHLD
18) SIGCONT 19) SIGSTOP 20) SIGTSTP 21) SIGTTIN 22) SIGTTOU 23) SIGURG 24) SIGXCPU 25) SIGXFSZ 26) SIGVTALRM 27) SIGPROF 28) SIGWINCH
29) SIGIO 30) SIGPWR 31) SIGSYS 34) SIGRTMIN 35) SIGRTMIN+1
36) SIGRTMIN+2 37) SIGRTMIN+3 38) SIGRTMIN+4 39) SIGRTMIN+5
40) SIGRTMIN+6 41) SIGRTMIN+7 42) SIGRTMIN+8 43) SIGRTMIN+9
44) SIGRTMIN+10 45) SIGRTMIN+11 46) SIGRTMIN+12 47) SIGRTMIN+13
48) SIGRTMIN+14 49) SIGRTMIN+15 50) SIGRTMAX-14 51) SIGRTMAX-13
52) SIGRTMAX-12 53) SIGRTMAX-11 54) SIGRTMAX-10 55) SIGRTMAX-9
56) SIGRTMAX-8 57) SIGRTMAX-7 58) SIGRTMAX-6 59) SIGRTMAX-5
60) SIGRTMAX-4 61) SIGRTMAX-3 62) SIGRTMAX-2 63) SIGRTMAX-1
64) SIGRTMAX

For most of these signals, a program may or may not specify a different action. If it defines, it is called catching or handling the signal, but if no action occurs, then the signal will be ignored.

The most commonly used signals are:

Signal Name            Single Value    Effect
SIGHUP                 1               Hangup, reload a process
SIGINT                 2               Interrupt from keyboard
SIGKILL                9               Kill a process
SIGTERM                15              Terminate a process gracefully
SIGSTOP                17, 19, 23      Stop a process

We can use SIGKILL when SIGTERM fails to stop or end the process.

[root@host ~]# ps -eo user,pid,command | grep java
tomcat 59815 /usr/bin/java -Djava.util.logging.config.file=/usr/local/tomcat9/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.net.preferIPv4Stack=true -Djava.net.preferIPv4Addresses=true -Djdk.tls.ephemeralDHKeySize=2048 -Djava.protocol.handler.pkgs=org.apache.catalina.webresources -Dorg.apache.catalina.security.SecurityListener.UMASK=0027 -Dignore.endorsed.dirs= -classpath /usr/local/tomcat9/bin/bootstrap.jar:/usr/local/tomcat9/bin/tomcat-juli.jar -Dcatalina.base=/usr/local/tomcat9 -Dcatalina.home=/usr/local/tomcat9 -Djava.io.tmpdir=/usr/local/tomcat9/temp org.apache.catalina.startup.Bootstrap start
root 66401 grep –color=auto java
[root@host ~]# kill -15 59815

Unfortunately, the kill -15 (SIGTERM) did not accomplish stopping the Java process.

[Want to know more? Contact us now]

Kill Commands In Linux

Kill Commands In Linux

The kill command sends a signal to terminate a process. By default, it will send a TERM signal. It will try to stop the process gracefully. If that fails, we can try terminating the process with another signal.

To kill a process with a different signal, it can be defined using a number (-9), with a SIG prefix (-SIGkill) with or without the SIG prefix (-kill).

[root@host ~]# ps -eo user,pid,command | grep java
tomcat 66469 /usr/bin/java -Djava.util.logging.config.file=/usr/local/tomcat9/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.net.preferIPv4Stack=true -Djava.net.preferIPv4Addresses=true -Djdk.tls.ephemeralDHKeySize=2048 -Djava.protocol.handler.pkgs=org.apache.catalina.webresources -Dorg.apache.catalina.security.SecurityListener.UMASK=0027 -Dignore.endorsed.dirs= -classpath /usr/local/tomcat9/bin/bootstrap.jar:/usr/local/tomcat9/bin/tomcat-juli.jar -Dcatalina.base=/usr/local/tomcat9 -Dcatalina.home=/usr/local/tomcat9 -Djava.io.tmpdir=/usr/local/tomcat9/temp org.apache.catalina.startup.Bootstrap start
root 66516 grep –color=auto java
[root@host ~]# kill -9 66469
[root@host ~]# ps -eo user,pid,command | grep java
root 66530 grep –color=auto java

As we can see, the kill -9 (SIGKILL) command terminates the Java process.

The kill command can be invoked with the following syntax:

kill [OPTIONS] [PID]

For example, if we find that the process ID for a httpd process is 21567, we can try to kill it gracefully by invoking:

[root@host ~]# kill 21567

This will send the TERM signal. If this does not stop the process, we can then try to kill it with the signal SIGKILL (-15).

We can accomplish it in one of the following ways:

[root@host ~]# kill -9 21567
[root@host ~]# kill -SIGKILL 21567
[root@host ~]# kill -kill 21567

 

Killall

Additionally, we can kill a process by using the unique process ID, by using the kill command, or with the process name, by using the

killall
command.

The same syntax applies with the

killall
command, which can invoke with
killall
[signal] [process_name], for example:

killall -9 httpd

This command will terminate the

httpd
process without waiting for it to stop gracefully. When determining which process the signal will be sent to, it will match the argument name exactly.

For example:

killall httpd

The command will send a termination signal to all processes that are exactly named “

httpd
.”

Instead, if we try to run this command:

killall http

It will show an error that there is no process with that name since Apache uses “

httpd
” and not “
http
.”

 

Pkill

A command similar to

killall
is
pkill
, which also can kill a process by name. This command takes a pattern as an argument, which matches against the names of running processes, so it does not need an exact name.

For example, we can terminate

httpd
with something like this:

pkill http

Although this is not the exact process name, it will find the processes that contain this pattern and send the terminate signal to

httpd
.

 

Skill

We can use the

skill
command to send termination signals, much like kill command. Here it uses the default TERM signal.

skill [signal] [options]

[root@host ~]# ps -eo user,pid,command | grep tomcat
tomcat 66546 /usr/bin/java -Djava.util.logging.config.file=/usr/local/tomcat9/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.net.preferIPv4Stack=true -Djava.net.preferIPv4Addresses=true -Djdk.tls.ephemeralDHKeySize=2048 -Djava.protocol.handler.pkgs=org.apache.catalina.webresources -Dorg.apache.catalina.security.SecurityListener.UMASK=0027 -Dignore.endorsed.dirs= -classpath /usr/local/tomcat9/bin/bootstrap.jar:/usr/local/tomcat9/bin/tomcat-juli.jar -Dcatalina.base=/usr/local/tomcat9 -Dcatalina.home=/usr/local/tomcat9 -Djava.io.tmpdir=/usr/local/tomcat9/temp org.apache.catalina.startup.Bootstrap start
root 66846 grep –color=auto tomcat
[root@host ~]# skill -9 66546

Our Support Techs suggest using the

kill
,
pkill
, or
killall
commands instead.

 

Mysql_zap

Another command that will end a process that matches a specific pattern is

mysql_zap
. An identified process will match this pattern if its output line from the ps command contains that pattern.

As with other commands,

mysql_zap
will send a TERM signal by default. The syntax used for this command is:

[root@host ~]# mysql_zap [signal] [pattern].

We should note that the

mysql_zap
command depreciates in MariaDB as of version 10.2 in favor of the
pkill
command.

 

Mk-kill

The

mk-kill
command is to kill MySQL queries that match a specific criterion.

If a file pass to

mk-kill
, it will read the queries from that file, which contain the output of SHOW PROCESSLIST.  If no file is given as an argument,
mk-kill
will execute a SHOW PROCESSLIST in MySQL to obtain the queries.

Here are two examples of that command:

[root@host ~]# mk-kill –busy-time 60 –print
[root@host ~]# mk-kill –match-command Sleep –kill –no-only-oldest –interval 10

The first command will kill any queries found to be running longer than sixty seconds. The second command checks for any sleeping processes every ten seconds, and if any are found, the

mk-kill
command ends those queries.

 

Mkill

Another command similar to

mk-kill
is the
mkill
command. This command will kill slow queries.

It will kill these queries based on several factors, such as query time, host, user, database, state, and query content. Note that the

mkill
command is still in an alpha version status.

 

Tkill/Tgkill

If we want to kill a specific thread, instead of an arbitrary thread within an entire process, we can do so with

tkill
and
tgkill
commands.

We should note that the

tkill
command should avoid as it is the depreciated predecessor to
tgkill
. The
tkill
command only allows for the target thread ID to be specified, which could lead to the termination of an incorrect thread if that thread ID is recycled.

On the other hand,

tgkill
will send a signal to the thread with the thread ID in the thread group
tgid
.

 

Killpg

It is also worth noting that several commands are to send signals to a process group. One of those commands is

killpg
.

The

killpg
command will send a signal to a process group (or
pgrp
). If the
pgrp
is 0, then a signal will be sent to the calling process’ process group.

Otherwise, the

killpgrp
command does not take any other arguments so that it will kill all processes within the same process group.

 

Tcpkill

We can also kill specific TCP connections that are in progress with the

tcpkill
command. We can specify a network interface to listen on, or we can also determine the degree of force to use in terminating a connection, where the default is
3
.

The following command is the syntax of

tcpkill
.

[root@host ~]# tcpkill [-i interface] [-1…9] expression
[root@host ~]# tcpkill -i eth0 port 21

 

Lxc-kill

If we need to stop a process running inside a virtualized container running on Ubuntu, we can use the

lxc-kill
command. This command will send a numeric signal to the first process of the container to end a process.

The syntax of the

lxc-kill
command is as follows:

lxc-kill –name=NAME SIGNUM

 

Arckill

The

arckill
command is to kill running jobs on an ARC enabled resource. We can either use the
jobid
, or the jobname, if such an attribute was submitted, to refer to a job.

arckill -j filename.xml (<jobid#>)

 

Pvm_kill

To terminate a specific PVM process, we can use the

pvm_kill
command. It will send a terminate signal to a PVM process that is identified by the task identifier
tid
.

We use this command with a larger program:

In C: info = pvm_kill( tid );
In Fortran: CALL PVMFKILL( TID, INFO )

 

Xkill

There is also the

xkill
command, which is a graphical way to kill an application.

When we enter the command

xkill
, the mouse cursor will change into a plus sign. It allows us to left-click an unresponsive window to close it. The
xkill
command instructs the xserver to terminate the window displaying a program.

Its syntax is as follows:

xkill [-display displayname] [-id resource] [-button number] [-frame] [-all]

[Finding it hard to execute a command? We’d be happy to assist]

 

General Rules of Kill Commands In Linux

It is essential to note that regular users can send signals to their own processes. However not to those that belong to other users.

The root user, on the other hand, can send signals to all other user’s processes.

This also depends on what PID we pass to the command:

  • If the PID is greater than zero, then the signal sends to the process with that PID.
  • When PID is equal to zero, the signal sends to all processes in the process group (PGID) of the shell that is invoking the kill command.
  • If PID is equal to -1, the signal sends to all processes with the same user ID as the user who has invoked the kill command.
  • If PID is less than -1, the signal sends to all processes in the process group with the process group ID that is equal to the absolute value of the PID.

[Confused with the rules? We’ll make it easy for you]

 

Conclusion

To conclude, there are several ways to terminate a process. However, one should exercise caution to prevent incorrectly terminating a process that should not be killed. Get in touch with our Support Engineers who will happily assist you in matters of Kill Commands In Linux.

PREVENT YOUR SERVER FROM CRASHING!

Never again lose customers to poor server speed! Let us help you.

Our server experts will monitor & maintain your server 24/7 so that it remains lightning fast and secure.

GET STARTED

var google_conversion_label = "owonCMyG5nEQ0aD71QM";
0 Comments

Submit a Comment

Your email address will not be published. Required fields are marked *

Get featured on the Bobcares blog and share your expertise with a global tech audience.

WRITE FOR US
server management

Spend time on your business, not on your servers.

TALK TO US

Or click here to learn more.

Speed issues driving customers away?
We’ve got your back!