새소식

반응형
CS 지식/시스템프로그래밍

[시스템프로그래밍] 1장. Unix와 Linux 소개

2023.11.07
  • -
반응형

Unix/Linux

학습 목표 및 내용

  • 학습 목표
    • 유닉스/리눅스 시스템의 체계적 이해
    • 시스템 프로그래밍 능력 향상
  • 학습 내용
    • 리눅스 시스템 프로그래밍
      • 시스템 호출을 이용한 C 프로그래밍
  • 주요 프로그래밍 주제
    • 파일
    • 프로세스
    • 메모리
    • 프로세스 사이의 통신(IPC)

 

System Programming

컴퓨터의 정의

  • 프로그램(명령어들의 리스트)에 따라 데이터를 처리하는 기계
  • 계산기: 특수 목적 컴퓨터(정해진 기능만을 수행, 기능 변경 불가능)
  • 노트북, 데스크 탑: 범용 컴퓨터(프로그램이라는 개념 도입, 수행 기능 변경 가능)

 

프로그램

  • 작업 지시서(instructions이 나열된 것)
  • 컴퓨터에게 해야 할 작업의 내용을 알려주는 문서
  • A sequence of steps(instructions): 명령 단계의 순서
  • 각 step에서는 arithmetic(산술) 혹은 logical(논리) operation이 수행된다.

 

von Neumann Architecture(매우 중요)

대부분의 컴퓨터는 폰노이만 구조를 따르고 있음.

  • Stored Program concept
    • program과 data를 저장하는 main memory
      • instructions과 data가 single read-write memory에 저장된다.
      • program과 data는 main memory에 탑재되어야 실행 가능.
    • 메모리의 내용은 location(주소)에 의해 addresable(접근가능)하다.
      • 그곳에 포함된 데이터의 종류와는 상관없이
    • Execution(실행)은 그 순서가 명시적(explicitly)으로 수정(modified)되지 않는다면 순서대로 발생한다. 
      • Sequence, Loop, Selection
      • 위 세가지로 어떤 프로그램이든 설명 가능하다.
      • Sequence: 첫 번째 instruction을 실행하고 두 번째 instruction을 실행하고 순차적으로 실행
      • Loop와 selection이 아닌 경우 sequential하게 실행됨
      • Loop와 selection이 explicitly modified 된 것이라고 할 수 있음

 

  • Structure of von Nuemann machine

  • main memory는 data와 instructions을 모두 저장한다.
  • binary data에 대해 연산하는 ALU
  • 메모리의 명령어를 해석하고 실행하는 Control unit  
    • decode(해석) 과정
  • control unit에 의해 작동되는 Input/output equipment(장비)

ALU와 control unit이 합쳐진 것이 CPU이다.

 

Instruction Cycle

  • Two steps이 존재:
    • Fetch: 다음에 실행할 instruction을 메인 메모리에 가져오는 과정.
    • Execute: 메인 메모리에 가져온 instruction의 실제 실행을 하는 과정.

첫 번째 instruction cycle이 실행 되면 fetch와 execute 과정이 이루어 지는 것이다.

 

CPU의 핀 중 하나는 Interrupt(방해)라는 것을 걸 수 있는데 이 핀이 cycle 중간에 active high가 되더라도 그 즉시 check하는 것이 아니라 한 instruction 사이클이 끝나고 다음 사이클을 다시 시작하기 직전에 잠깐 확인한다.

 

이렇게 똑같은 Instruction Cycle 구조를 갖고 있음에도 불구하고 여러 프로그램의 behavior가 각각 다른 이유는 프로그램 각자의 instruction 순서가 다르기 배치 되어있기 때문이다.

 

Fetch&Execution Cycle

  • Program Counter(PC)가 다음에 실행(fetch)할 instruction의 주소를 갖고있다.
  • Processor(CPU)는 PC가 가리키는 메모리 주소로부터 명령어를 fetch한다.
  • PC값을 증가시킨다.
    • (별 다른 말이 없다면)
  • Processor는 명령어를 해석하고 요구된 actions을 수행한다.(execution) 
    • 어떤 종류의 instruction인지 interpret -> decode (e.g. add, subtract, multiply)

 

Instruction Cycle의 좀 더 자세한 그림은 다음과 같다.

fetch - execution - interrupt check - fecth - ...

  • PC가 가리키고 있는 주소의 instruction을 읽어 온다.(fetch)
  • 어떤 종류의 instruction인지 해석한다. (decode)
  • instruction의 종류에 따라 operand의 갯수가 결정되고 이 operand들을 갯수만큼 가져온다.
  • ALU에 의해 연산이 진행되고 나온 결과값이 전달되어 이 값이 저장될 공간을 또 다시 계산을 하게 되고 해당 위치에 저장을 한다.
  • 마무리로 Interrupt check를 하여 interrupt를 걸지 말지를 결정하고 다시 맨 처음으로 돌아가 반복을 한다.

 

System software

시스템 소프트웨어를 작성하는 것이 시스템 프로그래밍(우리가 배우는 것)이기에 시스템 소프트웨어가 무엇인지 알아보자. 다음과 같이 정의할 수 있다.

  •  다른 소프트웨어(혹은 애플리케이션)에 플랫폼을 제공하기 위해 디자인된 소프트웨어
    • 소프트웨어 중 다른 소프트웨어에 영향을 주지 않고 uninstalled(삭제) 될 수 있는 소프트 웨어는 시스템 소프트웨어가 아니다.(wikipedia)
    • 즉, 시스템 소프트웨어는 다른 소프트웨어에게 플랫폼을 제공하기 위해 디자인 되었기 때문에 다른 소프트웨어와 일종의 종속 관계인 것이다.
  • 또 다른 정의: system application에 사용되는 OS 프로그램들과 OS가 제공하는 서비스들로 구성된 플랫폼
  • 컴퓨터 운영 시스템을 구성하는 파일들과 프로그램에 대한 지침 
    • System files include libraries of functions, system services, drivers for printers and other hardware, system preferences, and other configuration files(setting).
    • 시스템 파일들은 함수 라이브러리, 시스템 서비스, 프린터 드라이버, 또 다른 하드웨어, 시스템 preferences, 다른 설정 파일들 등을 포함한다.
    • The programs that are part of the system software include assemblers, compilers, file management tools, system utilities, and debuggers (techterms.com)
    • 시스템 소프트웨어의 부분인 프로그램은 assemblers(어셈블러), compilers(컴파일러), file management tools(파일 관리 툴), system utilities(시스템 유틸), 그리고 debuggers(디버거)를 포함한다.

 

system software인 것과 아닌 것?

system software의 예:

  • OS Kernals
  • Drivers
  • Bare Metal Hypervisors
    • bare metal hypervisor : 범용 하드웨어
  • Compilers(that produce native binaries) and Debuggers, linker, loader

system software가 아닌 것의 예:

  • GUI Chat application(Slack, Discord, etc)
  • Web-based JavaScript Application
  • Web service API
    • 다른 소프트웨어에게 서비스를 제공하고 추상화를 위해 하드웨어와 상호작용하지 않는다.

 

해당 소프트웨어를 지웠을 때 다른 애플리케이션에 영향을 주는지 여부를 생각해 보면 된다.

 

System programming

  • programming(writing) computer system software의 acticity(활동)
  • system programming의 구별되는 특징
    • application program은 유저에게 직접적으로 서비스를 제공하는 소프트웨어를 생산하는 것을 목표를 하고,
      • 예를 들어, ms word 프로그램은 사용자가 다른 소프트웨어가 아닌 사람(Human)이기 때문에 시스템 소프트웨어가 아니다.
    • 반면에 system programming은 다른 소프트웨어에게 서비스를 제공하는 플랫폼을 생산하는 것을 목표로 한다.
  • 또한 system programming은 프로그래머는 반드시 hardware와 os에 대해서 매우 잘 알아야 한다는 점에서 구분된다.
    • 시스템 소프트웨어는 kernel과 core system libraries와 직접적으로 마주보고 있기 때문에 low level에서 존재한다.
  • system programming의 가장 중요한 핵심 파트는 매우 빠른 속도가 요구된다는 것이다.
    • 이는 성능, 즉 performance와 직결된 문제로 다른 소프트웨어에 플랫폼 역할을하기 때문에 만약 사용하는 application의 중심부(즉, system software platform)가 느리다면, 전체 application의 performance도 매우 느려질 것이기 때문이다.
  • 따라서 목표가 available resources(사용가능한 자원)의 효율적인 사용인데 이는 software 그 자체로 성능이 중요하기 때문이기도 하고 매우 작은 성능의 개선이 service provider에게 중요한 금전적인 saving에 직접적으로 영향을 미칠 수 있기 때문이기도 하다.
  • System software는 shell, text editor, compiler, debugger, core utilities and system daemons을 포함한다.

 

Run-Time Environments(RTE)

  • 프로그램은 항상 RTE와 같은 또다른 프로그램과 연결되어 만들어진다.(혹은 그 프로그램 위에서 실행된다.)

RTE의 종류:

  • OS: Unix/Linux, Window OS
  • Java Virtual Machine(JVM)
    • JVM은 OS는 아니지만 다른 소프트웨어에게 플랫폼을 제공하기 때문에 RTE의 종류 중 하나인 것이다.
  • Cloud OS

 

What is an operating system?(OS)

만약 application을 짜는 사람들이 하드웨어를 직접 제어하도록 짜야 된다면 너무 힘들 것이기 때문에 application과 hardware의 중간 다리 역할을 하는 매개체가 있어야 하는데 이 매개체를 바로 OS(operation syste), 우리 말로 운영체제가 맡아서 하게된다.

  • OS는 hardware 자원에 access 하는 application software를 제공하는 special layer of software으로 정의할 수 있다.
    • 복잡한 하드웨어 장치의 간편한 추상화(abstraction)
    • 공유 자원에 대한 보호된 접근(protected access)
    • 보안와 인가
    • 논리 개체 사이의 커뮤니케이션

위 네 가지가 OS에서 중요한 부분이다.

 

Block diagram of Operating System modules

응용 프로그램이 하드웨어를 직접 access 해야 하는데 그것이 사실은 매우 불편하기 때문에 OS가 hardware를 추상화 하여 user program이 hardware 제어를 손쉽게 할 수 있도록 도와준다.

 

이때 이 둘(하드웨어, 유저 프로그램) 간의 interface가 정의되는데,

  • User interface: 사용자 관점에서 정의된 interface
  • System call: 하드웨어(OS) 관점에서 정의된 interface
  • 보라색으로 되어 있는 것들: system call에 의해서 사용자에게 제공되는 서비스들을 구현하는 알고리즘의 집합(OS kernal)이다.

 

What does an OS do?

  • apps에 대한 추상화를 제공한다. (편리함)
    • file system
      • 각각의 파일을 저장할 하드 디스크에 대한 access가 필요한데 파일을 사용하는 입장에서 실제 하드디스크를 어떻게 access를 해야하는지 알 필요까지는 없다.(OS에서 파일에 대한 추상화를 지원하기 때문에)
    • process, theads(프로그램 실행단위)
      • Process, Thread: Ms word 아이콘을 두 번 누르면 창이 두 개가뜸 -> 프로세스가 두개가 실행 된 것 즉, instance 두 개가 만들어진 것이라고도 한다.
    • VM, containers
    • Naming system
  • Manage resources(efficiency)
    • Memory, CPU, storage...
  • 특정 알고리즘을 구현함으로써 아래에 있는 것들을 이루어낸다. 
    • Scheduling(스케쥴링)
    • Concurrency(동시성)
    • Transactions(트랜잭션)
    • Security(보안)

 

Virtual Machines

  • Software emulation(한 컴퓨터가 다른 컴퓨터처럼 똑같이 작동하도록 하는 기법, 즉 복제) of an abstract machine
    • 프로그램들에게 마치 그들이 machine을 소유한 것과 같은 환상(illusion)을 준다.
    • 하드웨어가 마치 내가 원하는 feature들을 가지고 있다고 생각하게 만든다.
  • "VMs"의 두 가지 타입
    • Process VM: a single program의 실행을 지원(support)
      • 주로 OS에 의해 제공되는 기능
    • System VM: 전체 운영체제와 그것의 applications의 실행을 지원(support)
      • Hypervisor(가상화 기술)에 의해 제공됨
      • VMWare Fusion, Virtual box, Parallels Desktop, Xen

 

Process VMs

목적: 응용프로그램을 간단하게 만드는 것

  • Programming simplicity
    • 각 process는 모든 memory/CPU time을 소유한다고 생각한다.
    • 모든 devices를 소유한다고 생각함
    • 다른 device는 same high level interface를 가진 것처럼 보임
    • 다른 interface는 raw hardware보다 더 강력
      • Ethernet card -> reliable, ordered, networking (TCP/IP)
  • Fault Isolation(결함 고립)
    • 다른 precess들에게 직접적으로 영향을 줄 수 없다.
    • 버그가 전체 머신을 망칠 수 없다.
  • Protection and Portability
    • Java interface 는 안전하고 안정되어 있다 (많은 플랫폼들을 걸쳐서)

 

System VMs: Layers of OSs

  • Useful of OS development
    • OS가 충돌이 날때, 한 VM에게만 제약을 가한다.
    • 다른 OS들 위의 프로그램들을 테스트 하는 것을 돕는다.
  • 가상화 되어진 CPU, memory, devices를 가진다.

 

Process Life Cycle

  • OS가 process의 life cycle을 관리/감독한다.
    • 3 main steps: Creating the process, managing the process and terminating the process.(만들고 관리하고 종료하고)
  • OS는 어느 프로그램(=executable file)이 프로세스를 생성하기 위해 실행될지를 식별한다. 
    • Executable files are generated with a compiler given the text of the program in a language such as C or C++
    • Executable files은 C나 C++와 같은 언어로 프로그램의 텍스트가 주어진 컴파일러로 만들어진다. 
    • This is a file that contains instructions to be executed on the CPU to activate the process. The format of executable files is specified by the OS.
    • 프로세스를 활성화하기 위해 CPU에서 실행할 명령어가 포함된 파일이다. 실행파일의 형식은 OS에서 지정한다.
  • OS는 process를 만들라고 user에게 요청받는다.
    • 이는 shell(명령 프롬포트)을 통해 가능하다.
    • Shell: 소프트웨어 중 하나로 user를 위한 interface를 제공한다.
      • Command Line Interface(CLU) or a Graphical User Interface(GUI).

 

Creating the process

  • OS가 process instance를 executable로부터 생성한다.
    • 이 instance는 그것의 process ID로 식별되는데 이는 실행중인 모든 프로세스 사이에서 unique한 값을 가진다.
    • 실행중인 프로세스와 관련된 모든 정보는 OS의 process table에서 유지된다.
  • OS는 computer의 main memory에 새로운 process가 사용하기 위한 메모리도 할당한다.
  • OS는 프로그램 executable file에서 main memory로 명령어를 로드한다.

 

Managing the process

  • OS는 프로그램에서 starting function을 지정한다.(e.g., "main" in C and C++) 그리고 그 함수를 실행한다..
    • main 함수는 OS로부터 인자(arguments)를 전달받는다. 이러한 인자는 command line arguments라고 불린다.
  • 그 지점으로부터 메인 함수의 명령어가 프로그램에 명시된대로 실행된다.
    • 중간에 실행이 중지될 수도 있음.

 

Terminating the process

  • process가 special system call인 exit을 실행시 process가 종료됨
  • 메모리와 할당된 다른 모든 자원이 해방되고 process ID가 해방되며 프로세스 개체가 OS process table로부터 제거된다.

 

1.1 왜 리눅스인가?

실행환경 플랫폼(RTE platform)에는 다양한 종류가 있다.

 

Why Linux?

  • 1991년 : 핀란드 대학원생 Linus Tovalds가 만듬
    • MInix를 기반으로 version 0.01 개발
    • Paging, timer interrupt, device driver, file system,...
    • 1992년: 리눅스 배포판 등장
      • 리눅스 배포한 = 리눅스 커널 + 응용 프로그램

 

  • Linux
    • PC 등 다양한 컴퓨터 환경에서 동작하는 UNIX-like OS
    • 어느 상용 OS와도 견줄 수 있는 막강한 성능과 안정성
      • 인터넷 상의 많은 해커들의 참여로 커널이 개발됨.
      • 전세계의 수많은 사람들에 의해 테스트되고 개선, 발전됨.
    • COPYLEFT(open source)
      • GNU General Public License(GPL)에 따라 공개
      • 프로그램의 실행 파일 외에 소스코드 또한 공개.
      • 원하는 사람은 소스코드를 변경할 수 있음
      • 단, 변경된 프로그램을 공개하고자 할 때는 반드시 소스코드도 함께 공개해야 함.
  • 리눅스 기능상 장점:
    • 멀티 태스킹(Multi- Tasking)
    • 다중 사용자 접근(Multi-User access)
    • POSIX 1003.1 standard 지원
    • 다양한 파일 시스템 지원
    • 다양한 네트워크 프로토콜 지원
    • 다양한 아키텍처 지원
    • 멀티 프로세서 지원

 

동기

  • 유닉스/리눅스 운영체제
    • 스마트폰, PC, 서버 시스템, 슈퍼컴퓨터에까지 사용되고 있음
    • 소프트웨어 경쟁력의 핵심이 되고 있다.

 

  • 유닉스/리눅스 기반 운영체제:
  1. 안드로이드OS
  2. iOS
  3. Mac OS x
  4. Linux
  5. BSD 유닉스(버클리)
  6. 시스템 V
  7. Sun 솔라리스
  8. ...

 

유닉스의 설계 철학

  • 단순성
    • MIT MULTICS에 반대해서 최소한의 기능만을 제공
    • 자원에 대한 일관된 관점 제공(everything is file 관점)'
  • 이식성
    • 이식성을 위해 C 언어로 작성
    • 다양한 플랫폼에 이식 가능
    • 스마트폰, PC, 서버, 슈퍼컴퓨터 등
  • 개방성
    • 소스 코드 공개와 같은 개방성

 

유닉스의 특징

  • 다중 사용자, 다중 프로세스 운영체제(OS)
    • 여러 사용자가 동시에 사용 가능
    • 여러 프로그램이 동시에 실행
    • 관리자 슈퍼유저(Super User)가 있음.
  • 쉘 프로그래밍(Shell Programming)
    • 명령어나 유틸리티 등을 사용하여 작성한 프로그램
  • 훌륭한 네트워킹
    • 유닉스에서부터 네트워킹이 시작
    • ftp, telnet, WWW, X-window 등

 

1.2 유닉스 시스템 구조

Unix/Linux의 구성

  • Application program
    • ls, mkdir, chmod, vi, sh
  • Library
    • 많은 library function은 결국 system call을 호출
    • e.g. printf() -> write()
  • System call
    • Application과 operating system과의 interface
    • System call이 호출되면 kernal code가 수행됨
    • kernal의 기능을 추상화 한 것
  • Kernal
    • system resource를 효율적으로 사용하도록 관리
    • process/memory/file/IO management

 

유닉스 운영체제 구조

  • 운영체제
    • 컴퓨터의 하드웨어 자원을 운영 관리하고 프로그램을 실행할 수 있는 환경을 제공.
  • 커널(Kernal)
    • 운영체제의 핵심으로 하드웨어 운영 및 관리
  • 시스템 호출(system call)
    • 커널이 제공하는 서비스에 대한 프로그래밍 인터페이스 역할
  • 쉘(Shell)
    • 사용자와 운영체제 사이의 인터페이스
    • 사용자로부터 명령어를 입력받아 해석하고 수행해 주는 명령어 해석기

 

커널의 역할

  • 하드웨어를 운영 관리하여 프로세스, 파일, 메모리, 통신, 주변장치(키보드, 마우스) 등을 관리하는 서비스 제공

 

프로세스 관리(Process management)

  • 여러 프로그램이 동시에 실행될 수 있도록 프로세스들을 CPU 스케줄링한다.

파일 관리(File management)

  • 디스크와 같은 저장장치 상에 파일 시스템을 구성하여 파일을 관리한다.

메모리 관리(Memory management)

  • main memory가 효과적으로 사용될 수 있도록 관리한다.

통신 관리(Communication management)

  • 네트워크를 통해 주고받을 수 있도록 관리한다.

주변장치 관리(Device management)

  • 모니터, 키보드, 마우스와 같은 장치를 사용할 수 있도록 관리한다.

 

시스템 호출(system call)

OS 시스템과 사용자 프로세스 간의 inteface

 

  • system interface 역할
    • Application programs talk to the operating system(system call을 통해서)
    • UNIX kernel에 대한 프로그래머들의 기능적 인터페이스

호출하는 함수는 user space에 있지만 호출 되는 함수는 kernal 영역에 존재한다.

 

사용자 모드/커널

sytem call은 stack을 통해서 전달되지 못하기 때문에 register에 copy하여 trap instruction을 실행한다.

사용자 모드에서 커널 모드 간의 모드 change가 중요하다.(호출을 할 때나 값을 리턴할 때마다의 모드 변환이 이루어짐)

 

Library vs. system call

  • Library와 system call의 예

input()은 user space 안에서의 함수 호출

scanf()는 c 라이브러리 함수인데 해당 함수에는 read라는 system call인 커널 함수 read()를 호출한다.

 

Kernal mode

  • privileged mode
    • 무엇이 privileged인가?(특권을 가진)
    • 시스템 커널에 대해 부가되는 제약이 어떠한 것도 없다.
  • 프로세서의 명령어 전부를 사용할 수도 있다.
  • 메모리의 전체를 조작
  • 주변기기(peripheral) 컨트롤러와 직접적으로 소통

 

User mode

  • 프로세스에 대한 정상적인 execution mode 
    • privileges(특권)가 없다.
    • 특정 명령어가 금지되어있다.
    • 그것에 할당된 영역에만 허용가능하다.
    • 물리 기계와 상호작용할 수 없다.
  • 프로세스는 자기 자신 환경에서 연산을 수행한다. (다른 프로세스를 방해하지 않고)
  • 언제든 프로세스 중지 가능하다.

 

Calling a regular function & Invoking a system call

  • 우리가 프로그램을 작성할때 반드시 regular function을 호출하는 것과 system call을 invoke하는 것의 차이를 이해해야 한다.
    • 둘이 비슷해 보이지만(같은 일을 하는 것처럼 보이기 때문에) system call 호출과 function call은 서로가 완전히 다르다.
  • process가 system call을 부르면 프로세스는 OS가 요청된 service를 실행할 때까지 interrupted 상태를 유지한다.
    • 즉, system call이 불리게 되는 매 순간마다 process는 context switch에 착수된다는 것이다.
  • 프로그램과 OS간의 interface는 system call의 집합으로 정의된다.(with its own parameters)
    • 현대 OS(Linux와 Windows와 같은)들은 수백개 내지 수천개의 정의된 system call이 존재한다.

 

 

그래서 시스템 프로그래밍에서 배우는 것은?

 

  • 파일 관련 시스템 호출
    • open(), close(), read(), write(), dup(), seek(), …
  • 프로세스 관련 시스템 호출
    • fork(), exec(), exit(), wait(), getpid(), getppid(), …
  • 시그널 관련 시스템 호출
    • signal(), alarm(), kill(), sleep(), …
  • IPC 관련 시스템 호출
    • pipe(), socket()

 

시스템 호출과 라이브러리 함수 정리

  • 시스템 호출(System Calls)
    • Unix kernal에게 서비스를 요청하는 호출
    • Unix man의 Section 2에 설명되어 있음
    • C 함수처럼 호출될 수 있음
      • C 함수 처럼 호출될 수 있으나 context switch가 일어난다는 것이 C 라이브러리 함수와의 차이점이다.
  • C 라이브러리 함수(Libraray Functions)
    • C 라이브러리 함수는 보통 system call을 포장해 놓은 함수이다.
    • 보통 내부에서 system call을 함.
    • 이것이 사용자 입장에서는 더 직관적이고 쉽게 접근이 가능하다.(system call을 직접사용하는 것이 아니기 때문)

 

Linux 장점

  • 풍부하고 다양한 하드웨어를 효과적으로 지원
    • 대부분의 하드웨어를 지원하는 추세(PC, Work station, server...)
  • 놀라운 성능 및 안정성
  • 인터넷에 맞는 강력한 network 구축
  • 다양한 응용 프로그램 개발이 됨
  • 무료 배포판으로 Ubuntu등이 쓰임

 

1.3 유닉스 역사

  • 어셈블리어로 개발하여 C언어로 다시 작성됨.
    • 그렇기 때문에 C언어와 Unix를 작성하기 위한 언어로 밀접하게 관련되어 있다.
  • 이론적으로 C컴파일러만 있으면 이식이 가능하다.(potability)

 

What is good Unix

  • Open system
  • "Small"은 아름다운 철학이라고 할 수 있다.
    • file: 단순한 bytes들의 흐름
    • Data, Device, Socket, Process, ...등이 모두 파일로 다뤄진다.
  • Portability
    • high-level language
    • client-server model, clustering
  • True Parallelism
    • Multitasking, Multiprocessor,...

 

What is Wrong with Unix

  • 너무 많은 변수들 
    • dumping ground
  • Not small and simple any one 
    • uncontrolled growth(버전의 무한한 add-on의 제어가 힘듬)
  • GUI의 부족함
    • not now(MIT's X)

 

리눅스 장점

  • 풍부하고 다양한 하드웨어를 효과적으로 지원
    • 대부분의 하드웨어를 지원하는 추세임
    • PC, 워크스테이션, 서버 등
  • 놀라운 성능 및 안정성
    • Pentium으로도 충분히 빠르며 안전하게 수행
  • 인터넷에 맞는 강력한 네트워크 구축
  • 다양한 응용 프로그램 개발됨
  • 무료 배포판
    • 레드햇(Red Hat): 상업용
    • 우분투
    • 페도라
    • CentOS

 

UNIX의 표준화

  • ANSI C
    • American National Standards Institute
    • C 언어의 문법, 라이브러리와 헤더 파일의 표준을 제정
    • 다양한 운영체제환경에서 C프로그램의 호환성을 높이기 위함
  • POSIX
    • Portable Operating System Interface for Computer Environments
    • 운영체제가 제공해야 하는 서비스를 정의
    • 1003.1: 운영체제의 인터페이스 표준 (POSIX.1 이라고도 함)
    • 1003.2, 1003.7 등
반응형
Contents

포스팅 주소를 복사했습니다

이 글이 도움이 되었다면 공감 부탁드립니다.