OPS235 Lab 3 - CentOS7

From CDOT Wiki
Revision as of 11:31, 3 April 2015 by Msaul (talk | contribs)
Jump to: navigation, search


LAB PREPARATION

Purpose / Objectives of Lab3

In this lab, you are going to help conserve disk space by learning how to compress and decompress files that are stored on your computer server. In addition, you will learn alternative methods of how to install programs.

Topics include:

  1. Learning to troubleshoot some common problems after installing VMs
  2. Creating and using archive files (tar and tar.gz)
  3. Compiling software packages from source code
  4. Install applications using various methods:
  • Decompressing source code archive, and compiling source code
  • Use yum utility to install software from local programs (on DVD drive)
  • Use yum utility to install software from repositories (online storage areas)
  1. Demonstrating the use of Bash Shell scripts to automate routine tasks


Minimum Required Materials

CentOS7
FULL DVD
Removable Hard Disk Pack (SATA)
USB key
(for backups)
Lab3 Log Book

My Toolkit (CLI Reference)

Archiving / Compiling:

tar
gzip, gunzip
make

Software Manangement:

rpm
yum

Commands

ls
more
wget
chmod
vi

Idea.png
Online Linux Command Review
The following links will allow you to practice Linux commands that you learned from ULI101:
  • Bash Shell Scripting II: [ ]


INVESTIGATION 1: TROUBLESHOOTING SOME COMMON PROBLEMS

There are a few "classic problems" that students can encounter with their virtual machines and their host machine after performing lab2. Although all OPS235 students may not encounter these problems, it is good to be aware of them and know how to troubleshoot a problem in order to solve the problem.

A few common problems are:

  • I Can't boot into Graphical Mode on my c7host
  • I Forgot My Regular User Password
  • I Forgot My Root Password
  • I Can't Start My Virtual Machine
  • I Can't start my host machine

Process of Elimination: Find What It Is by Knowing What It Isn't

Troubleshooting consists of 3 basic elements:

  • Asking Questions (eg. what was done recently prior to problem?)
  • Eliminating what the problem isn't
  • Tenacity and patience (ability to focus on finding the cause of the problem)

If you cannot log graphically into your machine (first 3 common problems), there is a trick to boot your system into "single-user" mode. This mode does not provide networking, graphics, or logging in as other regular users, but can connect to a text-based interface as root. This method will only work if a GRUB (Grand Unified Boot-loader) password has not been set, or that you haven't forgotten the GRUB password.

Steps to Boot into "Single-User Mode":

  1. Boot-up your c7host. As soon as the Grub Boot menu appears, press the letter e (for "edit").
  2. Press the down arrow key to highlight:


Problem #1:

Problem #2:

Problem #3:

INVESTIGATION 2: ARCHIVING FILES

Part 1: Creating a File Archive

  1. Perform this part on your centos3 machine.
  2. Boot up your centos3 VM.
  3. Change your working directory to /usr/share/doc/sudo*
  4. Use the tar (tape archiver) command to create an archive file named /tmp/archive1.tar
    • tar cvf /tmp/archive1.tar .


Important.png
Warning!
Don't miss the . at the end of the tar commands below! It specifies what should go into the archive: the contents of the current directory.
  1. What do the options c, v, and f mean?
  2. Record the archive file size.
  3. Compress the file using gzip:
    • gzip /tmp/archive1.tar
  4. Record the archive file size after compression.
  5. Make sure you're still in /usr/share/doc/sudo* and then create a compressed archive:
    • tar cvzf /tmp/archive2.tgz .
  6. What does the z option do?
  7. Compare the sizes of /tmp/archive1.tar.gz and /tmp/archive2.tgz</code></b>. Why are they so close in size?
  8. </ol>

    Answer the Part 1 observations / questions in your lab log book.

    Part 2: Restoring Files From an Archive

    1. This section is to be performed in your centos3 VM.
    2. Create the directory /tmp/extract1
    3. Change to the /tmp/extract1 directory.
    4. Move the file archive1.tar.gz to your current directory.
    5. Unzip the first archive you created:
      • gunzip archive1.tar.gz
    6. Extract the files from the first archive:
      • tar xvf archive1.tar
    7. Are all the files there?
    8. Compare /tmp/extract1/README and /usr/share/doc/sudo*/README</code></b>. Are they exactly the same? Why?
    9. Create the directory /tmp/extract2
    10. Move the file archive2.tgz to the /tmp/extract2 directory.
    11. Extract the files from the second archive:
      • tar xvzf /tmp/extract2/archive2.tgz
    12. Note that this time a separate gunzip command was not needed. Why?
    13. Repeat the previous command, leaving out the option "z". Does it work? Why?
    14. Compare the README file in this directory with the original file. Are they exactly the same?

    Answer the Investigation 2 observations / questions in your lab log book.


    Part 3: Practical Application - Compiling Source Code from Archive File

    Now that you know how to create and decompress "zipped tarball archives", we will demonstrate how to install applications from websites containing these types of archives. Although this method is not as "user-friendly" as using the yum or rpm command, this method is useful if the application is NOT contained in regular software repositories...


    In order to build software from source code, you must have the appropriate software development tools (such as make and gcc) and libraries (such as GTK) installed. The required tools will vary depending on the computer languages used in the software being built.

    1. Part is to be performed in your centos2 VM.
    2. Issue the following command to install a basic set of development tools and libraries:
      yum groupinstall "Development Tools" "Development Libraries"


    Note.png
    Installing Development Libraries
    In the future, remember the above procedure whenever installing software from source. Sometimes, you need to install additional tools or libraries in order to compile a particular software package
    1. Go to the directory /tmp
    2. Use the wget command to download the "tar ball" that contains the source code for the NLED text editor. wget is a command-line tool to download files from the web using the http or ftp protocols.
    3. Extract the files. Change to the newly-extracted directory (/tmp/nled-2.52)
    4. Check to see if there is a file named configure. If so, run it; if not, skip this step. (Most but not all source code archives contain this file)
    5. Check to see if there is a file named Makefile or makefile. If so, type the command:
      • make
      • Did the command work? Why? Use the yum command to install the package gcc. What do you think the package gcc does?
    6. Reissue the make command. Where you successful? What does make do?
    7. Issue the command as root: yum list ncurses. What do you see? Issue the command at root: yum search ncurses. What do you observe?
    8. In this case, you need to install the ncurses development libraries as well. Issue the following command as root: yum install ncurses-devel.x86_64. Now issue the command: make
    9. Some software distributed as source code can automatically install itself. Try this command:
      • make install
    10. Most but not all source code archives include the capability of installing themselves this way.
    11. If the command make install does not work (how can you tell? What command did you learn from ULI101 to confirm that this command cannot be run from the command line?), copy the nled program manually:
      • cp nled /usr/local/bin
    12. Test nled to make sure it works.
    13. Why did copying the nled executable to /usr/local/bin allow the nled command to be run by name anywhere in the command prompt?

    Answer the Investigation 3 observations / questions in your lab log book.

    INVESTIGATION 3: Using the Yum Command for Local & Repository Installs

    Part 1: Install and Remove Software with Yum

    Note.png
    Internet Connection
    In order for yum to work you require a connection to the Internet. Establish this connection by using the browser to log into SeneNET
    1. Change to your home directory.
    1. Issue the command: yum install elinks and answer y to the question about installation.
      1. Where did yum get the elinks software?
      2. Why could yum install elinks when rpm couldn't?
    2. Issue an RPM query to verify that elinks is installed. Record this command in your lab log-book.
    3. Issue the command: yum remove elinks
    4. Issue an RPM query to verify that elinks is no longer installed. Record this command in your lab log-book.
    5. Issue this command: yum info cups
    • Based on the result, do you think that cups is a useful package for your system? If not, try removing it.
    1. Unused and unneeded software can present a security risk and ties up disk space needlessly. Find at least 4 other packages (for example: games, sound & video, etc) that you're not using on your system, and remove them. Be careful to ensure that removing those packages does not also remove other software that you do need.

    Answer the Investigation 3 observations / questions in your lab log book.

    Part 2: Managing Repositories with Yum

    ADD THIS SECTION

    INVESTIGATION 3: LOOKING AHEAD

    Part 1: Automating Routine Tasks (Shell Scripting)

    Idea.png
    Bash Shell Scripting Tips:

    • Manipulating Text:

    • Examples (try in a shell script)


    1. x

    Answer all observations / questions in your lab log book.

    LAB 3 SIGN-OFF (SHOW INSTRUCTOR)

    Important.png
    Time for a new backup!
    If you have successfully completed this lab, make a new backup of your virtual machines.

    Arrange evidence for each of these items on your screen, then ask your instructor to review them and sign off on the lab's completion:

    Archived files created
    Unnecessary/unused packages have been deleted (list at least 4, and show that they are no longer installed).
    2 packages installed with yum command
    1 repository added for yum
    License of the nautilus package


    Preparing for Quizzes

    1. What is the advantage of disabling services such as bluetooth?
    2. What is the difference between a .tgz file and a .tar.gz file? What do these stand for?
    3. What is the purpose of a repository?
    4. What is source code?
    5. How do you build software from source code?
    6. Which is preferred: installing from an RPM file, or installing from source code? Why?
    7. How do you use service/init/chkconfig to:
      • show/set current runlevel
      • list services
      • stop a service
      • start a service
      • Why is it important to learn how to manage services?
      • Why is it important to stop certain services?