목록백엔드 로드맵따라가기/OS 및 일반적인 지식 (8)
전성빈의 사리사욕
what is apt? APT(Advanced Package Tool)는 Debian계열의 패키지 관리 프로그램인 dpkg와 상호작용하는 커맨드 라인 도구입니다. apt-get apt-get은 패키지에 대한 설치, 검색, 업데이트 및 삭제등 여러 작업을 수행합니다. 오래된 패키지를 사용하는것은 보안 이슈가 생길 수 있으니 패키지를 가급적 최신의 상태를 유지하는 것이 좋습니다. apt-get은 시스템의 핵심 측면을 다루기 대문에 su 권한이 필요합니다. ubuntu 등에서 사용할 때는 sudo를 붙여줘야 합니다. sudo apt-get update 설치 되어있는 패키지들의 최신 버전이 있는지 확인합니다. Hit : 새로운 버전이 없습니다. Get : 새로운 버전에 대한 정보를 가져옵니다. Ign : 오류가..
I/O Devices and Connection IO 디바이스는 컴퓨터에게 감각을 제공합니다. 또한 컴퓨터가 사용자에게 표현할 수 있게 합니다. input : 키보드, 마우스, 카메라 .. output : 모니터, 스피커 I/O : 네트워크, 저장매체 IO 디바이스들은 Interface를 통해 연결됩니다. e.g. HDMI, USB, Ethernet ... CPU와 메모리, I/O 컨트롤러 사이에는 상호 연결이 필요합니다. 이를 Bus라는 매체를 통해 연결합니다. 버스란 데이터와 데이터 전송의 동기화를 위한 병렬로 연결된 통로 입니다. 초기에는 버스란 용어는 전선을 의미했지만 최근에는 연결을 위한 물리적 배치들을 말합니다. 병목현상이 발생할 수 있다. 물리적인 요소에 의해 성능의 한계가 정해진다. 통로의..
IPC란? 프로세스들은 각각이 완전히 독립된 실행 객체들입니다. 서로 다른 프로세스 끼리는 영향을 주지 않는다는 장점을 가집니다. 그러나 독립되어 있는 만큼 서로간 통시니 어렵다는 문제가 있습니다. 이를 위해 커널에서 IPC를 제공하게 되고 프로세스는 커널이 제공하는 IPC 설비를 이용해 프로세스간 통신을 할 수 있게 됩니다. IPC 표준 system V IPC : 오래된버전이며 역사가 긴 만큼 다른 기종간 코드 호환성을 보장해 주지만 API가 오래 되었으며 함수명도 며확하지 않습니다. POSIX IPC : 비교적 최근에 개발된 표준입니다. 직관적인 API들로 구성되어 있어 상대적으로 사용하기 쉽습니다. IPC 설비 다양한 IPC 설비들이 존재하고 각각의 필요에 따라 알맞은 IPC를 선택해야합니다. 상황..
메모리 관리 개념 프로그램을 실행 시키기 위해서는 메모리 위에 적재를 해야합니다. 멀티 프로세스 시스템에서는 다양한 프로세스들이 메모리에 적재되어 실행되는데 이를 위해서 메모리를 효율적으로 관리해야 합니다. 이러한 메모리 관리를 위해 메모리 관리자가 존재하고, 메모리 관리 장치(MMU, Memory Manangement Unit)와 OS가 함께 작업합니다. 이때 몇가지 정책에 따라 메모리를 관리합니다. 적재 정책 : Disk에서 메모리로 프로세스를 언제 가져와야 하는지 정하는것 배치 정책 : Disk에서 가져온 프로세스를 어느 위치에 저장할 지 정하는것 대치 정책 : 메모리가 충분하지 않을 때 현재 메모리에 적재된 프로세스중 무엇을 제거할 지 결정하는 논리적 주소, 물리적 주소, 메모리 매핑 1. 논리적..
쓰레드란? 쓰레드란 프로세스 내에서 존재하는 실행의 흐름이자 단위이다. 일반적으로 한 프로그램은 하나의 쓰레드를 가지고 있찌만 프로그램의 환경에 따라 둘 이상의 쓰레드를 가질 수 있다. 이렇게 여러개의 쓰레드를 갖는 방식을 멀티쓰레드(multithread)라고 한다. 프로세스와 쓰레드의 비교 쓰레드는 하나의 프로세스안에 여러개 존재할 수 있습니다. 따라서 여러개의 쓰레드를 생성하여도 코드, 데이터, 파일등은 공유할 수 있기 때문에 경량화 프로세스라고 하기도 합니다. 공유 하는 메타데이터가 있기때문에 쓰레드를 생성할 때 발생하는 오버헤드가 적으며 또한 Context Switch시 내용이 겹치는 부분이 많아 오버헤드가 적습니다. 또한 프로세스 끼리는 메모리에서 Stack 공간을 따로 쓰며 서로 침범하는 일이..
프로세스란? 프로세스란 디스크에 있는 프로그램이 메인 메모리에 올라와 있는 상태, 즉 실행중인 프로그램이다.(e.g. shell, a.out 등) 또한 CPU가 일을 처리할때 사용하는 단위로 task과 동의어이다. 시스템에는 많은 프로세스들이 있지만 프로세스들을 처리할 CPU는 단 하나거나 몇개일 뿐입니다. 프로세스들은 CPU를 공유하기 위해 실행되고 멈추고를 반복합니다. 따라서 프로세스들은 states가 변화하고 context를 가지고 있습니다. Process context란 프로세스가 정지할때 프로세스의 호나경에 대한 상태입니다. 프로세스가 다시 시작되기 위해서는 반드시 다시 읽어와야 합니다. 프로세스의 상태와 상태 변환 현대에서 사용되는 멀티 태스킹 시스템에서는 프로세스는 다른 프로세스들과 CPU를..
OS(Operating System)란? 운영체제(OS : Operating System)는 컴퓨터 시스템의 각종 자원을 효율적으로 관리하고 컴퓨터 HW와 User간의 인터페이스를 담당하는 시스템 프로그램이다. OS = kernel + System Promgrams + libraries + Utility Services(complier, shell etc) 운영체제의 목적은 사람이 컴퓨터를 편하게 이용하고 사용자 대신 HW를 효율적으로 관리하는데에 있다. 따라서 OS는 모든 어플리케이션에 대한 인터페이스를 제공하고 자원 관리자로서 CPU, RAM, I/O device 등을 관리한다. OS의 목적 OS는 사람이 HW와 SW를 편리하게 사용하며 컴퓨터의 성능을 높여주는것이 1차적인 목적이다. 일반적으로 OS..
커널(kernel)이란? 모든 OS들은 커널을 가지고 있습니다. 커널은 OS계층이며 HW와 컴퓨터에서 돌아가는 프로그램들을 연결해주는 역할을 합니다. 커널은 OS의 핵심이며 컴퓨터를 부팅시키면 가장먼저 메모리에 올라옵니다. 그리고는 컴퓨터가 꺼질때 까지 내내 메모리에 상주합니다. 커널은 모든 어플리케이션에게 인터페이스를 제공하며 HW를 컨트롤하고 프로세스들이 서로 정보를 주고 받는것을 허락 해줍니다. 쉘(Shell)이란? 쉘은 커널과 사용자의 사이에 존재합니다. 사용자가 커널을 사용하기 위해 명령어를 입력하면 커널이 읽을 수 있는 이진코드로 해석해줍니다. 리눅스에서는 기본적으로 Bash(Bourne Again SHell)라는 쉘을 사용합니다. 터미널(Terminal)이란? 터미널은 텍스트 기반 명령을 입..