Difference between revisions of "OPS235 Lab 1 - CentOS7"

From CDOT Wiki
Jump to: navigation, search
Line 261: Line 261:
 
# Make certain to log out of your root account and remain as a regular user.
 
# Make certain to log out of your root account and remain as a regular user.
 
# Open a Shell terminal and use a text editor (such as <b><code><span style="color:#3366CC;font-size:1.2em;">vi</span></code></b> or <b><code><span style="color:#3366CC;font-size:1.2em;">nano</span></code></b>) to create a Bash Shell script called: <b><code><span style="color:#3366CC;font-size:1.2em;">report.bash</span></code></b> in your current directory.
 
# Open a Shell terminal and use a text editor (such as <b><code><span style="color:#3366CC;font-size:1.2em;">vi</span></code></b> or <b><code><span style="color:#3366CC;font-size:1.2em;">nano</span></code></b>) to create a Bash Shell script called: <b><code><span style="color:#3366CC;font-size:1.2em;">report.bash</span></code></b> in your current directory.
# Enter the following text content into your text-editing session (or find out an easy way to copy and paste text in Linux from web or instructor):
+
# (or ask instructor for tip to easily copy and paste text in Linux!)<br>
 +
(or find out an easy way to copy and paste text in Linux from web or instructor):
 
<code style="color:#3366CC;font-family:courier;font-size:.9em;margin-left:20px;">
 
<code style="color:#3366CC;font-family:courier;font-size:.9em;margin-left:20px;">
 
<br>
 
<br>

Revision as of 08:02, 25 April 2015


LAB PREPARATION

Purpose / Objectives of Lab 1

The c7host Linux server will run virtualization software to install and run 3 virtual machines (installed in lab2).

You need to install a Linux OS to be a host or "platform" to install and use other Linux VMs (Virtual Machines) during this course.

The Linux OS you will be installing in this lab will be a Host Machine (hostname: c7host) that will allow you to run Virtualization Software to create 3 separate virtual machines (to be performed in lab2). It is important to install this host machine correctly since other labs will depend on the stability of this host machine.


Main objectives:

  • Correctly install the CentOS 7 FULL INSTALL DVD (not LIVE DVD) on your removable hard disk.
  • Record installation characteristics of CentOS 7 FULL INSTALL in a chart (contained in lab2 logbook chart) to compare with other installation methods performed in lab2.
  • Verify correct settings prior to proceeding with host installation stages.
  • Obtain Linux server information after installation to create a software asset report for later access.
  • Disable Linux Kernel security enhancements to allow easier internal networking connections (to be reactivated in a later lab).
  • Observe that Bash Shell Scripts can automate routine tasks.


Minimum Required Materials

CentOS 7FULL INSTALL DVD
Removable Hard Disk Pack (SATA)
USB key
(for backups)
Lab Log Book
(labs 1 & 2)
Idea.png
Access to Instructions for Lab1
Since you will performing a full install on your computer, you cannot use that computer to simultaneously view instructions while you perform the full install. Here are some suggestions to make this process easier:
  • Printout Lab1 instructions at home prior to performing Lab1
  • Use a smart-phone, notebook, or netbook computer to view lab instructions (highly recommended)
  • If lab space availability is not an issue, use another computer termimal to view lab instructions while performing install
  • Follow step-by-step instructions from your OPS235 instructor (if demonstrated by instructor)


My Toolkit (CLI Reference)

Package Management

rpm
yum

System Information

hostname
uname
ps
lsblk

Networking

ifconfig
netstat
route
nslookup

Miscellaneous

grep
wc
pwd
ls
more
file
wget
chmod
scp
vi

Idea.png
Online Hands-on Linux Tutorials (recommended)
The following online tutorial will allow you to practice Linux commands that you learned from ULI101. Login to your Matrix account, and issue the pathnames to run the online tutorial in Matrix:
  • Using the vi Text Editor:
    /home/murray.saul/vi-tutorial
  • Linux Basics:
    /home/murray.saul/linux-basics

INVESTIGATION 1: CREATE HOST MACHINE (c7host)

For the next 3 investigations, you will learn how to install your Centos Full DVD onto your removable hard disk. You will customize your install to setup several separate partitions: root (/), /home, /var/lib/libvirt/images (to store virtual machine images to be created in lab2), and a swap partition. Make certain to record your observations of this install in the comparison chart for c7host in your lab2 logbook.

Part 1: Start Installation

Host Machine Details:
  • Name: c7host
  • Boot media / Installation: CentOS7 Full Install DVD
  • Memory: 16GB
  • Disk space: 250GB (or higher)
  • CPUs: 1
Important.png
You're supposed to use this hard drive only for this course
But if you really need to use it for two courses, and the professor for the other (probably windows) course will allow it - ask your professor for help with partitioning.
comparison chart in lab2 logbook.
The Installation Summary screen provides flexibly when configuring to install on your computer.
  1. Refer to this listing of installation screenshots if you need a reference:
    [ installation screenshots ]
  2. Insert your removable SATA hard disk into the drive tray.
  3. Set your computer's drive selector switch to external (a.k.a position #4).
  4. Power up the computer and insert the CentOS 7 Installation DVD into the DVD drive, then power-off computer.
  5. Restart the computer, and press the function key F10, press ENTER, and specify the device to boot (eg. DVD drive).
NOTE: Refer to the comparison chart in lab2 lab logbook, and fill in various installation information for c7host while you perform the installation (such as time it took to perform a full install, installation options, etc).
  1. Select the option Test this Media & Install Centos7. Your DVD will be checked for defects
  2. If the check is successful, you will be prompted for a language. In the first screen, select language English with subselection English-Canada and then click the Continue button on the bottom right-hand screen.
  3. The Install Summary should now appear. This screen allows the installer to customize their Centos7 system prior to installation.
  4. Configure the following installation settings from the Install Summary Screen:

    DATE & TIME:
    • Click on the Map to select Toronto area (you may also select from the drop-down menu section)
    • Click the DONE button at the top-right corner to finish and return to the Installation Summary screen.

    NETWORK & HOSTNAME:
    • Select the default Ethernet connection and click the button on the right-hand side to change the setting from OFF to ON.
    • At the bottom right-hand corner type the hostname: c7host (all lowercase letters)
    • Review your settings, then click the DONE button at the top-right corner to finish and return to the Installation Summary screen.

    SOFTWARE SELECTION:
    • Select the software packages labelled: Gnome Desktop
    • Click the DONE button at the top-right corner to finish and return to the Installation Summary screen.

  5. Although the Centos installtion program can provide suggestions on how to partition your hard disk, you will be customizing partitions for your hard disk. This custom partitioning is important since it will have consequences on future labs that you perform (especially lab2!).


Part 2: Custom Partitioning

Idea.png
Mount Points and Linux File System Types
Similar to other Operating Systems like windows fat / vfat / ntfs file system types, it is good to know a few common file system types in Linux for comparison:
  • xfs:   Newer filesystem (fast transfer rates for large files, Journaling)
  • ext4:   Newer filesystem supporting large files and Journaling (used in for this lab)
  • ext2:   Stable filesystem popular for databases (no journaling)
Carefully verify partition mount-names and sizes prior to proceeding with install. Check installation screenshots link for verification.
  1. From the installation summary screen, click Installation Destination.
  2. In the installation destination screen, select the destination option: I will configure partitioning and then click Done.
  3. The manual partitioning screen should appear. Change the option New mount points will use the following partition scheme from LVM to Standard Partition (you will not be using LVM for your c7host machine).
  4. If you have used your hard disk for previous Linux (Centos) distributions, you should remove them. Click on the distribution, and for each partition, select the partition and click the remove button (minus sign) and confirm deletion.
  5. It is recommended to rescan the hard disks by clicking on the rescan button (loop symbol).
  6. Before you proceed with creating partitions, let's see the partitions that we need to create for our host computer:
    • Primary Partitions (ext4):
      • 30GB for / (i.e. "root")
      • 40GB for /home
      • 100GB for /var/lib/libvirt/images
    • Swap Partition:
      • 16GB (Note: "swap" must be selected from the drop down menu)

    NOTE: Remember that the sizes are recorded in MB (eg. 30 GB = 30000 MB) and you should multiply GB by a factor of 1024 to get the correct size.
    (eg. 30 GB x 1024 = 30720 MB)

  7. We will now create the root (/) partition. Click on the add button (plus) sign.
  8. In the Add a New Mount Point screen, enter / as the mount-point (either by typing or selecting from drop-down menu), and enter 30720 in for partition size and click Add Mount Point button.
  9. Repeat the same steps above for the /home partition and /var/lib/libvirt/images partition. You need to type the /var/lib/libvirt/images partition since it does not appear in the drop-down menu.
  10. Select each of the created partitions, and make certain that the file-system type is changed from xfs to ext4.
  11. Check that your partition settings are correct (you can ask your instructor or lab monitor to confirm), and then click Done to proceed.
  12. A Summary of Changes screen will appear to show the partitioning operations that will be created. Click the Accept Changes button to proceed with the installation.


Part 3: Completing the Installation

This screen indicates that installation is complete. You should remove the install DVD and confirm Centos7 boots from your removable hard drive.
  1. During the installation process, you will required to create a root password (for administration access) and create a regular user account. Click on Root Password and enter your root password. Think of an appropriate password and record that password somewhere in case you forget! An indicator will appear to show you how secure your password is. Retype your root password and click Done (you may have to click Done twice if your password is strong).
  2. You need to create a regular user account. This account will be used to graphical log into your host machine. It is never recommended to graphically log into a graphical Linux/Unix system as root. It is better to log into a regualr user account, then run a command to login as root (you will learn how to do this later in this lab.
  3. Click User Creation and enter your full name, username, and an appropriate password (and confirm password). Click Done to finish.
  4. Remember to record this host installation information in the comparison chart in lab2.
  5. When installation is complete, you will notice a message at the bottom of the screen stating: CentOS is now successfully installed and ready for you to use!
  6. Click the Reboot button. Your DVD will briefly open in the DVD drive bay. Make certain to remove this installation DVD so that Centos will boot from your hard drive.
  7. After the system reboots, login by clicking on your account name and entering the regular user password.

  8. The last phase of the installation process should now run:
    • Click Accept to confirm you will abide by the License and click Done.
    • Accept defaults to participate running KDump application that will report errors to developers for improvements to Centos7.
    • Select English as the default input source.
    • Quickly view Getting Started Resources, then close the help window.

  9. Proceed to Investigation 2 to obtain basic information from your newly installed Centos Host machine.

Answer Investigation 1 observations (all parts and questions) in your lab log book.


INVESTIGATION 2: OBTAINING HOST MACHINE SYSTEM INFORMATION

Part 1: Obtaining Package Management / Package Information

Important.png
Accessing the Administration Account (root)
Many administrative tasks require the root administrative account. There are many ways to access this administration account:
  • Login: root (enter root password)
  • Switch User to root (without login):
    • su: Remains in regular user's directory, does not run root's startup script(s).
    • su - : Changes to root's home directory (/root) and runs root's start script(s).

Navigate through your Graphical CentOS system, locate and run a terminal program (in order to issue Linux commands). Issue and record the commands used and the output generated in each of the following steps:

  1. Issue the following Linux command: login root
  2. Issue a Linux command (learned in ULI101) to confirm the type of account you are currently using. What is the purpose of this account?
  3. Exit your current account. Which account are you now using?
  4. Refer to the Information box regarding how to access the admin account from the command line.
  5. Issue the command su Issue the pwd and whoami commands to confirm your directory pathname. When finished logout of this account.
  6. Issue the command su - Issue the pwd and whoami commands to confirm your directory pathname. Remain in this account for the remainder of this lab.
  7. An installation log file called /var/log/anaconda/anaconda.packaging.log has been created to record the installation of your c7host machine. This file is an ASCII file which can be viewed with the more command.
  8. You can make use of this file to determine how many packages have been installed: complete the following command to count the number of packages that are labelled "Installing" in the installation log file:
grep ________________ ________________ | wc -l
  1. Using the rpm command: you can also use the following commands to list all the installed packages, and the total number of packages installed:
rpm -q -a
rpm -q -a | wc -l
rpm -qa | wc -l
  1. The -q option means query, and the -a option means all (in other words, query all installed software packages). Did you get the same number of packages from the above two methods?
  2. Some of the files on your system were installed with the software packages, and some were created by system activity (for example, by creating your Learn account and by logging in). If you know the package name (from the install.log), you can list all the files that were installed from the package by using the following command:
rpm -q -l package_name (where "package_name" represents the name of the application or package)
  1. This combines the -q (query) option with the -l (list filenames) option
  2. You can pipe the outupt through wc -l to count the number of lines:
rpm -ql package_name| wc -l
  1. Using what you learned in steps 3, 4, and 7, get a count of the total number of files installed by all of the software packages on your system.


Part2: Obtaining System Information

Important.png
Pathname for USB Stick
The default mount location has been changed in linux distributions newer than CentOS. So while we will get /media/usb-device-name, in newer distributions you'll see /run/media/userloginid/usb-device-name
  1. To find out the name that you have assigned to your Linux system, enter the command: hostname
  2. To find out the kernel version of your GNU/Linux workstation and the date it was created, enter the command:
    uname -rv
  3. To find out all the system processes running on your GNU/Linux workstation, enter the command: ps -ef
  4. We will now collect networking information for your installed system. Your system may not be automatically connected to Seneca's network. Locate the network icon (on top right-hand panel). Click on that icon, and select: system eth0
  5. Open a web-browser and log into Seneca's wired network. You will need to perform this set every time you start a new session with your computer to perform future labs.
  6. Open a shell terminal.
  7. To check the network configuration settings obtained from the DHCP server, run the following commands, describing the output in your log book:
ifconfig
route -n
nslookup (at the > prompt, enter the word "server" (do not type the quotes) and record the output. Type exit to leave nslookup).
  1. Find the following information in the output of the above commands:
MAC address of the ethernet network interface
Subnet mask
The IP address (assigned to you by the DHCP server)
The default gateway
The DNS nameserver
  1. Run the commands hostname, uname -rv, ps -ef, ifconfig, and route -n redirecting the output to add to a file in root's home directory called system.txt.
  2. Copy the installation log file /var/log/anaconda/anaconda.packaging.log and the file system.txt to a USB memory key, or scp to your matrix account as a backup.


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


INVESTIGATION 3: LOOKING AHEAD

Part 1: Disable SELinux and Perform Software Updates

Important.png
SELinux
SELinux stands for Security-Enhanced Linux. It is a component that helps to better secure the system to protect against intrusion (hackers). SELinux is enabled upon the default install of CentOS. SELinux can be a good thing, if you take care of it and know how it works. For this course it is strongly recommended that you disable SELinux by default because we won't have the time to reconfigure it every time the labs make it necessary.
  1. Disabling SELinux is quite simple, just edit the file /etc/selinux/config and set SELINUX to disabled.
  2. Add additional text regarding disabling SELinux.
  3. The CentOS software is updated frequently to add features, fix bugs, and upgrade security. Perform a system update to get the latest versions of the packages installed: Start the Firefox web browser, turn off popup window blocking (select Edit, Preferences, then select the Content tab and uncheck the box to Block Popups), then return to your web-browser, load a page, and when prompted, login to SeneNET.
  4. Open a terminal and type su to start a shell as root. Enter the command yum update This will download and install all of the packages that have been updated since the installation DVD image was created. If you complete this command at Seneca it should run quite fast as Seneca College hosts a CentOS Repository mirror (a copy of all of the current CentOS packages, on a local web server).


Part 2: Automating Routine Tasks (Shell Scripting)

Idea.png
Bash Shell Scripting Tips:

  • She-bang line: #!/bin/bash

    Shell scripts have evolved of the past 40 years. To avoid running a newer shell script on an older shell, it is recommended to force running the shell script in the correct shell. In order to do this, on the first line at the very beginning of the shell script, you add the #! (# as in "shhhh" - a comment, and ! is referred to as "bang" run a commmand: in this case, run the command: /bin/bash). You can issue the Linux command which bash to get the correct location. If there is no bash shell on that machine, the shell script will not run (as a precaution - the Linux admin will know how to make a fix to the shell script if required)
    .
  • Variables:

    There are 3 types of variables that can be used in shell scripting: ENVIRONMENT (eg. $USER), user-defined ($varName), and positional parameters (eg. $1, $2... containing arguments after shell script or by using set command (eg. set $(ls) ). Using dollar sign ($) in front of variable expands the value assigned.

  • Command Substitution:

    A very useful trick to take output from a command to be used as an argument for another command. Examples include:
    file $(ls)
    set $(ls);echo $#;echo $*
    echo "hostname: $(hostname)"

  • Logic Control Flow Statements:

    The test command can be used to see if a condition is true or false
    (i.e. test $USER = "root") . The $? special shell variable stores the result (zero if true, non-zero if false). Square brackets [ ] can be used to represent the test command with the condition inside the brackets (spaces separating brackets).Can use if / if-else / if-elif-else statements with brackets. The exit command can be used to terminate the shell script with a false value.

    Examples

    if [ $USER = "root" ]
    then
     echo "You must be root" >&2
     exit1
    fi

    # For number comparison: use:
    # -gt,-ge, -lt, -le, -eq, -ne

    if [ $age -gt 65 ]
    then
     echo "retire"
    else
     echo "don't retire"
    fi

    if [ $grade -gt 79 ]
    then
     echo "You get Good Mark"
    elif [ $grade -gt 49 ]
    then
     echo "You pass"
    else
     echo "You fail"
    fi

You may have learned about creating and running Bash Shell Scripts in your ULI101 course. Shell scripts help Linux users and system administrators to automatic repetitive tasks to become more efficient and to help them save time. You will be reviewing and building a basic Bash Shell script to generate your newly-installed Linux host machine. Take time to view Shell Scripting Tips on the right-hand side, and run the online tutorial to learn how to create simple shell scripts.

  1. Make certain to log out of your root account and remain as a regular user.
  2. Open a Shell terminal and use a text editor (such as vi or nano) to create a Bash Shell script called: report.bash in your current directory.
  3. (or ask instructor for tip to easily copy and paste text in Linux!)

(or find out an easy way to copy and paste text in Linux from web or instructor):
#!/bin/bash # Forces script to run in the bash shell

# Author: *** INSERT YOUR NAME ***
# Date: *** CURRENT DATE ***
#
# Purpose: Creates system info report
#
# USAGE: ./report.bash

if [ $USER != "root" ] # only runs if logged in as root
then
 echo "You must be logged in as root." >&2
 exit 1
fi

  1. Save your editing session, assign your report.bash file read and execute permissions (at least for the owner) and run by typing: ./report.bash
  2. Did it run? If not what do you think you need to do in order to run the Bash Shell Script?
  3. Issue the command su and run the Bash shell again. Did it work?
  4. Reopen your text-editing session for report.bash and add the following lines of code to the bottom of the shell script file:


# Create report title
echo "SYSTEM REPORT" > /root/report.txt
echo "Date: $(date +'%A %B %d, %Y (%H:%M:%p)')" >> /root/report.txt
echo >> /root/report.txt


  1. Save and run the bash shell script. View the contents of the file called "report.txt" that was generated. Notice how the redirection symbol > is used at the beginning of the report, and then the other redirection symbol >> is used to help "grow" the report with the other content.
  2. The only remaining content of the report would be the system information. We can use a shell scripting trick called "command substitution" $( .. ) in order place results from an command to be used by another command (like echo). Re-edit the shell script and add the following code at the bottom of the shell script file:


echo >> /root/report.txt
echo "Hostname: $(hostname)" >> /root/report.txt
echo >> /root/report.txt
echo >> /root/report.txt
echo "Kernel Version: $(uname -rv)" >> /root/report.txt
echo >> /root/report.txt


  1. Save, run the script, and view the resulting file contents.
  2. Edit the shell script and include output from the ps aux and ifconfig commands (with appropriate titles). Remember to redirect that output to add to the bottom of the file!
  3. Save, run and confirm that the shell script is working correctly.
  4. What would be the use of keeping this shell script as a Linux system administrator?
  1. Here are some more "complex" Bash Shell scripts, that perform the same task. Although you are not require to understand some of these other tricks, it is recommended that you view the contents of the scripts and save them for future consideration or exmaples.
  2. The wget command can be used to quickly download files from the Internet. Issue the following command:
    wget https://scs.senecac.on.ca/~murray.saul/text-report.bash
  3. Verify that the file text-report.bash was downloaded to your current directory.
  4. Assign read and execute permissions for this file by issuing the command: chmod u+rx text-report.bash
  5. Run this Bash Shell script by issuing the command: <b>./text-report.bash
  6. Check to see if it created a report in your current directory. What is the purpose of the report?
  7. Use the vi text editor to view the contents of the file text-report.bash. Can you understand how this script works?

  8. Use the wget command to download, study, and run the following shell scripts on-line:
    https://scs.senecac.on.ca/~murray.saul/report.bash
    https://scs.senecac.on.ca/~murray.saul/report3.bash
  9. Try to understand what these Bash Shell scripts do.
  10. You have completed lab1. Proceed to Completing The Lab, and follow the instructions for "lab sign-off".


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


LAB 1 SIGN-OFF (SHOW INSTRUCTOR)

Students should be prepared with all required commands (system information) displayed in a terminal (or multiple terminals) prior to calling the instructor for signoff.

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

Output of lsblk command showing correct partition names and sizes
Correct IP address and MAC address
Default route (gateway)
DNS name server IP Address
Contents of your report.bash shell script
lab1 notes and first column of Comparison Chart in lab2.

ADDITIONAL PRACTICE

  1. How many packages were installed?
  2. How many files (correct to the nearest hundred) were installed?
  3. How many users were created automatically on your system (regular, admin)?
  4. List 3 ways that you can access your root account
  5. What is the difference between the commands su and su -  ?
  6. What is the home directory for the user "root"?
  7. How do you determine the host name of your GNU/Linux workstation?
  8. What command can display the NIC's MAC address?
  9. What command is used to get a list of running processes on your newly-installed system?
  10. What is the command to copy files to your USB key?
  11. How can Shell Scripts be used to help automate a task performed in lab1?