Booting and Shutting Down the UNIX Operating System Arcadio A. Sincero Jr. 6/6/2001 CMSC 691X, Section 6080.

Slides:



Advertisements
Similar presentations
Introduction to Linux Linux startup process Unix Shells and scripts.
Advertisements

Basic Unix system administration
Linux Boot Loaders. ♦ Overview A boot loader is a small program that exists in the system and loads the operating system into the system’s memory at system.
Booting and Shuting Down WeeSan Lee. Roadmap Bootstrapping Boot Loaders Startup/Init Scripts Reboot & Shutdown Q&A.
Genesis: from raw hardware to processes System booting sequence: how does a machine come into life.
Chapter 9: Understanding System Initialization The Complete Guide To Linux System Administration.
Booting and Halting Chapter 4. Chapter Objectives Examine the sequence of events that occur when a system is booted. Examine the methods used to modify.
Week 8 System Initialization and X Windows. Objectives  Summarize the major steps necessary to boot a Linux system  Configure the LILO and GRUB boot.
Linux+ Guide to Linux Certification Chapter Nine System Initialization.
Linux Booting Procedure
Linux+ Guide to Linux Certification, Second Edition
Linux can be generally divided into four major components: 1. KERNEL – OS, ultimate boss The kernel is the core program that runs programs and manages.
Booting the Linux Kernel Dr. Michael L. Collard 1.
Linux+ Guide to Linux Certification, Third Edition
Linux+ Guide to Linux Certification, Second Edition
Booting And Shutting Down. Bootstrapping  Bootstrapping is standard term for “starting up a computer”  During bootstrapping the kernel is loaded into.
 Starting up a computer › Load kernel into memory and execute it. (1)BIOS load and run the MBR (Master Boot Record) (2)MBR searches for the bootable.
Startup and Shutdown1-1 Booting and Shutting Down  Bootstrapping m The computer must pull itself up m Automatic and manual booting m Steps in the boot.
Linux+ Guide to Linux Certification, Second Edition Chapter 3 Linux Installation and Usage.
Linux Boot Up Process Bootstrapping –Bootstrapping is the standard term for “ starting up a computer”. During bootstrapping, the kernel is loaded into.
1 Web Server Administration Chapter 3 Installing the Server.
Starting and Stopping Linux. Boot Process BIOS initializes hardware –Loads the boot sector MBR loads the bootloader –Point to kernel Kernel initializes.
Processes & Daemons Chapter IV / Part III. Commands Internal commands: alias, cd, echo, pwd, time External commands, code is in a file: grep, ls, more.
Va-scanCopyright 2002, Marchany Unit 4 – The Boot Process Randy Marchany VA Tech Computing Center.
System Startup and Shutdown
UNIX Startup and Shutdown CSCI N321 – System and Network Administration Copyright © 2000, 2012 by Scott Orr and the Trustees of Indiana University.
Linux+ Guide to Linux Certification, Third Edition
CompTIA Linux+ Certification
Linux+ Guide to Linux Certification Chapter Three Linux Installation and Usage.
Booting and boot levels
Linux Booting Procedure
Guide to Linux Installation and Administration, 2e1 Chapter 3 Installing Linux.
System Startup & Shutdown Objectives –to interpret the Unix startup and shutdown configuration files –to be able to create a customised run level Contents.
1 Linux Basics for Networking. 2 Module - Linux Basics for Networking ♦ Overview This module focuses on the basics of networking using Redhat Enterprise.
2/19/2003 Lecture 3 Computer System Administration Lecture 3 Setup (continued)
UNIX Startup and Shutdown CSCI N321 – System and Network Administration Copyright © 2000, 2010 by Scott Orr and the Trustees of Indiana University.
Guide to Linux Installation and Administration, 2e1 Chapter 2 Planning Your System.
Linux Administration. Pre-Install Different distributions –Redhat, Caldera, mandrake, SuSE, FreeBSD Redhat Server Install –Check HCL –Significant issues.
IT2204: Systems Administration I 8b).Booting (Supplementary Notes)
Guide to Linux Installation and Administration1 Chapter 4 Running a Linux System.
System Startup & Shutdown
UNIX (Linux) Introduction Module-1. OS Kernel In computing, the kernel is the central component of OS. It is a bridge between applications and the actual.
ITI Chris Uriarte ITI-481: Unix Administration Meeting 2 Rutgers University Center for Applied Computer Technologies Chris Uriarte, Instructor.
INFO 320 Server Technology I Week 4 Basic Unix commands 1INFO 320 week 4.
Linux Startup Process Presenter: Dipu Gupta.
Genesis: From Raw Hardware to Processes Andy Wang Operating Systems COP 4610 / CGS 5765.
Runlevel initialization. Boot to Linux Grub interface.
UNIX Startup and Shutdown CSCI N321 – System and Network Administration Copyright © 2000, 2009 by Scott Orr and the Trustees of Indiana University.
Unix System Administration Booting and Shutting Down Chapter 2.
IT Essentials 1 v3 Module 4 JEOPARDY IT Essentials 1 RouterModesWANEncapsulationWANServicesRouterBasicsRouterCommands RouterModesWANEncapsulationWANServicesRouterBasicsRouterCommands.
Sys Admin Course Service Management Fourie Joubert.
Lecture 4 & 5: System Architecture  File systems  Devices  File system permissions  Review of Linux runlevels  In-class exercise.
System initialization Unit objectives A.Outline steps necessary to boot a Linux system, configure LILO and GRUB boot loaders, and dual boot Linux with.
Overview A) Power on or reset B) 1st stage boot loader C) 2nd stage boot loader D) Operate system.
Linux Introduction Linux was developed in the early 1990’s by Linus Torvald computer science student at the University of Helsinki Linux is distributed.
Chap- 2 BOOTING & SHUTDOWN LINUX SYSTEM Created by: Asst. Prof. Ashish Shah, J.M.PATEL COLLEGE, GOREGOAN W 1.
The Linux startup process Jerry Feldman The Linux Expertise Center Hewlett-Packard Company Document produced via OpenOffice.org.
System Administration Startup Process. Why Care? ● Every process on your system comes about by following a specific chain of events from the machine startup.
The Linux Kernel About 6 million lines of code
Chapter 8 Unix & Linux.
Chapter Objectives In this chapter, you will learn:
Guide to Linux Installation and Administration, 2e
Booting Up and Shutting Down
Chapter 2: System Structures
Linux Start Sequence Summary
Structure of Unix OS.
OPS235: Week 1 Installing Linux (Lab1: Investigations 4 - )
SUSE Linux Enterprise Desktop Administration
Objectives Topic 2.6 Understanding the boot process
Presentation transcript:

Booting and Shutting Down the UNIX Operating System Arcadio A. Sincero Jr. 6/6/2001 CMSC 691X, Section 6080

Booting UNIX: Loading the Kernel. Most systems, particularly PCs, implement a two-stage loading process: Most systems, particularly PCs, implement a two-stage loading process:  The system BIOS loads a small boot program.  This small boot program in turns loads the kernel. On PCs, this small boot program exists within the first 512 bytes of the boot device. This 512-byte segment is called the Master Boot Record. The MBR is what loads the kernel from disk. On PCs, this small boot program exists within the first 512 bytes of the boot device. This 512-byte segment is called the Master Boot Record. The MBR is what loads the kernel from disk. A popular boot loader used by most Linux distributions to boot Linux is called LILO. A popular boot loader used by most Linux distributions to boot Linux is called LILO.  LILO can also be used to boot other operating systems as well such as MS-DOS, Windows 98 and Windows NT.

Booting UNIX: Loading the Kernel (continued) LILO can be installed to either the MBR or to the boot record of the Linux root partition. LILO can be installed to either the MBR or to the boot record of the Linux root partition.  Install to the boot record instead of the MBR to use another boot loader for another OS which does not know how to boot Linux itself.  For example, say that you want to have both Windows NT and Linux on the same box and you want to dual boot between them. You can have NT’s boot loader installed to the MBR and add the option to boot Linux to it’s boot menu. If the user elects to boot Linux, NTLOADER will then pass control to LILO which will in turn load the Linux kernel.

Booting UNIX: Loading the Kernel (continued) LILO’s configuration file is “/etc/lilo.conf”. More information on how to configure LILO can be had from reading lilo.conf’s man page (man lilo.conf). LILO’s configuration file is “/etc/lilo.conf”. More information on how to configure LILO can be had from reading lilo.conf’s man page (man lilo.conf). Other boot loaders which can be used to load Linux exist: Other boot loaders which can be used to load Linux exist:  GRUB – a more robust boot loader which sports nifty features such as being able to download a kernel off a network fileserver and boot that instead of the kernel which lives on the local harddisk.  LOADLIN – a boot loader which can be used to boot a Linux kernel from an MS-DOS command line.

Booting UNIX: Loading the Kernel (continued) FreeBSD has something similar to LILO for loading it’s kernel. It consists of two parts: one which lives in the MBR (see man boot0cfg) and another part which lives in the FreeBSD root partition (see man disklabel). FreeBSD has something similar to LILO for loading it’s kernel. It consists of two parts: one which lives in the MBR (see man boot0cfg) and another part which lives in the FreeBSD root partition (see man disklabel). UNIX and UNIX-like systems for non-PC hardware typically follow a straightforward (but usually proprietary and system specific) scheme for booting their kernels. UNIX and UNIX-like systems for non-PC hardware typically follow a straightforward (but usually proprietary and system specific) scheme for booting their kernels. The kernel itself is a program that usually lives in the root partition of the UNIX filesystem. Most Linux distributions call it “/vmlinuz” and it often a symbolic link to the real kernel file which lives in “/boot”. Other UNIX and UNIX-like systems may call it “/unix”, “/vmunix”, or “/kernel”. The kernel itself is a program that usually lives in the root partition of the UNIX filesystem. Most Linux distributions call it “/vmlinuz” and it often a symbolic link to the real kernel file which lives in “/boot”. Other UNIX and UNIX-like systems may call it “/unix”, “/vmunix”, or “/kernel”.

Booting UNIX: Hardware Initialization After the kernel is brought in from disk into main memory, it begins execution and one of the first things it does is initialize the system’s hardware. After the kernel is brought in from disk into main memory, it begins execution and one of the first things it does is initialize the system’s hardware. All those cryptic messages you see fly by when the Linux kernel first starts up are messages from the compiled-in kernel drivers initializing and configuring your hardware. All those cryptic messages you see fly by when the Linux kernel first starts up are messages from the compiled-in kernel drivers initializing and configuring your hardware.  Other UNIX and UNIX-like systems do something similar. Sometimes the kernel needs help in configuring your hardware. Information such as IRQ, DMA, and I/O base addresses need to be specified to the kernel. With Linux these can be specified via it’s “command line”. Sometimes the kernel needs help in configuring your hardware. Information such as IRQ, DMA, and I/O base addresses need to be specified to the kernel. With Linux these can be specified via it’s “command line”.  The BootPrompt-HOWTO has more information about the Linux command line. This can be had from

Booting UNIX: The init Process. The first program the kernel attempts to execute after basic system initialization is complete is called init. The first program the kernel attempts to execute after basic system initialization is complete is called init. The init process is the mother of all processes running on a UNIX system. If this process dies, so does the system. The init process is the mother of all processes running on a UNIX system. If this process dies, so does the system. init’s job after basic system initialization is complete is to take over the system start-up procedure and complete the system bootstrap process. init’s job after basic system initialization is complete is to take over the system start-up procedure and complete the system bootstrap process. The actual program which the Linux kernel executes as the init process can be specified via the “init” command line parameter. For example, to start bash instead of init, you can specify “init=/bin/bash” on the Linux command line. (see BootPrompt-HOWTO for details.) The actual program which the Linux kernel executes as the init process can be specified via the “init” command line parameter. For example, to start bash instead of init, you can specify “init=/bin/bash” on the Linux command line. (see BootPrompt-HOWTO for details.)

Booting UNIX: Startup Scripts The system start-up scripts are executed by init when the system starts up and it is these scripts which are responsible for completing the bootstrap process of the UNIX system. The system start-up scripts are executed by init when the system starts up and it is these scripts which are responsible for completing the bootstrap process of the UNIX system.  For those familiar with MS-DOS, this is similar to the AUTOEXEC.BAT facility of that operating system although it is much more complex on UNIX. In general there are two styles of system start-up scripts: In general there are two styles of system start-up scripts:  The System V style: used by most UNIX and UNIX-like operating systems today including Solaris, HP-UX and most distributions of Linux.  The BSD style: used by the various flavors of BSD (FreeBSD, NetBSD, OpenBSD, BSDi) and Slackware Linux.

Booting UNIX: Startup Scripts – System V Style All start-up scripts are typically kept in a directory named init.d which usually lives somewhere under “/etc”. All start-up scripts are typically kept in a directory named init.d which usually lives somewhere under “/etc”.  Red Hat Linux places this directory under “/etc/rc.d”.  HP-UX places this directory under “/sbin”. Each start-up script can usually accept at least two command line arguments: start and stop. Each start-up script can usually accept at least two command line arguments: start and stop.  start tells the script to start whatever it is that script is responsible for.  stop tells the script to stop whatever it is that script is responsible for.

Booting UNIX: Startup Scripts – System V Style (continued) A run-level is a state that the UNIX system can be in that specifies what the system should be doing and what services it should be providing. A run-level is a state that the UNIX system can be in that specifies what the system should be doing and what services it should be providing. The SysV init program defines 7 standard run-levels: The SysV init program defines 7 standard run-levels:  0: complete system shutdown  1 or S: single-user mode  2 through 5: multi-user modes  6: shutdown and reboot

Booting UNIX: Startup Scripts – System V Style (continued) Each run-level gets its own directory and is usually under “/etc”, but sometimes can be found under “/sbin” on some systems. This directory follows the naming convention of rcn.d where n is the run- level, i.e. scripts for run-level 2 would be found under a directory named rc2.d. Each run-level gets its own directory and is usually under “/etc”, but sometimes can be found under “/sbin” on some systems. This directory follows the naming convention of rcn.d where n is the run- level, i.e. scripts for run-level 2 would be found under a directory named rc2.d. This directory contains scripts which are executed when that run-level is entered. This directory contains scripts which are executed when that run-level is entered.  While this directory can contain actual scripts, it usually consists of symbolic links to real scripts which lives under the init.d directory. Scripts in the run-level directory are executed in alphanumeric order and if the script name begins with a “S” the script is passed the “start” command line parameter and if it begins with a “K” it is passed the “stop” command line parameter. Scripts in the run-level directory are executed in alphanumeric order and if the script name begins with a “S” the script is passed the “start” command line parameter and if it begins with a “K” it is passed the “stop” command line parameter.

Booting UNIX: Startup Scripts – System V Style (continued) Example: Example:  Suppose we have the following symbolic links in the directory “/etc/rc2.d” which is the run-level directory for run-level 2:  /etc/rc2.d/K01service4 - > /etc/init.d/service4  /etc/rc2.d/K10service3 -> /etc/init.d/service3  /etc/rc2.d/S10service1 -> /etc/init.d/service1  /etc/rc2.d/S25service2 -> /etc/init.d/service2  The scripts in “/etc/init.d” will then be executed in the following order: service4, service3, service1 and then service2. They are executed in this order because the scripts in the run-level directory are executed in alphanumeric order according to their name.  Scripts that start with the letter “K” are passed the “stop” parameter while scripts that start with the letter “S” are passed the “start” parameter.

Booting UNIX: Startup Scripts – System V Style (continued) SysV init’s configuration file is “/etc/inittab”. This file tells init what script it should run for each run-level. SysV init’s configuration file is “/etc/inittab”. This file tells init what script it should run for each run-level.  A common way to implement the SysV style start-up procedure is to have init execute some master control script passing to it as an argument the run-level number. This script then executes all of the scripts in that run-level’s script directory. For example, for run- level 2, init may execute the script “/etc/init.d/rc” passing it the argument “2”. This script in turn would execute every script in run-level 2’s script directory “/etc/rc2.d”.

Booting UNIX: Startup Scripts – BSD Style The BSD style is much more simpler than the SysV style. Basically on system start-up, BSD’s init executes the script “/etc/rc” and on system shutdown it executes the script “/etc/rc.shutdown”. The BSD style is much more simpler than the SysV style. Basically on system start-up, BSD’s init executes the script “/etc/rc” and on system shutdown it executes the script “/etc/rc.shutdown”. To keep things modular, these scripts in turn usually execute other scripts which are responsible for a single component of the start-up or shutdown procedure. For example, “/etc/rc” might execute the script “/etc/rc.network” which would be responsible for configuring the networking environment on system start-up. To keep things modular, these scripts in turn usually execute other scripts which are responsible for a single component of the start-up or shutdown procedure. For example, “/etc/rc” might execute the script “/etc/rc.network” which would be responsible for configuring the networking environment on system start-up.

Booting UNIX: Single User Mode Single-user mode is a special administrative mode that usually starts the system with a minimal configuration. For example, no system daemons are started and extra filesystems may not be mounted. Single-user mode is a special administrative mode that usually starts the system with a minimal configuration. For example, no system daemons are started and extra filesystems may not be mounted. Single-user mode is typically used to repair a broken system such as fscking a sick filesystem which cannot be repaired by the automatic fscking procedure. Single-user mode is typically used to repair a broken system such as fscking a sick filesystem which cannot be repaired by the automatic fscking procedure. Entering single-user mode varies from system to system, but it usually involves specifying to init a special flag before the system starts up. Entering single-user mode varies from system to system, but it usually involves specifying to init a special flag before the system starts up.  This can be done in Linux by specifying the parameter “single” on the LILO boot prompt. On SysV-ish systems, single user mode can also be entered by telling init to enter run-level 1 or S. This can be done via the telinit command. On SysV-ish systems, single user mode can also be entered by telling init to enter run-level 1 or S. This can be done via the telinit command.

Shutting Down UNIX UNIX systems have to be gracefully powered down. You cannot just shut the system off. This can damage the system. UNIX systems have to be gracefully powered down. You cannot just shut the system off. This can damage the system. The typical way to shutdown the UNIX system is to use the shutdown command. shutdown allows the system administrator to broadcast a message to all currently logged in users that the system is about to be shutdown. The exact syntax of the shutdown command tends to vary from system to system. Check shutdown’s man page for details. The typical way to shutdown the UNIX system is to use the shutdown command. shutdown allows the system administrator to broadcast a message to all currently logged in users that the system is about to be shutdown. The exact syntax of the shutdown command tends to vary from system to system. Check shutdown’s man page for details.

Shutting Down UNIX (continued) Other commands which can be used to shut down the system are halt, reboot, and init: Other commands which can be used to shut down the system are halt, reboot, and init:  halt and reboot perform the same procedures as shutdown except it doesn’t broadcast a message to all currently logged in users. reboot even goes a step further by causing the system to reboot after shutdown procedures are complete.  You can also get the system to shutdown by sending the init process a TERM signal using the kill command. On SysV-ish systems this usually causes the system to switch to either run-level 0 (halt) or run-level 6 (reboot). On BSD systems this causes the “/etc/rc.shutdown” script to be executed which handles the shutdown procedures for the system.