1장 시스템 구성 정보 확인하기
1.1 커널 정보 확인하기
1.2 CPU 정보 확인하기
1.3 메모리 정보 확인하기
1.4 디스크 정보 확인하기
1.5 네트워크 정보 확인하기
1.6 요약
2장 top을 통해 살펴보는 프로세스 정보들
2.1 시스템의 상태 살피기
2.2 VIRT, RES, SHR ..?
2.3 VIRT와 RES 그리고 Memory Commit의 개념
2.4 프로세스의 상태 보기
2.5 프로세스의 우선순위
2.6 요약
3장 Load Average와 시스템 부하
3.1 Load Average의 정의
3.2 Load Average 계산 과정
3.3 CPU Bound vs I/O Bound
3.4 vmstat으로 부하의 정체 확인하기
3.5 Load Average가 시스템에 끼치는 영향
3.6 Case Study - OS 버전과 Load Average
3.7 요약
4장 free 명령이 숨기고 있는 것들
4.1 메모리 사용량 확인하기
4.2 buffers와 cached 영역
4.3 /proc/meminfo 읽기
4.4 slab 메모리 영역
4.5 Case Study - Slab 메모리 누수
4.6 요약
5장 swap, 메모리 증설의 포인트
5.1 swap 영역
5.2 버디 시스템
5.3 메모리 재할당 과정
5.4 vm.swappiness와 vm.vfs_cache_pressure
5.5 메모리 증설의 포인트
5.6 Case Study - gdb를 이용해서 메모리 누수 잡기
5.7 요약
6장 NUMA, 메모리 관리의 새로운 세계
6.1 NUMA 아키텍처
6.2 리눅스에서의 NUMA 확인
6.3 메모리 할당 정책별 특징
6.4 numad를 이용한 메모리 할당 관리
6.5 vm.zone_reclaim_mode 커널 파라미터
6.6 NUMA 아키텍처의 메모리 할당 정책과 워크로드
6.7 요약
7장 TIME_WAIT 소켓이 서비스에 미치는 영향
7.1
[이 책에서 다루는 내용들]
시스템 구성 정보 확인하기
top 명령으로 프로세스 정보 확인하기
Load Average로 시스템 부하 확인하기
swap과 메모리 증설의 연관 관계
NUMA 아키텍처와 메모리 관리
TCP Keepalive로 종단 간 연결 유지하기
TIME_WAIT 소켓이 서비스에 미치는 영향
[추천의 글]
실무에서 궁금해하는 내용을 쉽게 정리한 책
실무에서 항상 궁금했지만 찾기 어려운 정보를 쉽게 정리해 주는 책입니다. 교과서에 나오는 내용이 아닌 실무를 하면서 찾아낸 방법이기 때문에 더욱 마음에...
[이 책에서 다루는 내용들]
시스템 구성 정보 확인하기
top 명령으로 프로세스 정보 확인하기
Load Average로 시스템 부하 확인하기
swap과 메모리 증설의 연관 관계
NUMA 아키텍처와 메모리 관리
TCP Keepalive로 종단 간 연결 유지하기
TIME_WAIT 소켓이 서비스에 미치는 영향
[추천의 글]
실무에서 궁금해하는 내용을 쉽게 정리한 책
실무에서 항상 궁금했지만 찾기 어려운 정보를 쉽게 정리해 주는 책입니다. 교과서에 나오는 내용이 아닌 실무를 하면서 찾아낸 방법이기 때문에 더욱 마음에 와닿는 것 같습니다. 또한, 문제 해결 방법을 같이 살펴보기 때문에 이를 통해서 독자 스스로 자신의 역량을 강화하는 데 큰 도움이 될 것으로 생각합니다. 리눅스 시스템을 운영하는 시스템 엔지니어나 데브옵스(DevOps라면 이 정도 깊이까지 이해하는 것을 목표로 했을 때 큰 도움이 될 것입니다.
- 고우찬(카카오 인프라 & 데이터플랫폼팀 팀장
대규모 서비스를 시스템 엔지니어의 시각에서 보여주는 책
실제로 서비스의 문제를 잘 해결하기 위해서는 두 SE의 시각이 필요합니다. 보통 서비스를 개발하고 운영하는 소프트웨어 엔지니어의 시각과, 시스템적인 부분의 운영을 다루는 시스템 엔지니어의 시각입니다. 문제가 발생하면 코드의 이슈에 집중하는 소프트웨어 엔지니어와 달리 시스템 엔지니어는 시스템의 설정부터