제01강 : Introduction to Linux Operatiing System (I) Introduction to Linux Operating System Kern Koh Seoul National University 1 Course Description • • • • • • • • • [Linux programming] First part of this course introduces students to the Linux programming. Most Linux manuals are very cryptic and hence needs a gentle introduction. Students will be introduced to the basic knowledge about (not necessarily all the commands themselves) Linux commands, system calls, library and scripts - what feature is provided in each, and where to look for the information about them, etc. [Modern program development environment] The second subject of this lecture is modern "program development environment" and program development productivity. All the modern source codes are stored and distributed in tens and hundreds of directories and files. All these files are combined and linked to make one executable file. Modern computer architecture dictates such modular programming practice. But such programming practise creates a host of new problems during program development. Students are encouraged to understand the reason why such modular programming method is needed. Regular expression and tags file will be taught as a means of helping source code browsing. Make and SCCS commands are explained as a way of managing source codes and as a way of minimizing build time. Other important tools and utilities such as grep, find, ctags etc will be also taught. [Linux Kernel Internal] Third subject of this lecture is Linux kernel internal. This part begins from the kernel overall architecture, several important concepts exported by kernel such as file descriptor, superblock, inode, buffer cache, fsck etc. We will first read UNIX source code then introduce Linux source code. In sum, much emphasis of this lecture is on the practice, not just the theory and concepts of Linux. The students are greatly encouraged to practise a lot of commands, make scripts, manage system, and study source code on Linux platform. All the lab work will be carried 2 out on recent Linux operating system. Following books are recommended as text books and references: Outline • Interface to Operating System – Command, system call, script, daemon – shell variable, IPC, Web, CGI etc • Modern Program Development – make, tags, include, DLL, RPM etc – testing & debugging • UNIX/Linux kernel Internal Design – UNIX – Lion’s book & code – Linux – Love’s book & code • Always have Linux machine on-line besides you – We emphasize practice in this class 3 References (1) If you are a Beginner: o Christian, The UNIX Operating System, 2nd Ed, Wiley. (2) To learn more about Commands: UNIX Power Tools, An O'Reilly & Associates/Random House Book. (3) If you want to be an advanced user o Anderson, The UNIX C Shell Field Guide, Prentice Hall o Newham & Rosenblatt, Learning the BASH shell, O'Reilly (4) For function call interface (library, system calls) Stevens, Advanced Programming in UNIX, Addison Wesley. (5) If you want a textbook about Operating System o Silberschatz et. al., Applied Operating System Concepts, John Wiley & Son (6) For kernel source code o John Lions, Lions' Commentary on Unix : With Source Code, o Robert Love, Linux Kernel Development, Developer’s Library. 4 Homework • Login to Linux machine • Use vi editor and type in C program • We assume you are familiar with C & vi editor. main() { printf(“Hello\n”); } • Name it “Hello.c” • Compile (use “gcc Hello.c”) • Check if a.out is created (use “ls”) • Run it (just say “./a.out”) 5 History of UNIX • UNIX was designed for – Timesharing (Interactive) System • Use terminals (not card reader, printer) • Response time oriented * (not Throughput oriented) • Main use: – Program Development – Office Automation – Multiuser system • Portable OS • by Bell Laboratories (AT&T) * 747 -- throughput oriented (batch -- wait until many arrives) – HW important taxi -- response time oriented (as soon as a customer arrives) --- customer important 6 Portability (移植可能) 1. Every programs needs OS (OS manages HW) 2. Before, hardware was expensive (no IC) 3. OS runs frequently OS must be efficient 4. Code OS with assembler CPU dependent -------------------------------------------------------1. UNIX was coded in C language 2. Unix can be ported to any CPU * (with C**) 3. Unix can talk with any HW(running UNIX) * ** Other OS UNIX No more learning, conversion needed when HW changes. Language porting is easier than OS porting 7 Terminology • utility – command, disk resident part of OS (loaded on demand), – “program”(next page) • kernel – memory resident part of OS, just plain C program. • shell – A special utility. It’s mission is Job Control – reads keyboard input & execute command (interpreter) – UNIX interface to user, • file – “named collection of information” – “sequence of bytes”, no other restrictions (eg record, block) – I/O devices are treated as files (special files, try ls /dev) • standard file – standard output: screen – standard error: error message – standard input: keyboard 8 Software Concept • Hardware supports only 3-level objects: [1] Instruction (機械語) [2] Function (函數) [ADD SUB JUMP …..…] [sin() open() print() ..] • function invocation push a frame into stack return address, local variables, … [3] Process • • • • [binary, a.out, a.EXE,…] eg shell, editor, word, kernel, … Program Image: functions, variables HW resource: keyboard, screen, memory, … SW resource: files, lock, … 9 Terminology (用語) main() Function (函數) printf() sin() Process (a.out, program) STACK 10 • Every SW object -- map to these three [1] Instruction (機械語) [2] Function (函數) [3] Process (program, binary, a.out) Editor game Shell Library System call Daemon (server) Window ftp Tcp/ip Web server macro 11 • Upper/Lower case – ‘Boy’ and ‘boy’ are different in UNIX! • Login – type username, password (multi-user system) – ask system administrator to get them • (shell) prompt – %, $, … – prompt appears “shell is ready to accept next command” • file names – absolute pathname: – relative pathname: /a/b/c starts from root x/y starts from current directory 12 • Suffix .c .h .f .s c source header file fortran source asm source • special characters – – – – kill EOF stop backspace ^c ^d ^s ^h 13 Manual • Manual volumes (1) commands (2) system call (3) library functions • try man cat, man ls – bold –[] – file as it is option name of the file –… repeat • Exercise rm [-fri] file … rm -fr rm -f -r f2 f3 f1 (o) (x) mail [-r][-q][-p][-f file] mail -r -p (o) mail -rp (x) try “man 1 intro”, … , “man 4 intro”, … 14 What are sections 4 - 9 about? $ man cat CAT(1) User Commands CAT(1) NAME cat - concatenate files and print on the standard output SYNOPSIS cat [OPTION] [FILE]... DESCRIPTION Concatenate FILE(s), or standard input, to standard output. -A, --show-all equivalent to -vET -b, --number-nonblank number nonblank output lines -e equivalent to -vE 15 command | sys call | library CAT(1) User Commands CAT(1) NAME cat - concatenate files and print on the standard output One Line Summary [] SYNOPSIS cat [OPTION] [FILE]... FILE … else DESCRIPTION --- option --- file --- repeat --- as it is Try “ whatis cat” Concatenate FILE(s), or standard input, to standard output. -A, --show-all equivalent to -vET -b, --number-nonblank number nonblank output lines -e equivalent to -vE 16 Manual • Manual volumes (1) commands (2) system call (3) library functions • try man cat, man ls – bold –[] – file as it is option name of the file –… repeat • Exercise rm [-fri] file … rm -fr rm -f -r f2 f3 f1 (o) (x) mail [-r][-q][-p][-f file] mail -r -p (o) mail -rp (x) try “man 1 intro”, … , “man 4 intro”, … 17 What are sections 4 - 9? CAT(1) User Commands CAT(1) NAME cat - concatenate files and print on the standard output SYNOPSIS cat [OPTION] [FILE]... DESCRIPTION Concatenate FILE(s), or standard input, to standard output. -A, --show-all equivalent to -vET if you don’t provide file name -b, --number-nonblank number nonblank output lines -e equivalent to -vE 18 man cat • SYNOPSIS – cat [OPTION] [FILE]... • need to provide FILE(s) – read until EOF (ctrl-D is EOF) • What if no FILE is provided? – (standard input standard output) until EOF (ctrl-D is EOF) $ cat 1 (user types) 1 (cat command outputs to screen) 2 (user types) 2 (cat command outputs to screen) ---------- until when? --------------- ctrl-D $ 19 man bash (Command Line Interpreter) • SYNOPSIS bash [options] [file] • bash needs FILE – read until EOF (ctrl-D is EOF) – eg bash FILE (read each line & execute it) – “FILE” is script file (text, whose line is command) – “bash” is interpreter • What if FILE is NOT provided? – bash reads from standard input until EOF (ctrl-D) $ bash $ command1 $ command2 … (ctrl-d) no FILE given. So bash reads from keyboard. user types command1 at keyboard. …. bash continue reading keyboard until EOF bash reached EOF at keyboard. 20 script $ bash hello Now we provide file called hello hello’s content is date date date • hello is an example of script file • Try another thing …. • At the shell prompt, try: $ ./hello bash reads lines in hello, executes • It looks the same as a command • Command can be either (a.out) or (script) • [binary] [text file] 21 • When you know the name of command (function) – man rm – whatis rm (one line summary) • When you don’t know the name of command, but you know what it does – man -k delete – apropos delete Ex apropos concatenate apropos shutdown 22 $ whatis cat cat (1) - concatenate files and print on the standard output $ apropos concatenate cat (1) - concatenate files and print on the standard output ospent (1) - Concatenate entities strcat (3) - concatenate two strings strncat [strcat] (3) - concatenate two strings tac (1) - concatenate and print files in reverse wcscat (3) - concatenate two wide-character strings wcsncat (3) - concatenate two wide-character strings $ 23 Multi-user vs Single-user • Linux • Protection - Yes • Resource – 最大 節約 – Text mode (CUI)* – Total silent • eg vi * CUI: Character User Interface • Windows • Protection - Little • Resource – 最大 使用 – Window, GUI – Shows everything • • • • History State Command Option • eg word …. * GUI: Graphical User Interface 24 User Interface (OS) GUI - Windows CUI - Linux $_ menu active processes (Programs in disk) (loaded into memory) man Command ps Command 25 $ ps -A PID TTY 1 ? 2 ? 3 ? 4 ? 5 ? 6 ? 7 ? 8 ? 9 ? 24 ? | more TIME 00:00:01 00:00:01 00:00:00 00:00:01 00:00:00 00:00:00 00:00:00 00:00:00 00:00:00 00:00:00 CMD init migration/ ksoftirqd/0 migration/1 ksoftirqd/1 events/0 events/1 khelper kacpid kblockd/0 $ ls /bin arch date gettext mkdir ash dd grep mknod ash. static df gtar awk dmesg gunzip more basename gzip mount rview bash doexec hostname mt bash2 igawk mv setfont bsh ipcalc netstat setserial rm touch rmdir tracepath mktemp tracepath6 rvi traceroute traceroute6 sed true umount uname 26 User Interface (editor) CUI – vi GUI - word :_ 27