What to do when Ctrl-C won't kill running job?

Sometimes, processes ignore the SIGINT signal sent by CtrlC in Bash. For instance, man and vi. Assuming you don’t want to google or read the manual on how to exit the running process, is there any key sequence that will always work (without leaving the terminal)?

Asked By: Olivier Lalonde

||

Try Ctrl+Alt+Backspace

If you are using ubuntu 10.04 you wanna enable this key to work.

To enable ControlAltBackspace

Goto System–>Preferences–>Keyboard

Select the Layouts tab and click on the Layout Options.

Select Key sequence to kill the X server and enable Control + Alt +Backspace.

Note:

Pressing CtrlAltBackspace will restart your X server.

Answered By: karthick87

You can try Ctrl+

Answered By: Benjamin

Send the SIGQUIT signal with Ctrl+.

.. $ sleep 10
^Quit

→ This is equivalent to kill -3 pid. Programs run in user-space don’t ignore sigquit.

There is also a set of Magic SysRq keyboard shortcuts. One of the more interesting ones is this: Alt+SysRq+k. It kills every process on the current virtual console. If one of your ttys is completely and utterly broken, this can be used to go back. On the tty running X.org, it can be used to kill X without mercy.

The SysRq key is, on most keyboards, the same as the Print Key. On my notebook, it can be invoked using the Fn key; I.e. Alt→Fn→Print→k in that order.

Here are some of the basic process management shortcuts:

  • Ctrl+Z: pause a
    process (plus bg to resume in the background, fg to raise to foreground)
  • Ctrl+C: politely ask the process to
    shut down now
  • Ctrl+: mercilessly kill the process that is
    currently in the foreground
  • Alt+SysRq+s: Write data to disk (always do this before killing anything important)
  • Alt+SysRq+s, k: mercilessly kill all current
    processes on a given virtual console
  • Alt+SysRq+s, b: mercilessly reboot without unmounting,
  • Alt+SysRq+r, e, i, s, u, b: Safely reboot even if the system is utterly broken,

Note: Ctrl+Z, in contrast to Ctrl+C and Ctrl+, also works for man, vi, less, and the like.

When in doubt, the follwing procedure will almost always work:

~$ sleep 10
^Z
[5]+  Stopped              sleep 10
~$ ps
  PID TTY          TIME CMD
 4804 pts/0    00:00:00 bash
 6207 pts/0    00:00:00 sleep
 6208 pts/0    00:00:00 ps
~$ kill -9 6207
[5]+  Killed                  sleep 10
~$ 

^Z of course indicates that Ctrl+Z has been pressed.


For a more in-depth look at Shells and Terminals, also see my answers on:

Answered By: Stefano Palazzo

Sometimes the CTRL+C is getting sent to the wrong program or input channel. This is especially common with editors such as vi, with commands with piped output, complex bash commands involving loops, etc.

A simple, quick solution is to suspend the job CTRL+Z and then kill it by job number: kill %1 or kill -9 %1, etc.

Answered By: tylerl

To quit from man, use q
To leave vi use :q

Answered By: antivirtel
  • Try one of these:

    Ctrl+4

    Ctrl+


  • Or:

    Ctrl+Z and then run:

    kill %1

Where %1 is the number of job which was returned when you pressed ControlZ. Add -9 to force the kill.


When you’re in text console, you could also try: CtrlSysRq. The kernel should kill the process.

Or SysRqk, kill all processes on the current virtual console (can kill X and svgalib programs as well).

Note: When magic SysRq keys are used to kill a frozen graphical
program, the program has no chance to restore text mode. This can make
everything unreadable.

See: Magic SysRq key and its command combinations.

Answered By: kenorb

It’s possible, that you changed the shortcut of copy from:

CTRL+SHIFT+C

To

CTRL+C

That way, when you try to kill a process, the CTRL+C doesn’t work.

Try to replace the copy shortcut to CTRL+SHIFT+C.

Answered By: Minter

Open Terminal → Preferences → Shortcuts and search if by mistake you have replaced any key with Ctrl+C.

Answered By: Manas kumar