💋 CPU Burst VS IO Burst ✔️ Burst 어떤 현상이 짧은 시간 안에 집중적으로 일어나는 일 계속되는 작업 ✔️ CPU Burst 프로세스가 CPU에서 한 번에 연속적으로 실행되는 시간 메모리에 올라가 있는 프로세스가, 자신의 차례가 되어 CPU에서 실행되었을 때, 자신의 명령어가 CPU에서 연속적으로 실행되는 시간 ✔️ IO Burst 프로세스가 IO 작업을 요청하고 결과를 기다리는 시간 프로세스를 실행하면, CPU Burst, IO Burst가 번갈아가며 나타난다. (마지막은 CPU Burst겠죠?) 💋 CPU Bound VS IO Bound ✔️ CPU Burst 시간의 분포 위 그래프를 보면, 대부분의 프로세스는 CPU Burst가 8ms 이내에 끝나는 것을 볼 수 있다. 프로세..
Computer Science/Operating System
💋 인트로 안녕하세요. 우아한테크코스 5기 깃짱이라고 합니다. 💋 컨텍스트 스위칭 ✔️ 개념 CPU/코어에서 실행중이던 스레드가 다른 스레드로 교체되는 것 이 때 두 스레드는 같은 프로세스에 속할수도, 다른 프로세스에 속할 수도 있다. 여러 프로세스/스레드를 동시에 실행시키기 위해 필요하다. ✔️ 발생 원인 크게 3가지! Time Quato Expiry: 주어진 quantum(time slice)의 시간이 다됨. 쉽게 말해 Time Over! Interrupt: 커널 함수를 통해서 프로그램 실행 도중에 멈춰버림. (SIGKILL interrupt signal) Preemption: 더 우선순위가 높은 일을 해야 할 때 선점해버려서 ✔️ 컨텍스트(context)란? 프로세스/스레드의 상태 CPU, 메모리의..
💋 인트로 안녕하세요, 우아한테크코스 5기 백엔드 깃짱이라고 합니다. 이번 포스팅부터는 유튜브 쉬운코드의 운영체제 영상을 보면서, 운영 체제의 기초에 대해 정리해 나가려고 합니다. 대부분의 내용과 사진은 쉬운코드 개발자님의 영상을 보고 작성한 내용입니다. 텍스트로 이해가 잘 되지 않는다면 참고자료에 있는 영상을 직접 보면서 공부하시면 많은 도움 될 거에요! 💋 용어 정리 먼저 기본적인 용어부터 정리하고 시작해야 한다. ✔️ 프로세스 컴퓨터에서 실행중인 프로그램으로, 각각의 프로세스는 독립된 메모리 공간을 할당 받는다. 또 각 메모리 공간은 독립적인 명령어와 데이터를 가진다. ✔️ CPU(Central Processing Unit) 명령어를 실행하는 연산 장치 ✔️ 메인 메모리 프로세스가 CPU에서 실행되..
💋 인트로 안녕하세요. 우아한테크코스 5기 깃짱이라고 합니다. 이번 포스팅에서는 DB Connection Pool Size를 줄일 수록 오히려 성능이 개선될 수 있는 이유에 대해서 작성했습니다. 아래 내용은 HikariCP에서 작성한 깃허브 Wiki의 내용을 토대로 작성했습니다. 💋 커넥션 풀의 크기를 결정할 때, 얼마나 작게 하는지가 더 중요하다? 커넥션 풀을 설정하는 것은 개발자들이 자주 실수하는 부분입니다. 커넥션 풀을 구성할 때 이해해야 할 몇 가지 원칙이 있습니다. 동시에 10,000명의 사용자가 있는 서비스를 상상해보세요. 아마도 페이스북처럼 대규모는 아니더라도 10,000명의 사용자가 동시에 데이터베이스 요청을 하는 경우입니다. 이는 초당 약 20,000개의 트랜잭션을 의미합니다. 이때 커넥..