CSN09101 Networked Services Week 4 : Basic Administration Concepts Module Leader: Dr Gordon Russell Lecturers: G. Russell.

Slides:



Advertisements
Similar presentations
Some history PDP versions BSD/Version 7 split VAX virtual memory implementations End of line 4.4 BSD System V merges Modern versions OSF/1, Solaris, HPUX.
Advertisements

Booting and Shuting Down WeeSan Lee. Roadmap Bootstrapping Boot Loaders Startup/Init Scripts Reboot & Shutdown Q&A.
Chapter 9: Understanding System Initialization The Complete Guide To Linux System Administration.
Booting and Shutting Down the UNIX Operating System Arcadio A. Sincero Jr. 6/6/2001 CMSC 691X, Section 6080.
Cosc 4750 Booting and shutdown. Bootstrapping Starting up a computer, load kernel into memory and begin executing. a vulnerable time, since errors in.
Module 8 - Process Management. 1.Linux boot loader 2.Linux boot process 3.Linux processes 4.Linux services 5.Linux top 6.Remember proc ? 7.Linux Device.
Learning Unix/Linux Bioinformatics Orientation 2008 Eric Bishop.
NETW-240 Shells Last Update Copyright Kenneth M. Chipps Ph.D. 1.
Exploring the UNIX File System and File Security
Introducing the Command Line CMSC 121 Introduction to UNIX Much of the material in these slides was taken from Dan Hood’s CMSC 121 Lecture Notes.
Linux Boot Up Process Bootstrapping –Bootstrapping is the standard term for “ starting up a computer”. During bootstrapping, the kernel is loaded into.
Bootloader / multi-boot
Processes & Daemons Chapter IV / Part III. Commands Internal commands: alias, cd, echo, pwd, time External commands, code is in a file: grep, ls, more.
Laksh mi.  fdisk is an interactive utility to manipulate disk partitions.  Use fdisk –l to review the disks and partitions on the system.  Use fdisk.
A crash course in njit’s Afs
L INUX C OMMAND L INE I NTERFACE G UNAANBAN.G
CS 141 Labs are mandatory. Attendance will be taken in each lab. Make account on moodle. Projects will be submitted via moodle.
Configuring Disk Quotas Linux System Administration To implement disk quotas, use the following steps: Enable quotas per file system by modifying /etc/fstab.
Booting and boot levels
Manage Directories and Files in Linux
Chapter 9 Part II Linux Command Line Access to Linux Authenticated login using a Linux account is required to access a Linux system. The Linux prompt will.
Files & Directories Objectives –to be able to describe and use the Unix file system model and concepts Contents –directory structure –file system concepts.
Guide to Linux Installation and Administration, 2e1 Chapter 8 Basic Administration Tasks.
COSC 4750 Customizing and maintenance. Installing software Redhat/Fedora (and linux in general) has a package installer, called rpm Many programs will.
UNIX Startup and Shutdown CSCI N321 – System and Network Administration Copyright © 2000, 2010 by Scott Orr and the Trustees of Indiana University.
ITI-481: Unix Administration Meeting 3. Today’s Agenda Hands-on exercises with booting and software installation. Account Management Basic Network Configuration.
Day 11 SAMBA NFS Logs Managing Users. SAMBA Implements the ability for a Linux machine to communicate with and act like a Windows file server. –Implements.
Linux Services Muhammad Amer. 2 xinetd Programs  In computer networking, xinetd, the eXtended InterNET Daemon, is an open-source super-server daemon.
INTRODUCTION TO LINUX Jacob Chan. GNU/Linux Consists of Linux kernel, GNU utilities, and open source and commercial applications Works like Unix –Multi-user.
Linux Administration. Pre-Install Different distributions –Redhat, Caldera, mandrake, SuSE, FreeBSD Redhat Server Install –Check HCL –Significant issues.
More on file systems, Booting Todd Kelley CST8177– Todd Kelley1.
ITR3 lecture 6: intoduction to UNIX Thomas Krichel
CIS Lesson 5 Lesson 5 New Skills Boot time GRUB edits (review) Changing BIOS boot order on a VM (review) Mounting CD ISO and floppy Image files on.
Chapter 3 & 6 Root Status and users File Ownership Every file has a owner and group –These give read,write, and execute priv’s to the owner, group, and.
Linux Startup Process Presenter: Dipu Gupta.
CSN09101 Networked Services Week 4 : Basic Administration Concepts Module Leader: Dr Gordon Russell Lecturers: G. Russell, J. Jackson.
User Environments Objectives –to provide appropriate environments for different types of users Contents –different login programs –user profiles –restricted.
Introduction to Programming Using C An Introduction to Operating Systems.
Advanced Programming in the UNIX Environment Hop Lee.
Lesson 3-Touring Utilities and System Features. Overview Employing fundamental utilities. Linux terminal sessions. Managing input and output. Using special.
Linux booting How does it work?. First the bootloader The first step is for the bootloader to run BIOS indicates what devices to examine Bootstrap program.
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.
CSC414 “Introduction to UNIX/ Linux” Lecture 6. Schedule 1. Introduction to Unix/ Linux 2. Kernel Structure and Device Drivers. 3. System and Storage.
Lecture 02 File and File system. Topics Describe the layout of a Linux file system Display and set paths Describe the most important files, including.
The Kernel At a high level, the kernel in an operating system serves as the bridge between applications and the actual data processing of the hardware.
1 CS3695 – Network Vulnerability Assessment & Risk Mitigation – Introduction to Unix & Linux.
File Management commands cat Cat command cat cal.txt cat command displays the contents of a file here cal.txt on screen (or standard out).
System initialization Unit objectives A.Outline steps necessary to boot a Linux system, configure LILO and GRUB boot loaders, and dual boot Linux with.
Linux Tutorial Lesson Two *Getting Help in Linux *Data movement and manipulation *Relative and Absolute path *Processes Note: see chapter 1,2,3 from Linux.
1 C1-UD 6-2 INSTALLING LINUX Academic Year DAI. Credit 1 (Single and Multiuser Operating Systems) Ferran Chic PELE-08/09 (Pla Experimental Llengües.
Linux Administration – Finding You Way on the Command Line The Linux File Directory or Tree.
System Administration Startup Process. Why Care? ● Every process on your system comes about by following a specific chain of events from the machine startup.
Using Linux Kaya Oğuz Room: 310.
Getting Started with Linux
Chapter 11 Command-Line Master Class
Linux Commands Help HANDS ON TRAINING Author: Muhammad Laique
Chapter 9 Router Configuration (Ospf, Rip) Webmin, usermin Team viewer
Andy Wang Object Oriented Programming in C++ COP 3330
Rootly Powers and Controlling Processes
Basic Commands ls cp ls –l (in detail format) echo ls –a
Some Linux Commands.
The Linux Operating System
Securing Network Services
Unix : Introduction and Commands
SUSE Linux Enterprise Desktop Administration
Devices, Linux Filesystems,and the Filesystem Hirarchy standard
A shell is a user interface.
Configuring Disk Quotas
Presentation transcript:

CSN09101 Networked Services Week 4 : Basic Administration Concepts Module Leader: Dr Gordon Russell Lecturers: G. Russell

This lecture Disks The boot process User Management Discussions

Disks and Partitions

Disks /dev/hda – primary disk on first IDE controller /dev/hdb – slave on first IDE controller /dev/hdc – primary disk on second IDE controller /dev/hdd – slave on second IDE controller /dev/sda – lowest numbered SCSI device /dev/sdb – next lowest SCSI device …

Partitions Rather than use the whole disk for one purpose… Split disk up into chunks. The chunks are known as partitions. Partitions can be primary or secondary. This is partially a hang-over from when DOS could only handle 4 partitions…

> sfdisk -l /dev/sda Disk /dev/sda: cylinders, 255 heads, 63 sectors/track Units = cylinders of bytes, blocks of 1024 bytes, counting from 0 Device Boot Start End #cyls #blocks Id System /dev/sda1 * Linux /dev/sda Linux swap / Solaris /dev/sda Linux /dev/sda Empty

> cat /etc/fstab When the system boots the fstab file tells the kernel what filesystems to load UUID=d40d9bef f-bcba-61990e1bf886 / ext4 defaults 1 1 UUID=f9d f-9cc6-553eeb /home ext4 defaults 1 2 UUID=5501a6af-ee7f-4c73-81a7-cf5c75cb8661 swap swap defaults 0 0 # /dev/sda2 swap swap defaults 0 0 tmpfs /dev/shm tmpfs defaults 0 0 devpts /dev/pts devpts gid=5,mode= sysfs /sys sysfs defaults 0 0 proc /proc proc defaults 0 0

Partition identifiers /dev/sda1: UUID="d40d9bef f-bcba-61990e1bf886" TYPE="ext4" /dev/sda2: UUID="5501a6af-ee7f-4c73-81a7-cf5c75cb8661" TYPE="swap" /dev/sda3: UUID="f9d f-9cc6-553eeb685213" TYPE="ext4" > blkid

> df Filesystem 1K-blocks Used Available Use% Mounted on /dev/sda %/ /dev/sda % /boot none % /dev/shm /dev/sda % /home “df –h” is also useful, translating bytes in MB or GB as appropriate…

* UML In UML, there are no IDE or SCSI drives. The disks are called /dev/ubd/n where n is a number They are actually implemented by files in the host operating system, but this is hidden from you. –/dev/ubd/0 is / –/dev/ubd/1 is swap However if you are using the standard QEMU/KVM virtualisation then the drives are the normal /dev/sda1 style devices.

Disk Usage If you want to find out how much disk space a directory is using, the “du” command does this easily. $ du -s /usr/lib /usr/lib $ du -sh /usr/lib 467M /usr/lib “-s” is useful, otherwise it tells you about all subdirectories too. “-h” puts it into human readable form.

Linux Boot Process

Booting to kernel From switch-on: –PC BIOS selects a boot disk –BIOS loads the boot block and executes it. –This loads a stage 1 boot loader. –Stage 1 loads stage 2 loader. –Linux loader (e.g. Grub, lilo) runs –Operator selects from loader menu –Kernel loaded with device ramdisk

> cat /etc/grub.conf default=1 timeout=10 splashimage=(hd0,0)/grub/splash.xpm.gz title Fedora Core ( ) root (hd0,0) kernel /vmlinuz ro root=LABEL=/ rhgb quiet initrd /initrd img title Fedora Core ( ) root (hd0,0) kernel /vmlinuz ro root=LABEL=/ rhgb quiet initrd /initrd img

Init.d Startup Commands As linux boots, it runs various system scripts. Eventually it runs one for your standard “runlevel”. The runlevel startup enables the services (like ssh and apache”) which you may want to start. Such startup scripts all live in: /etc/init.d/ For example, apache is looked after in: /etc/init.d/httpd

/etc/init.d/* The scripts in init.d can: –Start –Stop –Restart –Reload –+ a few others You should not call these scripts directly –This can interfere with different security models in use (such as SELinux). –Instead you need to use the "service" command. Example: sending "start" to the “httpd” control script in init.d is performed as follows: > service httpd start

Run levels The run level determines what init.d files run. As you enter a run level services not running which should run at that run level start. As you leave a run level services which should not be running at the new run level stop. What start and stop are determined by the soft links found in the /etc/rd?.d directories. Usually all we need to know is the stardard runlevel is 5.

> ls /etc/rc5.d K01yum K35vncserver K74ypxfrd S13portmap S80sendmail K05saslauthd K35winbind K89netplugd S14nfslock S90crond K10dc_server K45named K95kudzu S18rpcgssd S90xfs K10psacct K50netdump K96init.cssd S19rpcsvcgssd S95anacron K12dc_client K50snmpd S00microcode_ctl S20random S95atd K12mysqld K50snmptrapd S04readahead_early S25netfs S96init.cssd K20nfs K50tux S06cpuspeed S26apmd S96readahead K24irda K54dovecot S08iptables S28autofs S97messagebus K25squid K70aep1000 S09isdn S44acpid S97rhnsd K34dhcrelay K70bcm5820 S10network S55sshd S99local K34yppasswdd K74ntpd S12syslog S56rawdevices S99mdmonitor K35dhcpd K74ypserv S13irqbalance S56xinetd

S/K priority service-name S99mdmonitor : ls –l /etc/rc5.d/S99mdmonitor lrwxrwxrwx 1 root root 19 Jul 27 13:00 S99mdmonitor ->../init.d/mdmonitor Starts at priority 99 – runs last Start mdmonitor at this runlevel

Link management We used to have to create the soft links ourselves to manage the run levels. This is disgusting! In Redhat, chkconfig does this job. > chkconfig –list mdmonitor mdmonitor 0:off 1:off 2:on 3:on 4:on 5:on 6:off > chkconfig --levels 345 mdmonitor off > chkconfig –list mdmonitor mdmonitor 0:off 1:off 2:on 3:off 4:off 5:off 6:off

Newer service managers One problem with init.d is that it is linear. –Each service is started in turn before the next service starts. There are newer service managers available which use tree dependency models and parallel execution. –Fedora 15 uses systemd. –Still uses init.d for some services –More complex to understand but much faster to boot. –This is still an area under active development

The syslog Clicking on the syslog console output link on the control window finishes with: Starting system message bus: [ OK ] Starting mdmonitor: [ OK ] That confirms mdmonitor was started You can also read this from within linux using the “dmesg” command.

The xinetd super-daemon Some of the services (e.g. sshd) are processes. They start running from an rc script. They wait on their own for comms. They terminate only when the machine does down. Some people say this wastes resources. The super-server concept was born.

XINETD Xinetd waits for requests from the internet. From the requests it works out what program would like to deal with that request. It then starts that program running and gives it the waiting requests. In this way resources are only used if someone actually requests access to a particular service.

The approach of xinetd is not as popular as services started explicitly from init.d. The virtual machines use xinetd to control telnet. If you connect to your VM with telnet, xinetd starts up the telnet daemon for you. Services from xinetd usually start “in.”. Telnet is “in.telnetd” /etc/xinetd.d/ contains all the services it manages.

> cat /etc/xinetd.d/telnet service telnet { flags = REUSE socket_type = stream wait = no user = root server = /usr/sbin/in.telnetd log_on_failure += USERID disable = no }

Terminating a process If you know the process id (the PID) of a program you can terminate it quickly and easily You send it a message (a signal) to tell it to end. The message to end now is called SIGKILL. > ps aux | grep sshd root 1796 …… /usr/sbin/sshd > kill –s SIGKILL 1796

User Management

A wide topic… –Adding/Removing/Changing current users –Default Scripts –Global Scripts

Manual Creation User entries in passwd,shadow, group,gshadow. Home directory in /home. Copy basic.files into their home directory. Make new user own their own directory and files.

> adduser gordon This does all the magic for you. It copies the default.files from /etc/skel/ > ls –a /etc/skel/.bash_logout.bash_profile.bashrc.gtkrc.kde In bash,.bashrc is executed in non-login shell, and.bash_profile in a login shell.

Skel files These files are the basic.files created for a new user. Users are free to edit these when they log in. This allows them to control their own path, env, and other settings (such as aliases). However, if you install a new package which needs something set for each user at login, editing all these copies by hand would be tiresome.

> ls /etc/profile.d colorls.csh gnome-ssh-askpass.csh krb5.csh less.csh vim.csh colorls.sh gnome-ssh-askpass.shkrb5.sh less.sh vim.sh glib2.csh kde.csh lang.csh qt.csh which-2.sh glib2.sh kde.sh lang.sh qt.sh If you log in with bash, all the.sh files are executed before your.files If you log in with csh, all the.csh files are executed before your.files.

> cat /etc/profile.d/vim.sh if [ -n "$BASH_VERSION" -o -n "$KSH_VERSION" -o -n "$ZSH_VERSION" ]; then # for bash, pdksh and zsh, only if no alias is already set alias vi >/dev/null 2>&1 || alias vi=vim fi I.e. if this is bash, and you have not set an alias for “vi”, then set one to run “vim” when you type “vi”.

Example Create a user jim, in group staff But how to set the group? You could do: $ man adduser Usually commands also take the flag “-h” $ adduser –h adduser: invalid option -- h Usage: useradd [options] LOGIN Options: -b, --base-dir BASE_DIR base directory for the new user account … -g, --gid GROUP force use GROUP for the new user account …

$ adduser jim –g staff $ tail -1 /etc/passwd jim:x:502:100::/home/jim:/bin/bash $ grep 100 /etc/group staff:x:100:

$ ls -lnd /home/jim drwx--x--x Mar 27 11:53 /home/jim $ ls -lan /home/jim drwx--x--x Mar 27 11:53. drwxr-xr-x Jul rw Apr 8 14:48.bash_history -rw-r--r Dec planner.zip Moving a uid or gid $ tail -1 /etc/passwd jim:x:502:100::/home/andrew:/bin/bash $ grep 100 /etc/group staff:x:100:

Useful Commands $ chown jim.staff filename $ chown jim filename $ chgrp staff filename

When a User logs in When a user logs in the appropriate. files are executed (.login,.cshrc, etc). If you want to change to a different user, you could log out and log in again, or you could do –su – gordon (change to the gordon user) –su – (change to root) Without the “-”, you still change users, but the. scripts don’t get executed. To go back to the previous user, press CTRL-D

FILE SEARCHING

A file CONTAINING something You are looking for a file containing “gordon” You think it is in /etc/ something $ grep “gordon” /etc/* /etc/group:gordon:x:500: /etc/group-:gordon:x:500: /etc/gshadow:gordon:!!:: /etc/gshadow-:gordon:!!:: /etc/passwd:gordon:x:500:100:Dr Gordon …

A FILENAME containing something You know somewhere in /etc there is a filename with the word “host” in it. $ find /etc –name ‘*host*’ /etc/hosts.deny /etc/ghostscript /etc/ssh/ssh_host_dsa_key.pub Find can find on a range of things, not just names. Other things include sizes, permissions, types, ownership, and combinations of tests.

Find to do something Usually find prints the things which match. You can get it to execute instead. Here you want to find all files called core, and delete them: $ find. -name core -print -exec rm {} \; I didn’t invent the syntax, so don’t blame me…

Discussion A user keeps getting logged out each time they log in… why?

Discussion A user find their ls command is broken… why?

Discussion Here are some past exam questions you should now be able to answer:

Question 1 What is the function of “su”, and what is the difference between “su – gordon" and “su gordon"?

Question 2 What type of files would you expect to find in /sbin?

Question 3 Consider the following line: gordon:x:44: In which file in /etc would you expect to see such a line, and what does it mean?

Question 4 The following commands are typed on a Unix computer. $ mkdir temp $ cd temp/ $ mkdir txt.txt/ $ cd txt.txt/ $ touch hello $ cd.. $ ls *.* What is printed on the screen in response to the last line of the commands?