[CS 스터디] 5주차 OSI 1 ~ 3 계층
·
공부/CS 스터디
OSI 1 ~ 3 계층OSI는 Open System Interconnection Reference Model 의 약자로, 국제 표준화 기구인 ISO에서 개발한 네트워크 모델이다.7계층으로 이루어져 있으며, 아래와 같이 각 계층은 분리되어 있다.7계층: 응용 계층6계층: 표현 계층5계층: 세션 계층4계층: 전송 계층3계층: 네트워크 계층2계층: 데이터 링크 계층1계층: 물리 계층이 중 오늘은 1계층부터 3계층을 알아보려고 한다.1계층: 물리 계층 (Physical Layer)1계층은 OSI 7계층 중 가장 아래에 있는 계층으로, 물리적 매체를 통해 데이터를 전기적, 광학적으로 전송하는 것을 담당한다.허브허브는 근거리의 장비들을 연결하는 물리계층에 속하는 중계 장비이다.전기 신호를 증폭하는 기능을 가지고 있..
[CS 스터디] 4주차 동기화, 메모리
·
공부/CS 스터디
동기화동기화란, 여러 프로세스 혹은 스레드에서 하나의 공유 자원에 접근 할 때, 접근 순서를 보장해주는 방식이 동기화이다.동기화가 필요한 이유여러 프로세스 혹은 스레드가 하나의 자원에 접근할 때, Race condition이 발생하게 되는데, 이를 해결하기 위해서는 동기화가 필요하다.Race condition (경쟁 상태)Race condition은 여러 프로세스 혹은 스레드가 하나의 자원에 동시에 접근할 때, 서로 자원을 선점하려 경쟁하는 것을 뜻한다.이 과정에서 실행마다 순서가 달라지게 되고, 이는 일관되지 못한 결과를 만들어낸다import kotlin.concurrent.threadvar counter = 0fun main() { val threads = List(1000) { t..
[CS 스터디] 3주차 CPU 스케줄링과 IPC
·
공부/CS 스터디
CPU 스케줄링선점형 VS 비선점형CPU 스케줄러는 선점형(Preemptive)과 비선점형(Non-Preemptive)으로 구분할 수 있다.두 스케줄링은 자원을 빼앗길 수 있느냐 빼앗기지 않느냐에 따라 구분할 수 있다.먼저, 선점형 스케줄링은 자원을 다른 프로세스에 빼앗길 수 있다.실행중이던 프로세스가 자원을 빼앗기면 어떻게 될까?자원이 없으면, 프로세스를 실행할 수 없기 때문에 현재 작업을 저장하게 되고, 이 과정에서 잦은 Context Switching이 발생한다.또한, 선점형 스케줄링은 응답성이 높다는 장점이 있다.만약 더 높은 우선순위를 가진 프로세스가 생성된다면, 선점형 스케줄링은 기존 프로세스의 자원을 회수하고, 새로운 프로세스에게 할당할 수 있다.이렇게 되면, 우선순위가 높은 프로세스는 기다..
[CS 스터디] 2주차 커널 동작과 인터럽트
·
공부/CS 스터디
CS 스터디 2주차 - 커널 동작과 인터럽트커널 모드커널 모드는 말 그대로 커널에서 실행하는 모드로, 다음과 같은 특징을 가진다.모든 하드웨어에 직접 접근 가능모든 CPU 명령어 실행 가능운영체제가 커널 모드로 실행됨유저 모드유저 모드는 userspace에서 동작하는 모드로, 다음과 같은 특징을 가진다.하드웨어에 직접 접근 불가제한된 CPU 명령어 실행 가능일반 애플리케이션이 기본적으로 유저 모드로 실행됨그렇다면, 유저 모드에서 실행중이던 애플리케이션이 네트워크 처리, 파일 입출력 등 하드웨어에 직접 접근하는 등, 유저 모드 권한 밖의 작업을 하려면 어떻게 동작할까?이때 애플리케이션은 시스템 콜 (System Call)을 사용한다.시스템 콜시스템 콜을 애플리케이션이 커널 기능을 요청할 때 사용하는 인터페..