A friggin run through 10 really friggin useful friggin Linux tips.

These tips are quick and dirty. I encourage everyone to try to learn the mechanics behind these “just do it” instructions.

1. Filename completion in Bash

This may be an obvious one to some, but bear with me. By far the most useful thing is speed and quickness on the command line. Bash makes the shell quick and easy to use. You can find commands that you didn’t know about with command completion. You can complete long filenames without having to type the whole thing.

The tab key, [tab], is the filename and command completion key. You can hit [tab] to complete directory names, filenames and even commands that are in your $PATH environment variable. [tab] can be hit twice to list files, directories and commands matching your input thus far. For example, let’s say we have three commands: show, shift and set. If I type “s, [tab]”, nothing happens because “s” is the 1st letter in all three commands. “s” is not unique. However, I can type “s, [tab], [tab]” to display all the commands that start with “s” (this would display all three). If I type “sh, [tab], [tab]”, then show and shift are displayed.

You get the idea. The best way to learn more is to try it out for yourself. Most Linux distros come with Bash, if you aren’t sure what your current shell is, do a echo $SHELL' to find out. If you aren't running bash, just type bash’ to run bash.

2. Customizing your environment with profiles

There are many environment variables that you don’t want to have to set manually everytime you log in. You can set these variables automatically with profile scripts. There are a few files that execute in a certain order:

  1. /etc/profile system wide profile, maintained by root
  2. .bash_profile
  3. .bash_login if .bash_profile is not found
  4. .profile if .bash_profile and .bash_login not found

There’s nothing special about /etc/profile except for two things: 1. every user picks it up when they log in 2. it’s usally a root writable file only. Typically, if more than one user uses a environment variable (like $JAVA_HOME) then you should throw it into /etc/profile.

So what kinds of things do you put in your profile? Before we take a look at an example, remember that the profile gets executed in order. If you are changing a default /etc/profile, typically you’ll want to throw your own stuff at the bottom of the file.

# Ant/Java stuff
export PATH=$PATH:/usr/local/apache/bin:/usr/local/jakarta-ant-1.5/bin:/usr/java/j2sdk1.4.0/bin
export JAVA_HOME=/usr/java/j2sdk1.4.0
export CLASSPATH=.:/usr/java/castor:/usr/java/xerces/tools/xml-apis.jar:/usr/java/castor/castor-0.9.4.jar

MANPATH=$MANPATH:/usr/local/man
export MANPATH

Take a look at the PATH statement. PATH has been defined earlier and I don’t want to throw away its contents, so we include $PATH. If we did PATH=/usr/local/bin, PATH would only be /usr/local/bin. Seeing how there are many useful things in directories like /bin and /usr/bin, this would be bad.

A few other things, MANPATH holds the directories for man pages and colons separate directories and files in a list. Also, if you want to read in a profile without having to log out and log back in, try: . /etc/profile' or source /etc/profile’. You can substitute /etc/profile with “whatever” profile file.

3. Jobs and background processes

You can start up a background process by appending an ampersand. You can view the background jobs with jobs'. You can bring a job back to the foreground with fg [job number]’ where [job number] is the number of the job. Let’s create a quick script and put it into the background:

echo 'while (true); do echo yay; sleep 1; done' > yay.sh

Now we have a yay.sh script. Let’s make sure that is full of what we want.

[chris@server /tmp]$ cat yay.sh
while (true); do echo yay; sleep 1; done

Good. Now let’s run the script.

[chris@server /tmp]$ sh yay.sh
yay
yay
yay
...

So this is running and it’s annoying us. Hit [ctrl+z] to stop it and then type bg 1' to put it into the background. Note that it keeps outputing to the screen. This is probably because echo’ writes to STDOUT which is what our terminal is on. Normally, [ctrl+c] will send a break but since it’s in the background, the [ctrl+c] doesn’t work like you’d expect it to, it’s tricking you. Through the madness, type `fg 1’. Now hit [ctrl+c].

[chris@server /tmp]$ sh yay.sh
yay
yay

[1]+  Stopped                 sh yay.sh
[chris@server /tmp]$ bg 1
[1]+ sh yay.sh &
[chris@server /tmp]$ yay
yay
yay
fgyay
 yay
1
sh yay.sh
yay
yay

[chris@server /tmp]$

One more thing on background jobs. If a job is running in the background and you log out, the jobs is going to stop. You can make a job persist in the background by starting it with the utility ‘nohup’. For example: nohup ncftpget ftp://ftp.netscape.com/hugedownload.zip &' would start the ncftpget program (a FTP downloader) with nohup in the background. It'll run until we kill’ it, even if we log out.

4. History expansion variables

Whether you use csh or bash, there are a few variables to make your life easier when trying to recall previous commands.

Let’s say we are trying to create a directory called “/tmp/aDirectory/aSubDirectory/ohMyThisIsLong”. We create the directory and now we want go there quickly:

[chris@server /]$pwd
/
[chris@server chris]$ mkdir -p /tmp/aDirectory/aSubDirectory/ohMyThisIsLong
[chris@server chris]$ cd !:2
cd /tmp/aDirectory/aSubDirectory/ohMyThisIsLong
[chris@server ohMyThisIsLong]$ pwd
/tmp/aDirectory/aSubDirectory/ohMyThisIsLong

What is “!:2”? ! calls the last command and :2 means “substitute the 3rd command parameter” (remember that the list starts with 0). You can even print a history parameter with “:p”:

[chris@server /]$ dog cat bird worm dirt
bash: dog: command not found
[chris@server /]$ !:1:p
cat
[chris@server /]$

You get the idea. Again, the best way to learn is to try.

5. The fuser command

Let’s say you can’t figure out what’s accessing a file or directory. You need to kill the job, maybe you want to eject the CD, maybe you want to move the file … Use fuser to view all the processes acessing a file or directory resource:

fuser /mnt/cdrom

6. Screen

I’ve written about screen before. Can’t preach enough about it. So much better than nohup. Run screen' to start screen. Hit [ctrl+a, ctrl+-] to open another virtual terminal, hit [ctrl+a, ctrl+c] to open a shell on that v-terminal. Hit [ctrl+a, ctrl+d] to detach and run screen -r’ to reattach. Very useful for logging in somewhere and keeping your sessions open when you go home or switch workstations. For example:

  • You could ssh to home, start a huge download, detach, drive home and reattach after your commute.
  • You can grab a text mode ICQ client and stay connected all the time whether you are logged in or not.
  • You can start a long compile job and log out without erasing any errors.
  • You don’t have to set up your “One True Way” every time you log in. For example, I like to have a browser in window #1, a shell in window #2 and something else in #3. You’d just have to set this up once.
  • You can stay connected to IRC.

7. Text mode browsers

Can’t get a GUI started up? Try links' or lynx’. Links does better frames, lynx can do HTTP authentication. Get started with links www.google.com' or lynx www.google.com’.

8. RPMFind.net

The best place to grab missing RPMs is from RPMFind.net hosted by the nice people at SpeakEasy (Speakeasy rocks as an ISP). Let’s say you’re on your windows box and you want to install nethack (a famous rpg game).

  1. Open IE and goto www.rpmfind.net
  2. Search for nethack
  3. Find the rpm best matching your Linux distro
  4. Right click on the rpm file itself and “Copy Link Location”
  5. ssh into your linux box
  6. Either download the rpm and install it later - `wget [paste]’
  7. Or have rpm download it and install it in one motion - `rpm -ivh [paste]’ Of course, if the rpm install fails, you have to download it again (like if you’re missing the ncurses library for nethack).

9. Working with processes

man ps man kill man bg

10. Finding stuff

It’s not easy finding files and folders. UNIX is full of antiquated terms and abbreviations. Someone asked me, “What does /etc stand for?”. It stands for ‘et cetera’. /etc is where people used to put miscellaneous files. Now you typically find all the configuration files there. How can you know all this? Experience?

Nah. Just use the locate' command. Like "locate httpd.conf" or "locate ssh". Locate looks in a database for file info. The database update typically runs as a cron job. If you just copied a file 5 minutes ago, chances are that locate won't find it. You can force a database update with updatedb’. Or…

You can use the find' command. Like find / grep httpd.conf’ would search for httpd.conf starting at the root directory.