선배가 옆에서 하나하나 알려주듯 친절히 설명해주는
실습과 그림으로 배우는 리눅스 지식의 모든 것
* Go 언어와 Python, Bash 스크립트 실습 코드 제공
* 이 도서는 『실습과 그림으로 배우는 리눅스 구조』의 개정판입니다.
리눅스 커널 책의 두께와 깊이에 질려 중간에 포기했던 경험이 있는 엔지니어라면, 『그림으로 배우는 리눅스 구조』로 다시 한번 도전해 보길 추천합니다. 이 책은 컴퓨터 시스템을 구성하는 OS나 하드웨어를 직접 동작해 보며 리눅스 개념을 종합적으로 이해할 수 있도록 다양한 실습을 제공합니다. 또한 리눅스가 무엇인지, 리눅스에 포함된 다양한 프로그램에는 어떠한 것이 있는지, 리눅스 프로그램의 필요성 등을 그림으로 친절하게 설명합니다.
Go, Python으로 작성된 실습 코드와 그 실행 결과를 그래프로 나타내어 리눅스의 흐름을 쉽게 파악할 수 있도록 도와줍니다. 프로세스 관리, 메모리 관리뿐만 아니라 디바이스 드라이버를 포함한 장치 접근 방법, 현대 소프트웨어 시스템을 다루는 데 빠질 수 없는 가상화, 컨테이너, cgroup 등의 내용까지 다룹니다. 이 한 권으로 리눅스 지식의 전반적인 내용과 기본 개념부터 파고들어야 비로소 배울 수 있는 심화 내용까지 배울 수 있습니다. 다양한 그림과 실습으로 리눅스 OS의 핵심 개념과 기술을 깊이 있게 배워봅니다.
책을 통해 OS와 하드웨어에 대한 이해도를 높이고 나면 다음과 같은 일이 가능합니다.
- 시스템 운용에 활용
- 보다 나은 프로그래밍에 활용
- 본격적인 커널 개발 시작
Contents
CHAPTER 0 시작하면서
CHAPTER 1 리눅스 개요
프로그램 및 프로세스
커널
시스템 콜
_시스템 콜 호출 확인해 보기
_시스템 콜을 처리하는 시간 비율
Column 모니터링, 경고 알림 및 대시 보드
_시스템 콜 소요 시간
라이브러리
_표준 C 라이브러리
_시스템 콜 래퍼 함수
_정적 라이브러리와 공유 라이브러리
Column 정적 링크가 돌아왔다
CHAPTER 2 프로세스 관리(기초편)
프로세스 생성
_같은 프로세스를 두 개로 분열시키는 fork() 함수
_다른 프로그램을 기동하는 execve() 함수
_ASLR로 보안 강화
프로세스의 부모 자식 관계
Column fork() 함수와 execve() 함수 이외의 프로세스 생성 방법
프로세스 상태
프로세스 종료
좀비 프로세스와 고아 프로세스
시그널
Column 반드시 죽이는 SIGKILL 시그널과 절대로 죽지 않는 프로세스
셸 작업 관리 구현
_세션
_프로세스 그룹
데몬
CHAPTER 3 프로세스 스케줄러
기본 지식: 경과 시간과 사용 시간
논리 CPU 하나만 사용하는 경우
논리 CPU 여러 개를 사용하는 경우
real보다 user+sys가 커지는 경우
타임 슬라이스
Column 타임 슬라이스 구조
컨텍스트 스위치
처리 성능
프로그램 병렬 실행의 중요성
CHAPTER 4 메모리 관리 시스템
메모리 관련 정보 수집하기
_used
_buff/cache
_sar 명령어를 사용해서 메모리 관련 정보를 수집하기
메모리 재활용 처리
_프로세스 삭제와 메모리 강제 해제
가상 메모리
_가상 메모리가 없을 때 생기는 문제점
_가상 메모리 기능
_가상 메모리로 문제 해결하기
프로세스에 새로운 메모리 할당
_메모리 영역 할당: mmap () 시스템 콜
Column Meltdown 취약점의 공포
_메모리 할당: Demand paging
Column 프로그래밍 언어 번역기와 메모리 관리
페이지 테이블 계층화
_Huge Page
_Transparent Huge Page(THP)
CHAPTER 5 프로세스 관리(응용편)
빠른 프로세스 작성 처리
_fork() 함수 고속화: 카피 온 라이트
_execve() 함수의 고속화: Demand paging
프로세스 통신
_공유 메모리
_시그널
_파이프
_소켓
배타적 제어
돌고 도는 배타적 제어
멀티 프로세스 및 멀티 스레드
Column 커널 스레드와 사용자 스레드
CHAPTER 6 장치 접근
디바이스 파일
_캐릭터 장치
_블록 장치
Column 루프 장치
디바이스 드라이버
_메모리 맵 입출력(MMIO)
_폴링
_인터럽트
Column 일부러 폴링을 사용하는 경우
디바이스 파일명은 바뀌기 마련
CHAPTER 7 파일 시스템
파일 접근 방법
메모리 맵 파일
일반적인 파일 시스템
쿼터(용량 제한)
파일 시스템 정합성 유지
_저널링을 사용한 오류 방지
_카피 온 라이트로 오류 방지
_뭐니 뭐니 해도 백업
Btrfs에서 제공하는 파일 시스템의 고급 기능
_스냅샷
_멀티 볼륨
Column 어떤 파일 시스템을 사용하면 좋은가?
데이터 손상 감지와 복구
기타 파일 시스템
_메모리 기반의 파일 시스템
_네트워크 파일 시스템
_procfs
_sysfs
CHAPTER 8 메모리 계층
캐시 메모리
_참조의 지역성
_계층형 캐시 메모리
_캐시 메모리 접근 속도 측정
Simultaneous Multi Threading (SMT)
Column 변환 색인 버퍼(Translation Lookaside Buffer)
페이지 캐시
_페이지 캐시 효과
버퍼 캐시
쓰기 타이밍
직접 입출력
스왑
통계 정보
CHAPTER 9 블록 계층
하드 디스크의 특징
블록 계층의 기본 기능
블록 장치의 성능 지표 및 측정 방법
_하나의 프로세스만 입출력을 호출하는 경우
_여러 프로세스가 병렬로 입출력을 호출하는 경우
Column 추측하지 말고, 측정해라
_성능 측정 도구: fio
블록 계층이 하드 디스크 성능에 주는 영향
_패턴 A 측정 결과
_패턴 B 측정 결과
Column 무엇을 위한 성능 측정인가
_기술 혁신과 관련된 블록 계층의 변화
블록 계층이 NVMe SSD의 성능에 미치는 영향
_패턴 A 측정 결과
_패턴 B 측정 결과
Column 실제 성능 측정
CHAPTER 10 가상화 기능
가상화 기능이란 무엇인가
가상화 소프트웨어
이 장에서 사용하는 가상화 소프트웨어
Column 중첩 가상화
가상화를 지원하는 CPU 기능
_QEMU+KVM 조합
Column CPU 가상화 기능이 없는 경우의 가상화
가상 머신은 호스트 OS에서 어떻게 보이는가?
_호스트 OS에서 본 게스트 OS
_여러 머신을 실행하는 경우
Column IaaS의 오토스케일 메커니즘
가상화 환경의 프로세스 스케줄링
_물리 기기에서 프로세스가 동작하는 경우
_통계 정보
가상 머신 및 메모리 관리
_가상 머신이 사용하는 메모리
가상 머신과 저장 장치
_가상 머신과 저장소 입출력
_저장 장치 쓰기와 페이지 캐시
_반가상화 장치와 virtio_blk
Column 호스트 OS와 게스트 OS의 저장소 입출력 성능 역전 현상
virtio_blk 구조
Column PCI 패스스루
CHAPTER 11 컨테이너
가상 머신과 차이점
컨테이너 종류
네임스페이스
_프로세스ID 네임스페이스
_컨테이너 정체
보안 위험성
CHAPTER 12 cgroup
cgroup으로 제어 가능한 자원
사용 예: CPU 사용 시간 제어
Column cgroup 기능이 리눅스 커널에 포함된 과정
응용 예
Column cgroup v2
CHAPTER 13 이 책에서 배우는 내용과 활용법
Author
타케우치 사토루,서수환
2005년부터 2017년까지 후지츠(주)에서 엔터프라이즈용 리눅스, 그중 특히 커널 개발과 서포트 일을 주로 했다. 2017년부터는 사이보우즈(주)에서 기술고문으로 일하고 있다.
2005년부터 2017년까지 후지츠(주)에서 엔터프라이즈용 리눅스, 그중 특히 커널 개발과 서포트 일을 주로 했다. 2017년부터는 사이보우즈(주)에서 기술고문으로 일하고 있다.