asterisk and have their letter, for example:
* A: PID = Process Id
If you press the a
key, the screen changes to this:
a: PID = Process Id
When you have made your selections, press Enter to return to the normal top
view with your normal column selection.
You can also press F
to select the field you want to use for sorting. This works in the same way as the field selection screen, except that you can select only one field at a time. Again, press Enter to get back to top
after you have made your selection, and the output will be updated with the new sorting.
If you press B
, text bolding is enabled. By default, this bolds some of the header bar and any programs that are currently running (as opposed to sleeping), but if you press x
you can also enable bolding of the sorted column. You can use y
to toggle bolding of running processes.
The last command to try is r
, which enables you to nice
value — of a process. You need to enter the PID of the process, press Enter, and enter a new nice value. Keep in mind that 19 is the lowest and -20 is the highest; anything less than 0 is considered 'high' and should be used sparingly.
Printing the Location of a Command with which
The purpose of which
is to tell you the exact command that would be executed if you typed it. For example, which mkdir
returns /bin/mkdir
, telling you that running the command mkdir
runs /bin/mkdir
.
Combining Commands
So far, we have been using commands only individually, and for the large part that is what you will be doing in practice. However, some of the real power of these commands lies in the capability to join them to get exactly what you want. There are some extra little commands we have not yet covered that are often used as glue because they do one simple thing that enables a more complex process to work.
All the commands we have examined have printed their information to the screen, but this is often flexible. There are two ways to control where output should go: piping and output redirection. A
Two of the commands covered so far are ps and grep: the process lister and the string matcher. You can combine the two to find out which users are playing Nethack right now:
$ ps aux | grep nethack
That creates a list of all the processes running right now and sends that list to the grep command, which filters out all lines that do not contain the word nethack. Fedora allows you to pipe as many commands as you can sanely string together. For example, you could add in the wc command, which counts the numbers of lines, words, and characters in its input, to count precisely how many times Nethack is being run:
$ ps aux | grep nethack | wc -l
The -l
(lowercase wc
prints only the line count.
Using pipes in this way is often preferable to using the -exec
parameter to find
, simply because many people consider find
to be a black art and so anything that uses it less frequently is better! This is where the xargs
command comes in: It converts output from one command into arguments for another.
For a good example, consider this mammoth find
command from earlier:
$ find / -name '*.txt' -size +10k -user paul -not -perm +o=r -exec chmod o+r {} ;
That command searches every directory from /
onward for files matching *.txt
that are greater than 10KB, are owned by user paul
, and do not have read permission for others. Then it executes chmod on each of the files. It is a complex command, and people who are not familiar with the workings of find
might have problems understanding it. So, what we can do is break up the single command into two parts: a call to find
and a call to xargs
. The conversion would look like this:
$ find / -name '*.txt' -size +10k -user paul -not -perm +o=r | xargs chmod o +r
That has eliminated the confusing {} ;
from the end of the command, but it does the same thing, and faster, too. The speed difference between the two exists because using -exec
with find causes it to execute chmod
once for each file. However, chmod
accepts many files at a time and, because the same parameter is used each time, you should take advantage of that. The second command, using xargs
, is called once with all the output from find
, and so saves many command calls. The xargs
command automatically places the input at the end of the line, so the previous command might look something like this:
$ xargs chmod o+r file1.txt file2.txt file3.txt
Not every command accepts multiple files, however, and if you specify the -l
parameter, xargs
executes its command once for each line in its input. If you want to check what it is doing, use the -p
parameter to have xargs
prompt you before executing each command.
For even more control, the -i
parameter enables you to specify exactly where the matching lines should be placed in your command. This is important if you need the lines to appear before the end of the command or need them to appear more than once. Either way, using the -i
parameter also enables the -l
parameter so that each line is sent to the command individually. This next command finds all files in /home/paul
that are larger than 10,000KB in size (10MB) and copies them to /home/paul/archive
:
$ find /home/paul -size +10000k | xargs -i cp {} ./home/paul/archive
Using find
with xargs
is a unique case. All too often, people use pipes when parameters would do the job just as well. For example, these two commands are identical:
$ ps aux --sort=-%cpu | grep -v `whoami`
$ ps -N ux --sort=-%cpu
The former prints all users and processes and then pipes that to grep
, which in turn filters out all lines that contain the output from the program whoami
(our username). So, line one prints all processes being run by other uses, sorted by CPU use. Line two does not specify the a
parameter to ps
, which makes it list only our parameters. It then uses the -N
parameter to flip that, which means it lists everyone but us, without the need for grep
.
The reason people use the former is often just simplicity: Many people know only a handful of parameters to each command, so they can string together two commands simply rather than write one command properly. Unless the command is to be run regularly, this is not a problem. Indeed, the first line would be better because it does not drive people to the manual to find out what ps -N
does!