- In this lab students will learn to navigate their file system using only the terminal
- Students will practice using the following commands to traverse directories and investigate their contents:
pwd
,ls
,cd
,cat
,less
,grep
- Why? well, for forever coders have used the shell to interact with a computer, as it can be, with practice, very efficient and fast.
The console (also referred to as the command line, terminal, or shell) is an essential tool for programmers to be familiar with. The command line shell we will be using is called Bash. This lab will focus on the basics for navigating and investigating the file system through the command line. In this lab we will only be using the command line in interactive mode (more on that in the Bash labs). Here are the commands we will focus on:
pwd
- "Print Working Directory" prints out your current location (known as your current working directory or 'cwd')ls
- lists contents of the cwdcd
- change directory. This is how you move around the file system. You can specify the destination as an absolute or relative path.echo
- prints text to the terminalcat
- concatenates zero or more files. Often used to print the contents of a file to the terminal. Often misusedless
/more
- Display contents of a file one page at a time ...just remember that less is more (more or less) and you'll be fine.grep
- search for the specified text or pattern
head
- display the first lines of a filetail
- display the last lines of a file
This lab is an instructional introduction to terminal. There are no unit tests.
It's a good practice to have a directory called Dev
inside your home directory for all development work. You can create one in Finder (right click -> New Folder) or in the terminal (mkdir ~/Dev
). This directory will come in handy in case things go horribly wrong, or if you want to back up all of your work. You should always make sure you are working in Dev or a directory inside of it during this course.
- Open up a terminal (Applications->Utilities->Terminal)
- Find out what directory you're in using
pwd
- You know where you are, but not what's around you. Take a look around with
ls
- You probably started in your home directory, but just in case, tell the terminal to move to your home directory with
cd ~
. Usepwd
again to confirm. - Change into your Dev directory with
cd Dev
. If you don't have one you should create one (see above) - Now let's try printing the contents of a file. First we need to create the file. One quick way to do that is with the command
echo "Hello Terminal" >myFile.txt
. We'll explain this command in greater detail in the next lab. - Use
ls
to list the contents of your directory after running that command to see what changed. - Now show the contents of that new file using the
cat
command. - You can use
cat
to print the contents of multiple files; Create another file the same way you created myFile.txt and then print them both together (eg:cat myFile.txt myFile2.txt
) - Using
cat
is fine for small files, or when you just want to print the entire contents of a file, but if you want to read through a large file it's not great. Try using cat on the file/etc/bashrc_Apple_Terminal
- That file's a bit big for
cat
; try viewing it again withless
. You can move around inless
using ENTER, SPACE, and your arrow keys. To exit less, press the letterq
. (note that if this is the first time you've used the terminal, your .bash_history file may still be very small) - The last command for you to try out is
grep
. You can use this to search for a pattern in a file or other body of text. Try using it on that first file you created like this:grep Hello myFile.txt
. Notice that the result is the whole line where the text you searched for occurs. What happens if you use grep to search for something that isn't in the file?
- After this lab students will know how to create, remove, and modify files and directories using the terminal
- By completing this lab students will gain exposure to man pages and the use of bash commands with arguments and options.
In Part 1 lab you learned to navigate your file system in the terminal. In Part 2 you will learn how to actually make changes to the file system and where to find documentation to get a better grasp on commands you are already familiar with as well as those you haven't seen before. The commands you will practice in this lab are:
touch
mkdir
rmdir
rm
cp
mv
<
,>
,>>
,|
In lab 1 you learned one way to create a file using the echo
command and output redirection. That can be useful but there are other methods that make more sense sometimes. Here we'll focus on two other methods:
- the
touch
command. - file editors.
To create a file using touch, simply type the command followed by the name of the file you want to create, like this: touch filename
. Touch is actually meant to update the timestamp on files, but as a side effect it creates files that are named but don't already exist. It's time to practice touch
ing files
-
Use
touch
to create two files, called myfile1 and myfile2 -
Try using
touch
to create three more files, but all in the same command. Just give touch the filenames you want one right after the other, separated by a space -
Use the
ls -lT
(that's a lowercase 'L' after the dash) command to see the full timestamps of the files you just created. Notice that the first two are different but the last three are all the same.
There are many text editors out there. We will be using an editor called VIM (short for VI iMproved -- it is a clone of the editor VI with some improvements). Other options that you can explore on your own include emacs and nano (a clone of a program called pico). Here are the VIM commands we'll use along with a few other useful basics (there are many, many, many many more):
-
:w
- Write; writes the current contents of the buffer (editor) to a file. -
:q
- Quit; Quits VIM. Complains if you have unsaved changes (use:w
first, or:q!
to force quit and abandon your changes) -
:set number
/:set nonumber
- Enables/disables line numbers. -
a
- Switch to insert mode after the current character.A
goes to the end of the line instead. -
i
- Switch to insert mode before the current character.I
goes to the beginning of the line instead -
x
- Delete the character under the cursor. -
dd
- Delete the current line. -
h``j``k``l
- Work like the left, down, up, and right arrow keys respectively. -
Let's create a file with vim. Start by opening the program with the
vim
command. -
This is the editor screen. VIM has two modes, insert mode and normal mode; it starts in normal mode. The
esc
key switches to normal mode from insert mode but not the other way -- if you ever get lost just hit escape. -
We want to create a file, but we don't need anything in it yet. To save your current file you can use the
:w
command from normal mode. Type:w myfile6
to save this empty file as "myfile6" -
Quit VIM with the
:q
command and list the contents of your directory to confirm that you created a file (Shortcut::wq
allows you to save a file and quit with just one command) -
Open that file by running vim with the filename. This time we'll add a little text.
-
Switch to insert mode by pressing the
a
key and type the message "Hello Editor!". Remember to pressesc
when you finish to switch back to normal mode. -
Save the file (remember how?)
-
Let's make that message a little more specific. Delete the word 'Editor' and replace it with VIM. Look at the list of commands to see how to do this. Save the changed file.
-
One powerful feature in VIM is the ability to repeat commands automatically. Type the number 10 before using the
A
(note that it's capitalized) command to add text to the end of the line; Press enter to go to the next line and then type a short message. See what happens when you finish the message and pressesc
-
Now that you have several lines in your file, line numbers might be helpful. Enable them using the
:set number
command. -
Ten copies of the same message might be a bit too much. Move the cursor to line 2 and type
9dd
. You should now see only one line of your message.
- Use
mkdir
to make a directory with your name - make two more directories inside of that one called "dir1" and "dir2"
- You can make directories in other places than your current directory, without
cd
ing into it, make a directory inside dir1. When you give the location of a file or directory relative to your current position that's called a relative path - Try making a directory inside dir2 by giving an absolute path. Absolute paths list the exact location of a file -- you've seen this before with the pwd command.
- use the
cp
command to copy the file you wrote in the last section. Try using the man file for cp to see what the correct syntax is (anything between [] braces is optional) - Make a new directory and then move the copied file you just created into that directory using the
mv
command. - Let's change the name of that file. The
mv
command doesn't have to move a file to a new location; it can simply change the name of the file in place. Change the name to something that starts with a dot (.) such as ".myFile" - Now check the contents of your directory with
ls
. Where is the file you just renamed? In Linux and Unix systems, files and directories with names starting in "." are hidden, so by renaming your file you actually made it a hidden file. Let's see how we can view hidden files withls
- The
man
command lets you view the man(ual) pages for any command that is documented. Try viewing the man pages for ls, cp, and mv. Once you've looked at each of these and have a feel for how they are laid out, take another look at the ls man page and see if you can figure out how to view hidden files (remember, hidden files begin with a dot '.' ) hint: viewing man pages is like using less; you can move up and down in the file with the keyboard and when you want to exit you can press the 'q' key*
- Make three files and two directories any way you like; create a file inside one of those directories.
- The
rm
command deletes files, try using that on one of the files you created. - Another way to delete a file is the
unlink
command. Use this to delete the second file. - Sometimes you want to make sure you are deleting the right files (particularly if you use the * wildcard). use
rm -i
to delete the last file and notice that you have to confirm it before it's deleted. - Try to delete one of those directories with
rm
. Notice that on its own it won't delete directories. - Use
rmdir
(orrm -d
) to delete the empty directory, then try it on the directory with a file in it. - Directories can only be deleted when they are empty; this could get painful if you have a lot of files and directories inside of one you want to delete. Try deleting that directory again with the
rm -R
command. The-R
flag tellsrm
to recursively delete the contents of each directory it encounters and then delete the directory. - Bonus: run the command
echo "Hello" >-toughFile
and then try to delete the file created by that command. There are at least two ways to do this.
Remember in the previous lab when you typed the command echo "Hello Terminal" >myfile.txt
? That 'greater than' sign is actually a special character in bash used for redirecting output to a file. There are several of these operators for redirecting output and input. The main redirection operators to be aware of are as follows:
-
<
- Redirects input to come from the specified file. By default input comes from a stream called STDIN (STandarD INput) -
>
- Redirects output to the specified file (if the file exists its contents are erased first). By default normal program output is directed to a stream called STDOUT (STandarD OUTput) and errors are directed to a stream called STDERR (STandarD ERRor -- Redirect STDERR using2>
instead) -
>>
- Appends output to the specified file instead of overwriting it -
|
- redirects the output from the previous command to be the input of the next command. -
Use the
find
command to search for all files on your machine with "core' in the name. You can do that withfind / -name core
. -
That's a lot of "Permission denied" errors, and they make it hard to see the useful output from that command. Fortunately that's where output redirection becomes helpful: Those errors all go to STDERR, while the output we want is going to STDOUT. Use the commands above to redirect STDERR to
/dev/null
, effectively throwing away the output from STDERR. -
That's a little better. We want to search for specific core files in this output, so let's redirect STDOUT to a file called
corefiles.log
. -
Next, use
grep
to search for any lines that contain the string 'lib'. We want the search to be case insensitive so we'll use the-i
flag like so:grep -i lib corefiles.log
(note: your file may have very few lines in it if your computer is rather new and has not had many programs installed yet. It may seem silly to use grep to search for a particular line in a file with only two lines, but when you're searching for an error that occurred only once in over 10000 lines of debugging output you will want to know this tool well.) -
Great, but there's a quicker way to do this without creating a file and running two separate commands. Try using the
|
(pipe) character to redirect the output fromfind
to the input forgrep
. Don't forget to throw out the STDERR output; we don't need grep to search through that since we already know it won't contain the files we're looking for.
Did you notice how you had to wait a few seconds every time you ran that find command? Sometimes you may need to use a long-running command and don't want it to lock up your terminal the whole time it's running. That's when you would want to run it in the background (by default, any command you run on a terminal runs in the foreground. Let's play with backgrounding and foregrounding a bit.
- Run that same
find | grep
command that you used in the last step, but add the background operator,&
, to the end of it. Notice that you immediately get a prompt, but after a few seconds the result of the grep prints to the command line. - For now we won't worry about that output getting in the way, but this is another good example where you may want to redirect STDOUT to a file.
Now let's practice one more backgrounding technique with a different command.
- Run the command
python -m SimpleHTTPServer
. This will run forever until you kill it withfireCtrl
+C
- Now you're stuck without your prompt; but we can fix that! Press
Ctrl
+Z
to suspend (not kill) that program. - Now you've got your terminal back, but if you type
jobs
you'll see that python is currently stopped. You can bring it back withfg
, but that will block your prompt again; instead, usebg
to resume it in the background. - Now that you've resumed python in the background, you can see it listed as running in
jobs
. Bring it back to the foreground withfg
and then kill it withCtrl
+C
-
For more practice with the basics of the terminal, try the Command Line Crash Course.
-
vimtutor
-- type this command on your command line for a built-in lesson in VIM basics.
- "Often misused" https://en.wikipedia.org/wiki/Cat_(Unix)#Useless_use_of_cat
- "more or less" http://unix.stackexchange.com/questions/81129/what-are-the-differences-between-most-more-and-less
- "Command Line Crash Course" http://learnpythonthehardway.org/book/appendixa.html
- "VIM 101" https://www.linux.com/learn/vim-101-beginners-guide-vim