System call 시스템 호출 또는 시스템 콜(system call), 간단히 시스콜(syscall)은 운영 체제의 커널이 제공하는 서비스에 대해, 응용 프로그램의 요청에 따라 커널에 접근하기 위한 인터페이스이다. 보통 C나 C++과 같은 고급 언어로 작성된 프로그램들은 직접 시스템 호출을 사용할 수 없기 때문에 고급 API를 통해 시스템 호출에 접근하게 하는 방법이다. - 위키백과 위의 정의로 보면 우리가 개발을 할 때, 내가 모든 기능을 구현할 수 없어 API를 통해서 원하는 기능을 수행하게 만들 때가 있다. system call도 마찬가지로 직접 os의 system 호출이 어려워 그것을 편하게 만들어 놓은 것이다. 운영체제는 커널모드(kernel mode)와 사용자 모드(user mode)로 나..
멀티 프로세스(Multi process) 멀티 프로세스는 다수의 프로세서(CPU)가 협력적으로 하나 이상의 작업을 동시에 처리하는 것이다. 병렬처리의 개념이라고 생각할 수 있다. 스레드와 프로세스의 차이점으로는 주소공간이나 공유하는 점이 있고 없고의 차이가 있다. thread: code, file, data를 공유한다. 따라서, 프로세스를 여러게 쓰는 경우에는 메모리의 구분이나 독립된 주소 공간을 가져야 할 때이다. 장점 하나의 프로세스가 장애가 나더라도 다른 프로세스에 영향을 미치지 않는다. 별도의 동기화 작업이 필요없다. 단점 독립된 메모리 영역으로 인해 작업량이 많아질수록 문맥교환(Context Switching)이 많이 일어나 오버헤드가 발생해 성능저하가 발생할 수 있다. 멀티 스레드(Multi ..
1. 기본 개념 다중 프로그래밍의 경우에는 항상 실행할 수 있는 프로세스가 있도록 하여 CPU의 사용률를 극대화 하는데에 있다. 따라서 CPU의 스케줄링은 OS 성능에 있어서 중요한 이슈중에 하나이다. 스케줄링의 종류로는 2가지가 있다. 선점: 조건이 만족되면 기존에 실행되는 프로세스를 중단하고 다른 프로세스를 CPU에 할당하는 것 비선점: 프로세스가 CPU에 할당되면 종료 / 대기 상태가 될 때까지 CPU를 점유하는 것 여기서 스케줄러가 선택한 프로세스를 CPU에 할당해주는 역할을 dispatcher라고 부른다. 2. 스케줄링 알고리즘 FCFS(First Come First Service) 알고리즘 이름 그대로 먼저 요청된 프로세스를 먼저 처리해주는 알고리즘이다. FCFS의 단점으로는 "호위 효과(Co..
1. 스레드 스레드(Thread)는 프로그래밍을 하다보면 다음과 같이 굉장히 많이 듣게 되는 단어이다. 멀티스레딩을 이용한다... 멀티스레딩 환경에 안전하게 설계 되었나... 스레드 풀 범위를 어떻게 설정할 것인가.... 간단히 말하면 스레드란 경량 프로세스이다. 경량이라는 말은 프로세스보단 더 라이트한 버전이라고 할 수 있다. 그 이유는 하나의 프로세스에서 주소 공간과 같은 자원을 서로 공유하기 때문이다. 위의 그림에서 보듯, thread는 code, data, file을 공유하는 구조이다. 이 스레드를 쓰게 됨으로써 얻게 되는 장점은 크게 3가지가 있다. 응답성: 스레드의 일부가 블록되어도 나머지 부분은 계속 실행될 수 있다. 자원공유: 같은 프로세스의 스레드는 메모리나 그 외의 자원을 공유한다. 그..
1. 프로세스 프로세스란 실행 중인 프로그램이다. Linux 운영체제에서는 다음과 같은 명령어로 실행중인 프로세스를 확인 할 수 있고, $ ps -ef Windows 운영체제에서는 작업 관리자를 켜면 볼 수 있는 것이 프로세스이다. 프로세스에는 몇가지 상태로 나눌 수 있다. 생성중(new) 실행중(running) 대기중(waiting) 준비완료(ready) 종료(terminate) 여기서 다른 부분은 쉽게 이해가 가지만 대기중(waiting) 상태로 넘어가는 경우는 크게 2가지가 있다. CPU를 주어도 당장 실행하지 않음. 요청한 event가 즉시 만족하지 않음. 2. 스케줄러 위와 같이 프로세스가 여러 상태로 변경될 때, 다음 차례의 프로세스를 결정해주는 스케줄러가 있다. 장기 스케줄러 다른 말로는 j..
Replication replication은 기본적으로 데이터의 손실을 최소화하기 위해서 만든 개념이다. partition을 복제하여 다른 broker상에서 복제물(replicas)을 만들어서 장애에 따른 손실을 대비한다. 원본 - Leader, 복제 - Follower producer, consumer는 Leader에만 pub/sub한다. replication은 broker 내부적으로 만든다. Follower가 요청해서 메시지를 가져가는 방식이다. Leader 장애가 나면 새로운 Leader 선정 및 선출된 Leader partition으로 pub/sub 한다. 하나의 Broker에만 Leader가 몰린다면? 하나의 broker에만 부하가 집중되는 것을 Hot Spot이라고 한다. Hot Spot을 방..
- Total
- Today
- Yesterday
- Java
- API
- Front
- OS
- KAFKA
- rhel
- apache
- spring
- spring boot
- NextJS
- feign client
- caching
- 리액트
- Firebase
- consumer
- broker
- React
- apache kafka
- cs
- JPA
- Data Engineering
- Linux
- backend
- Producer
- zookeeper
- centos
- K8S
- frontend
- Container
- 프론트엔드
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |