Table of Contents
Objectives
- Become familiar with the Linux environment, commands, and some applications.
- Be able to navigate a directory tree from the command line.
- Use a text editor to create and edit text files.
Getting Started
Use the GitHub Classroom link posted in the Learning Suite for the lab to accept the assignment. Next, ssh
into your Raspberry Pi and clone the repository into your Raspberry Pi’s home directory. This lab must be done on your Raspberry Pi. As a reminder, to ssh
into your Rapsberry Pi, plug it in, and run this command on the terminal of your lab computer:
ssh [your-netid]@doorbell-[your-netid].local
Fill in your NetID in the command. To clone the repository, follow the instructions on the Lab Setup page.
This lab should be done in the terminal, not VSCode.
Overview
In this lab you will learn some basic Linux features and skills that are useful throughout a technical career. The Linux environment is used commonly in the engineering, scientific and research communities. One of the reasons for this stems from the openness of Linux and the many applications that run on it. The source code to most everything that runs on Linux, and the kernel itself, is available on the Web. If you don’t like something or want to improve it, nothing is stopping you from getting the source code and changing it. You are encouraged to learn and explore beyond what is presented here on your own. We can only touch on a few Linux features. Discovering the flexibility that is available to the creative mind is left to you.
Explore Common Linux Commands
Work through Modules 1, 2, 3 (skip the printing commands), and 4 of the Linux Survival tutorial. It has a simulated Linux terminal for practicing what you learn in the modules.
For a brief list of commonly used commands, see the Linux Command Summary.
Keyboard Shortcuts
Even though using the command line to do things in Linux may seem like a lot of typing, there are shortcuts in place that can tremendously reduce the number of keystrokes. With a little practice, the shortcuts become a natural part of doing work on the command line and can even be more efficient than pointing, clicking, and navigating menus in a graphical interface. With a graphical interface, a user will often need to move their hand back and forth between the keyboard and the mouse. This motion is inefficient, even though most of us get used to it. With command line operation, our fingers never need to leave the keyboard and reach for the mouse.
Command History
When you type a command on the keyboard, there is a good chance you will want to execute it again, exactly the same way, or with a small variation. Using the up and down arrows on the keyboard allows you to navigate through a history of commands you have typed on the command line. When you hit the up arrow key the first time, the last command you executed will appear on the command line. If you hit up arrow again, you will see the next to the last and so forth. Typing down arrow will show more recent commands. After you have selected a previous command with the arrow keys, hitting the Enter
key will execute the command.
Command Editing
Once you have selected a prior command with the up and down arrow keys, you may want to slightly change it before you execute it again. The left and right arrow keys allow you to move the cursor to a location where you want to change the command. Use the backspace key to remove characters and then type new text at that location. When satisfied with the modified command, hit Enter
to execute it. This is useful, for example, when you want to execute the same command on a different filename. Just hit up arrow to get the previous command, then backspace over the old file name and type the new one.
Command Completion
Another helpful shortcut is called tab completion. If the tab key is pressed while a partial command or file name is typed, the shell will complete the rest of the text based on what has already been typed. Open a terminal window to your home directory (you can do this by typing Ctrl
+Alt
+T
and then ssh
ing into your Raspberry Pi) and type the following and then hit Tab
.
ls /d
After hitting Tab
you should see that “/d” was extended to “/dev/”. Now type Enter
to execute the command. When navigating deep directory hierarchies, tab completion can assist in typing what could otherwise be very long path names. For example, tab can be pressed multiple times to keep extending the path name after typing a few characters, enough to make the name unique.
Command names can also be tab completed. In a terminal window, type the following and then hit Tab
.
mkd
Pressing the tab key should complete the command to mkdir. Press Enter
to start the web browser. If you press Tab
and you don’t get a response, you have mistyped the leading characters or there are other options that are ambiguous. Typing Tab
again a second time will list the remaining options that begin with the characters you have typed. For example type in
mk
Now hit Tab
a couple of times and you should see something like this:
mkdir mk_modmap mksh mktemp mkvinfo mkvpropedit
mkfifo mknod mksh-static mkvextract mkvmerge
You can Tab
through the possible commands and hit Enter
to select the highlighted command.
Set and Read Environment Variables
The Linux environment holds configuration variables used by application programs. These variables are set in the environment by a user or by the system as needed. Knowing how to set environment variables and view them is important, since some Linux application programs may depend on you setting these up properly before running them. For example, the shell inside your terminal uses environment variables to indicate the location of where all the commands are stored. Now let’s see how to set an environment variable. The following example will set the variable MYLAB to a value of 02.
export MYLAB=02
After typing the command in the terminal, you can view the value that was last set by typing:
echo $MYLAB
Notice that you have to put a $
in front of the variable name in order to refer to it.
You can also see your variable among all the others by typing:
env
There are some system environment variables that are defined for you when you open a terminal window, like $SHELL
, $USER
, and $HOME
. You can read some more about environment variables here.
Get Familiar with a Command Line Text Editor
Several text editors are installed on your system, for example, code
, gedit
, nano
, vim
, and emacs
. Some applications can only be run from the command line, while others can be launched graphically by clicking on its icon in the application screen. Choose an editor, and use it to create a new file. Hint: If you are doing this lab SSHed into your Pi Z2W, code
and gedit
will not work because they require a GUI. emacs
can also be terminal based (and is a great option - google the debate between vim
and emacs
) - but will need to be installed before you can use it.
Open a new file in the cloned lab directory using nano
and create a note to yourself. Experiment with deleting text, copying, and pasting. Save the file. Quit out of nano
and type ls -l
to see details about the text file you created.
Shell Challenge
To round out your shell learning experience, you are required to complete the shell challenge. In the lab repo, uncompress the challenge.tar.xz
package; you will want to Google on how to do this. Notice that the file has two layers - the .tar and the .xz. In order to view the contents of the folder you must remove both (this can be done in one command). Inside the resulting directory, complete the various levels of the challenge to finish the lab.
In order to complete this lab, you will need to use Google. If you don’t know how to do something, Google will help you find the answer. You will likely want to search things like:
-
How to uncompress a tar.xz file
-
How to make a script executable in Linux
To ensure this is graded successfully, make sure you commit the decompressed files!
Lab Submission
-
Pass off to a TA by showing the correct output of your
tree
command. Make sure to show hidden folders and files. - Follow the instructions in the README file in the repository to write your own README for this lab. Include your name, section, semester, and lab title. A good README should answer the following questions:
- What is the purpose of this project and its code/files?
- What is the structure/organization of the project files?
- How do you build and run the code in this project?
- To successfully submit your lab, you will need to follow the instructions in the Lab Setup page, especially the Committing and Pushing Files section.