Top

리눅스 API의 모든 것 Vol. 1 기초 리눅스 API [파일, 메모리, 프로세스, 시그널, 타이머]

  • 원서명The Linux Programming Interface: A Linux and UNIX System Programming Handbook (ISBN 9781593272203)
  • 지은이마이클 커리스크
  • 옮긴이김기주, 김영주, 우정은, 지영민, 채원석, 황진호
  • ISBN : 9788960773196
  • 50,000원
  • 2012년 07월 12일 펴냄
  • 페이퍼백 | 1,120쪽 | 188*255mm
  • 시리즈 : 오픈소스 프로그래밍

책 소개

리눅스에서 프로그램을 작성할 때 사용하는 시스템 호출과 라이브러리 함수를 설명한 책으로, 해당 함수를 사용할 수 있는 리눅스 버전, 버전별 차이 등을 꼼꼼하게 정리했다. 워낙 방대한 내용이라 1권과 2권으로 나눠 구성했으며, 1권은 기초편으로, 리눅스 프로그래밍에서 흔히 쓰이는 파일 관리, 메모리 관리, 프로세스 관리, 시그널 처리, 타이머 사용법 등을 다룬다.


[ 소개 ]

리눅스와 유닉스 시스템 프로그래밍 인터페이스를 빠짐없이 다룬 최고의 안내서!

『리눅스 API의 모든 것』은 리눅스와 유닉스 프로그래밍 인터페이스(리눅스나 유닉스 시스템에서 동작하는 거의 모든 응용 프로그램이 사용하는 인터페이스)을 위한 최고의 안내서다.

리눅스 프로그래밍 전문가 마이클 커리스크는 이 권위 있는 책에서, 시스템 프로그래밍 기술을 마스터하는 데 필요한 시스템 호출과 라이브러리 함수를 자세히 설명하며, 이에 덧붙여 명확하고 완전한 예제 프로그램을 제공한다.

이 책에서는 1권과 2권 통틀어 500개가 넘는 시스템 호출과 라이브러리 함수, 200개가 넘는 예제 프로그램, 88개의 표, 115개의 다이어그램에 대한 설명이 들어 있으며, 1권에서는 다음과 같은 내용을 설명한다.

■ 파일을 효율적으로 읽고 쓰기
■ 시그널, 클록, 타이머 사용법
■ 프로세스를 만들고 프로그램 실행하기
■ 안전한 프로그램 작성법
■ 공유 라이브러리 만들고 사용하기

『리눅스 API의 모든 것』이 epoll, inotify, /proc 파일 시스템 등 수많은 리눅스 고유 기능을 다루지만, 유닉스 표준(POSIX.1-2001/SUSv3와 POSIX.1-2008/SUSv4)을 강조하기 때문에 여타 유닉스 플랫폼에서 작업하는 프로그래머들에게도 마찬가지로 가치가 크다.

『리눅스 API의 모든 것』은 리눅스와 유닉스 프로그래밍 인터페이스를 다룬 가장 포괄적인 책이며, 새로운 고전이 되리라 믿어 의심치 않는다.


[ 이 책의 대상 독자 ]

● 리눅스나 기타 유닉스, 기타 POSIX 호환 시스템용 응응 프로그램을 작성하는 프로그래머와 소프트웨어 설계자
● 리눅스와 기타 유닉스 구현 간이나 리눅스와 기타 운영체제 간에 응용 프로그램을 이식하는 프로그래머
● 리눅스/유닉스 프로그래밍 인터페이스와, 시스템 소프트웨어의 다양한 부분이 어떻게 구현됐는지를 좀 더 잘 이해하고자 하는 시스템 관리자와 ‘파워 유저’


[ 한국어판 출간에 부쳐 ]

『The Linux Programming Interface』 한국 독자 여러분께 인사를 전합니다.

『The Linux Programming Interface』(한국어판 제목: 『리눅스 API의 모든 것』)는 리눅스 시스템 프로그래밍 API를 거의 모두 설명한 책으로서 전통적인 서버, 메인프레임, 데스크탑 시스템부터 근래 리눅스를 사용하는 임베디드 디바이스에 이르기까지 광범위한 리눅스 플랫폼에 적용할 수 있습니다. 뿐만 아니라 리눅스 커널이 안드로이드의 심장부를 이루고 있기 때문에, 이 책 내용의 대부분은 안드로이드 디바이스 상의 프로그래밍에도 응용할 수 있습니다.

이 책의 영문판은 2010년 말에 출간되었습니다. 이후로 9개의 새로운 리눅스 커널 버전이 릴리스되었습니다(버전 2.6.36부터 3.4까지). 그럼에도 영문판과 이 한국어판의 내용은 여전히 최신에 가깝고, 앞으로도 수년 동안 유효할 것입니다. 그 주된 이유는 리눅스 커널의 개발이 매우 빠르지만, 커널-사용자 공간 API의 변경 속도는 매우 느리기 때문입니다(이는 커널이 사용자 공간 응용프로그램의 ‘안정적인’ 기반을 제공하도록 설계된다는 사실의 당연한 결과입니다). 따라서 최근 9개의 커널 버전을 보면, 커널-사용자 공간 API의 변경은 비교적 적었음을 알 수 있습니다. 더욱이 발생한 변경들도 이 책에 설명된 기존 기능의 ‘수정’보다는 이 책에 설명된 인터페이스에 ‘추가’되는 형태를 띱니다(다시 한 번 말하지만, 이는 커널 설계 과정의 자연적인 결과로, 리눅스 커널 개발자들은 ‘기존’ 사용자 공간 API를 깨뜨리지 않기 위해 엄청나게 애씁니다). 궁금한 독자들은 저의 웹사이트 http://man7.org/tlpi/api_changes/에서 영문판이 출판된 이래의 사용자 공간 API 변경 사항들(영문으로 되어 있음)을 찾아볼 수 있습니다.

한국어판의 독자들은 영문판과 한국어판 사이에 약간의 구조적인 차이가 있음을 참조하시면 좋겠습니다. 가장 두드러진 차이는 영문판이 한 권으로 출간된 반면, 한국어판은 한국어로 옮기는 과정에서 책의 분량이 늘어난 이유 때문에 부득이하게 두 권으로 출간된 점입니다. 그 과정에서 몇몇 장들의 순서가 약간 바뀌었습니다. POSIX 스레드를 설명한 5개의 장은 뒤쪽으로 이동하여 한국어판 2권(Vol.2)의 첫 장들로 구성되었습니다(두 권으로 나눌 경우, 저와 출판사는 이렇게 순서를 바꾸는 것이 더 합리적이라고 서로 동의했습니다).

마지막으로, 저의 책이 다른 언어로 번역되는 것은 제게는 크나큰 영광입니다. 제 책에 대한 다수의 번역 작업이 각국에서 현재 진행 중이지만, 한국어판이 세계에서 최초로 출간되는 번역서로 이름을 올렸습니다. 1,500페이지가 넘는 분량을 번역하는 일은 대단한 과업입니다. 멋진 번역을 만들어낸, 부지런하고 빠르게 작업해준 출판사와 번역 팀에게 감사합니다. 저의 작업물과, 이 책을 옮겨 준 번역 팀의 좋은 글과, 영문판에 도움을 준 여러 관계자분들의 노고가 한국어판 독자들에게 많은 도움이 되길 바랍니다.

- 2012년 6월, 독일 뮌헨에서
마이클 커리스크

저자/역자 소개

[ 저자 서문 ]

이 책은 리눅스 프로그래밍 인터페이스를 설명한다. 리눅스는 무료로 사용할 수 있는 유닉스 운영체제로서, 리눅스 프로그래밍 인터페이스에는 리눅스가 제공하는 시스템 호출, 라이브러리 함수, 기타 저수준 인터페이스가 포함된다. 리눅스에서 실행되는 모든 프로그램이 이 인터페이스를 직간접적으로 사용한다. 응용프로그램은 이 인터페이스를 사용해 파일 I/O, 파일이나 디렉토리 생성/삭제, 새 프로세스 생성, 프로그램 실행, 타이머 설정, 같은 컴퓨터 안의 프로세스와 스레드 간 통신, 네트워크로 연결된 각기 다른 컴퓨터에 존재하는 프로세스 간의 통신 등을 할 수 있다. 이 저수준 인터페이스를 시스템 프로그래밍(system programming) 인터페이스라고도 한다.

이 책은 주로 리눅스에 초점을 맞췄지만, 표준과 이식성 이슈도 소홀히 다루지 않았고, 리눅스 고유사항에 대한 논의와, 대부분의 유닉스 구현에서 공통적이고 POSIX와 단일 유닉스 명세(Single UNIX Specification)에 의해 표준화된 사항에 대한 논의를 분명히 구별했다. 따라서 이 책은 유닉스/POSIX 프로그래밍 인터페이스도 광범위하게 기술했고, 여타 유닉스 시스템을 대상으로 응용 프로그램을 작성하거나 여러 시스템에 이식할 수 있는 응용프로그램을 작성하려는 프로그래머가 활용할 수 있다.


[ 저자 소개 ]


마이클 커리스크 (Michael Kerrisk) http://man7.org
20년 이상 유닉스 시스템을 사용하고 프로그래밍을 했으며, 유닉스 시스템 프로그램을 주제로 한 많은 강의 경험이 있다. 2004년부터 리눅스 커널과 glibc 프로그래밍 API를 설명하는 매뉴얼 페이지 프로젝트를 관리했다. 250개가 넘는 매뉴얼 페이지를 작성했거나 공동 작성했고, 새로운 리눅스 커널/사용자 공간 인터페이스의 테스트와 설계 리뷰에 활발히 참여하고 있다. 마이클은 독일의 뮌헨에서 가족과 함께 살고 있다.


[ 옮긴이의 말 ]

리눅스가 지배하는 세상이 됐다. 최소한, 리눅스가 도처에서 쓰이는 세상이 되었다. 데스크탑을 정복하지는 못했지만 데스크탑보다 훨씬 많은 곳에서 리눅스가 쓰인다. 보이지 않는 곳에서 인터넷을 움직이는 서버와, 매일 들고 다니는 핸드폰과 태블릿, 자동차마다 달려 있는 내비게이션과 블랙박스, 아침에 일어나자마자, 그리고 퇴근해서 집에 오면 무심코 켜는 TV, 셋톱박스, 블루레이 플레이어, 냉장고, 인터넷 공유기, 프린터, 가정용 파일 서버 등이 리눅스로 구동된다.

『리눅스 API의 모든 것』은 리눅스에서 프로그램을 작성할 때 사용하는 시스템 호출과 라이브러리 함수를 설명한 책이다. 서버에서 동작하는 리눅스용 프로그램을 작성하는 사람들에게 좋은 참고서가 될 것이고, 역자처럼 임베디드 시스템용 프로그램을 작성하는 사람들의 경우, 임베디드 리눅스에서는 서버에서 제공되는 모든 기능을 사용할 수는 없겠지만, 많은 부분이 겹칠 것이고 활용할 수 있으리라 믿는다.

채원석 님의 제안대로 구글 닥스를 사용해 용어집을 공유하고, 번역 뒤 리뷰를 해서 문체를 다듬기는 했지만 여러 역자가 함께 작업하다 보니 문체라든지 용어 등이 약간씩 차이가 날 수 있는 점 양해 부탁드린다. 엄청난 두께의 책을 저술하고, 역자의 질문에 바로 답해준 저자의 열정에 경의를 표한다.

원서의 양이 매우 방대하고 번역 과정에서 두께가 더 두꺼워지는 바람에 저자와의 협의 끝에 두 권으로 나누어 출간하게 되었다. 1권은 기초 리눅스 API 편으로, 리눅스 프로그래밍에서 흔히 쓰이는 파일, 메모리, 사용자, 프로세스, 시간, 시그널, 타이머, 라이브러리 사용법과 작성법 등을 설명하고, 2권은 고급 리눅스 API 편으로, 좀더 세련되고 복잡한 리눅스 프로그램을 만들 때 사용되는 스레드, IPC, 소켓, 고급 I/O 등을 설명한다.

이 책은 예제가 많아 리눅스 프로그래밍을 배우고자 하는 사람들도 쉽게 따라 하면서 배울 수 있으리라 생각한다. 숙련된 프로그래머의 경우에는 인덱스를 활용해 참고서로 사용할 수 있을 것이다. 비록 두 권으로 나뉘었지만, 인덱스에는 1권과 2권에 나오는 모든 용어를 담고, 각 용어가 어느 권에 나오는지 명시했으므로, 용어를 찾는 데 어려움이 없으리라 믿는다.

리눅스는 항상 개발 중이며, 최근에는 커널 3.3이 발표되었다. 책이 출판된 뒤에 바뀐 내용에 대해서도 저자가 자신의 사이트에서 정오표(지은이의 말 참조)를 통해 안내하고 있으므로, 참고하면 도움이 될 것이다.

- 대표 역자 김기주


[ 옮긴이 소개 ]

김기주
포항공과대학교 컴퓨터공학과와 동 대학원을 졸업한 뒤 지금은 임베디드 소프트웨어를 개발하고 있다. MHP와 JavaFX TV 개발에 참여했으며, '자바원'과 '한국 자바 개발자 컨퍼런스', '썬 테크 데이' 등에서 디지털 TV와 Java ME를 소개하기도 했다. 역서로는 『임베디드 프로그래밍 입문: C와 어셈블리로 확실히 배우는』(에이콘출판, 2006)과 『실시간 UML: 임베디드 시스템에서 활용하는』(에이콘출판, 2008)이 있다.

김영주
건국대학교를 졸업한 뒤 공채 2기로 한글과컴퓨터에 입사해, 한컴고객지원센터장을 역임하고, 한컴오피스, Anti-Virus, 통합보안 등의 마케팅을 담당했다. 지금은 보안 소프트웨어 업체에서 Business Development & Marketing을 하고 있다. 「마이크로소프트웨어」, 「PCPLUS」 같은 컴퓨터월간지에서 필자로 활동했으며, 저서로는 한컴고객지원센터센터 공동 저술한 『따라해보세요, 한글 815 특별판』(한컴프레스, 1998)이 있다.

우정은
인하대학교 컴퓨터공학과를 졸업하고 현재 오라클 한국 사무실에서 Java Licensee Engineer로 근무하고 있다. 모바일 기기에 사용되는 자바 가상 머신 플랫폼과 관련된 업무를 주로 하고 있으며, 아이폰과 iOS가 출시된 이후로 다양한 원서 번역과 프로그램 개발을 즐기고 있다. 『iPhone advanced Projects』(한빛미디어, 2010), 『iPhone Programming 제대로 배우기』(한빛미디어, 2010), 『대규모 웹 개발』(한빛미디어, 2011), 『엔터프라이즈 아이폰 & 아이패드 관리자 가이드』(위키북스, 2011)의 역자이기도 하다.

지영민
고려대학교 통신시스템 석사를 졸업하고 모토로라와 삼성 SDS에서 사물 인터넷관련 연구를 진행했다. 책을 마무리 하던 시점은 삼성 SDS에 근무하고 있었으나 지금은 전자부품연구원으로 자리를 옮겨 초지일관 사물 인터넷 확산에 노력하고 있다.

채원석
포항공과대학교 컴퓨터공학과와 동 대학원을 졸업한 후 미국 시카고의 TTIC에서 프로그래밍 언어 전공으로 박사 학위를 받았다. 현재 마이크로소프트 사에서 컴파일러를 개발하고 있다. 『실시간 UML: 임베디드 시스템에서 활용하는』(에이콘출판, 2008)을 공동 번역했다.

황진호
IT 경력은 미국에서 시작됐다. 국내에서 석사 과정을 마치고 1년여 동안 미국의 연구기관에서 방문 연구원으로 재직했다. 미국에서 유명 통신회사의 시스템을 연구/개발하는 몇 가지 프로젝트를 마무리하고, 한국으로 돌아와 포스코 ICT에서 통신 시스템 소프트웨어 개발자로 3년 동안 근무했다. 현재는 미국의 조지 워싱턴 대학교의 컴퓨터 사이언스 학과에서 박사 과정을 밟는 중이며 클라우드 컴퓨팅과 빅 데이터에 관한 연구를 진행 중이다. 『Learning PHP, MySQL & JavaScript 한국어판』(에이콘출판, 2011), 『Creating iOS 5 Apps Develop and Design 한국어판』(에이콘출판, 2012)의 역자이기도 하다.

목차

목차
  • 1장 역사와 표준
    • 1.1 유닉스와 C의 간략한 역사
    • 1.2 리눅스의 간략한 역사
    • 1.3 표준화
    • 1.4 정리
  • 2장 기본 개념
    • 2.1 핵심 운영체제: 커널
    • 2.2 셸
    • 2.3 사용자와 그룹
    • 2.4 단일 디렉토리 계층구조, 디렉토리, 링크, 파일
    • 2.5 파일 I/O 모델
    • 2.6 프로그램
    • 2.7 프로세스
    • 2.8 메모리 매핑
    • 2.9 정적 라이브러리와 공유 라이브러리
    • 2.10 프로세스 간 통신과 동기화
    • 2.11 시그널
    • 2.12 스레드
    • 2.13 프로세스 그룹과 셸 작업 제어
    • 2.14 세션, 제어 터미널, 제어 프로세스
    • 2.15 가상 터미널
    • 2.16 날짜와 시간
    • 2.17 클라이언트/서버 아키텍처
    • 2.18 실시간
    • 2.19 /proc 파일 시스템
    • 2.20 정리
  • 3장 시스템 프로그래밍 개념
    • 3.1 시스템 호출
    • 3.2 라이브러리 함수
    • 3.3 표준 C 라이브러리: GNU C 라이브러리(glib)
    • 3.4 시스템 호출과 라이브러리 함수의 에러 처리
    • 3.5 이 책의 예제 프로그램
    • 3.6 이식성 이슈
    • 3.7 정리
    • 3.8 연습문제
  • 4장 파일 I/O: 범용 I/O 모델
    • 4.1 개요
    • 4.2 I/O의 범용성
    • 4.3 파일 열기: open()
    • 4.4 파일 읽기: read()
    • 4.5 파일에 쓰기: write()
    • 4.6 파일 닫기: close()
    • 4.7 파일 오프셋 변경: lseek()
    • 4.8 범용 I/O 모델 외의 오퍼레이션: ioctl()
    • 4.9 정리
    • 4.10 연습문제
  • 5장 파일 I/O: 더 자세히
    • 5.1 원자성과 경쟁 상태
    • 5.2 파일 제어 오퍼레이션: fcntl()
    • 5.3 파일 상태 플래그 열기
    • 5.4 파일 디스크립터와 열려 있는 파일의 관계
    • 5.5 파일 디스크립터 복사하기
    • 5.6 지정된 오프셋에서의 파일 I/O: pread()와 pwrite()
    • 5.7 스캐터-개더 I/O: readv()와 writev()
    • 5.8 파일 잘라내기: truncate()와 ftruncate()
    • 5.9 비블로킹 I/O
    • 5.10 큰 파일에 대한 I/O
    • 5.11 /dev/fd 디렉토리
    • 5.12 임시 파일 만들기
    • 5.13 정리
    • 5.14 연습문제
  • 6장 프로세스
    • 6.1 프로세스와 프로그램
    • 6.2 프로세스 ID와 부모 프로세스 ID
    • 6.3 프로세스의 메모리 레이아웃
    • 6.4 가상 메모리 관리
    • 6.5 스택과 스택 프레임
    • 6.6 명령행 인자(argc, argv)
    • 6.7 환경 변수 목록
    • 6.8 비지역 goto 수행: setjmp()와 longjmp()
    • 6.9 정리
    • 6.10 연습문제
  • 7장 메모리 할당
    • 7.1 힙에 메모리 할당하기
    • 7.2 스택에 메모리 할당하기: alloca()
    • 7.3 정리
    • 7.4 연습문제
  • 8장 사용자와 그룹
    • 8.1 패스워드 파일: /etc/passwd
    • 8.2 섀도 패스워드 파일: /etc/shadow
    • 8.3 그룹 파일: /etc/group
    • 8.4 사용자와 그룹 정보 읽기
    • 8.5 패스워드 암호화와 사용자 인증
    • 8.6 정리
    • 8.7 연습문제
  • 9장 프로세스 자격증명
    • 9.1 실제 사용자 ID와 실제 그룹 ID
    • 9.2 유효 사용자 ID와 유효 그룹 ID
    • 9.3 set-user-ID와 set-group-ID 프로그램
    • 9.4 저장된 Set-User-ID와 저장된 Set-Group-ID
    • 9.5 파일 시스템 사용자 ID와 파일 시스템 그룹 ID
    • 9.6 추가 그룹 ID
    • 9.7 프로세스 자격증명 읽고 수정하기
    • 9.8 정리
    • 9.9 연습문제
  • 10장 시간
    • 10.1 달력 시간
    • 10.2 시간 변환 함수
    • 10.3 시간대
    • 10.4 로케일
    • 10.5 시스템 클록 갱신하기
    • 10.6 소프트웨어 클록
    • 10.7 프로세스 시간
    • 10.8 정리
    • 10.9 연습문제
  • 11장 시스템 한도와 옵션
    • 11.1 시스템 한도
    • 11.2 실행 시에 시스템 한도(그리고 옵션) 구하기
    • 11.3 실행 시에 파일 관련 한도(그리고 옵션) 읽기
    • 11.4 결정되지 않은 한도
    • 11.5 시스템 옵션
    • 11.6 정리
    • 11.7 연습문제
  • 12장 시스템과 프로세스 정보
    • 12.1 /proc 파일 시스템
    • 12.2 시스템 식별: uname()
    • 12.3 정리
    • 12.4 연습문제
  • 13장 파일 I/O 버퍼링
    • 13.1 파일 I/O의 커널 버퍼링: 버퍼 캐시
    • 13.2 stdio 라이브러리 내의 버퍼링
    • 13.3 파일 I/O의 커널 버퍼링 제어
    • 13.4 I/O 버퍼링 요약
    • 13.5 I/O 패턴에 대한 커널 조언
    • 13.6 버퍼 캐시 우회: 직접 I/O
    • 13.7 파일 I/O를 위한 라이브러리 함수와 시스템 호출의 혼합
    • 13.8 정리
    • 13.9 연습문제
  • 14장 파일 시스템
    • 14.1 디바이스 특수 파일(디바이스)
    • 14.2 디스크와 파티션
    • 14.3 파일 시스템
    • 14.4 i-노드
    • 14.5 가상 파일 시스템(VFS)
    • 14.6 저널링 파일 시스템
    • 14.7 단일 디렉토리 계층과 마운트 지점
    • 14.8 파일 시스템의 마운트와 마운트 해제
    • 14.9 고급 마운트 기능
    • 14.10 가상 메모리 파일 시스템: tmpfs
    • 14.11 파일 시스템 정보 획득: statvfs()
    • 14.12 정리
    • 14.13 연습문제
  • 15장 파일 속성
    • 15.1 파일 정보 추출: stat()
    • 15.2 파일 타임스탬프
    • 15.3 파일 소유권
    • 15.4 파일 권한
    • 15.5 i-노드 플래그(ext2 확장 파일 속성)
    • 15.6 정리
    • 15.7 연습문제
  • 16장 확장 속성
    • 16.1 개요
    • 16.2 확장 속성 구현 세부사항
    • 16.3 확장 속성 조작을 위한 시스템 호출
    • 16.4 정리
    • 16.5 연습문제
  • 17장 ACL
    • 17.1 개요
    • 17.2 ACL 권한 검사 알고리즘
    • 17.3 ACL의 길고 짧은 텍스트 형식
    • 17.4 ACL_MASK 엔트리와 ACL 그룹 클래스
    • 17.5 getfacl과 setfacl 명령
    • 17.6 기본 ACL과 파일 생성
    • 17.7 ACL 구현 제항사항
    • 17.8 ACL API
    • 17.9 정리
    • 17.10 연습문제
  • 18장 디렉토리와 링크
    • 18.1 디렉토리와 (하드) 링크
    • 18.2 심볼릭(소프트) 링크
    • 18.3 (하드) 링크 생성과 제거: link()와 unlink()
    • 18.4 파일이름 변경: rename()
    • 18.5 심볼릭 링크 관련 작업: symlink()와 readlink()
    • 18.6 디렉토리 생성과 제거: mkdir()과 rmdir()
    • 18.7 파일이나 디렉토리 제거: remove()
    • 18.8 디렉토리 읽기: opendir()과 readdir()
    • 18.9 파일 트리 검색: nftw()
    • 18.10 프로세스의 현재 작업 디렉토리
    • 18.11 디렉토리 파일 식별자 관련 작업 운용
    • 18.12 프로세스의 루트 디렉토리 변경: chroot()
    • 18.13 경로명 결정: realpath()
    • 18.14 경로명 문자열 파싱: dirname()과 basename()
    • 18.15 정리
    • 18.16 연습문제
  • 19장 파일 이벤트 감시
    • 19.1 개요
    • 19.2 inotify API
    • 19.3 inotify 이벤트
    • 19.4 inotify 이벤트 읽기
    • 19.5 큐 한도와 /proc 파일
    • 19.6 파일 이벤트 감시의 오래된 시스템: dnotify
    • 19.7 정리
    • 19.8 연습문제
  • 20장 시그널: 기본 개념
    • 20.1 개념과 개요
    • 20.2 시그널 형식과 기본 동작
    • 20.3 시그널 속성 변경: signal()
    • 20.4 시그널 핸들러 소개
    • 20.5 시그널 전송: kill()
    • 20.6 프로세스 존재 여부 검사
    • 20.7 시그널을 보내는 그 밖의 방법: raise()와 killpg()
    • 20.8 시그널 설명 출력
    • 20.9 시그널 집합
    • 20.10 시그널 마스크(시그널 전달 블록)
    • 20.11 보류 중인 시그널
    • 20.12 시그널은 큐에 들어가지 않는다
    • 20.13 시그널 속성 변경: sigaction()
    • 20.14 시그널 대기: pause()
    • 20.15 정리
    • 20.16 연습문제
  • 21장 시그널: 시그널 핸들러
    • 21.1 시그널 핸들러 설계
    • 21.2 시그널 핸들러를 종료하는 그 밖의 방법
    • 21.3 대체 스택의 시그널 처리: sigaltstack()
    • 21.4 SA_SIGINFO 플래그
    • 21.5 시스템 호출 인터럽트와 재시작
    • 21.6 정리
    • 21.7 연습문제
  • 22장 시그널: 고급 기능
    • 22.1 코어 덤프 파일
    • 22.2 전달, 속성, 처리의 특별한 경우
    • 22.3 인터럽트 가능과 불가능 프로세스 수면 상태
    • 22.4 하드웨어 생성 시그널
    • 22.5 동기와 비동기 시그널 생성
    • 22.6 시그널 전달 시점과 순서
    • 22.7 signal()의 구현과 이식성
    • 22.8 실시간 시그널
    • 22.9 마스크를 이용한 시그널 대기: sigsuspend()
    • 22.10 동기적 시그널 대기
    • 22.11 파일 식별자를 통한 시그널 획득
    • 22.12 시그널을 통한 프로세스 간 통신
    • 22.13 구형 시그널 API(시스템 V와 BSD)
    • 22.14 정리
    • 22.15 연습문제
  • 23장 타이머와 수면
    • 23.1 시간 간격 타이머
    • 23.2 타이머 스케줄링과 정확성
    • 23.3 블로킹 오퍼레이션에 타임아웃 설정
    • 23.4 일정 시간 동안 실행 중지(수면)
    • 23.5 POSIX 클록
    • 23.6 POSIX 시간 간격 타이머
    • 23.7 파일 식별자를 통해 통지하는 타이머: timerfd API
    • 23.8 정리
    • 23.9 연습문제
  • 24장 프로세스 생성
    • 24.1 fork(), exit(), wait(), execve() 소개
    • 24.2 새 프로세스의 생성: fork()
    • 24.3 vfork() 시스템 호출
    • 24.4 fork() 후의 경쟁 상태
    • 24.5 시그널 동기를 통한 경쟁 상태 회피
    • 24.6 정리
    • 24.7 연습문제
  • 25장 프로세스 종료
    • 25.1 프로세스 종료하기: _exit()와 exit()
    • 25.2 프로세스 종료 자세히 들여다보기
    • 25.3 종료 핸들러
    • 25.4 fork(), stdio 버퍼, _exit()의 상호작용
    • 25.5 정리
    • 25.6 연습문제
  • 26장 자식 프로세스 감시
    • 26.1 자식 프로세스 기다리기
    • 26.2 고아와 좀비 프로세스
    • 26.3 SIGCHLD 시그널
    • 26.4 정리
    • 26.5 연습문제
  • 27장 프로그램 실행
    • 27.1 새 프로그램 실행하기: execve()
    • 27.2 exec() 라이브러리 함수
    • 27.3 인터프리터 스크립트
    • 27.4 파일 디스크립터와 exec()
    • 27.5 시그널과 exec()
    • 27.6 셸 명령 실행하기: system()
    • 27.7 system() 구현하기
    • 27.8 정리
    • 27.9 연습문제
  • 28장 더 자세히 살펴보는 프로세스 생성과 프로그램 실행
    • 28.1 프로세스 어카운팅
    • 28.2 clone() 시스템 호출
    • 28.3 프로세스 생성 속도
    • 28.4 exec()와 fork()가 프로세스 속성에 미치는 영향
    • 28.5 정리
    • 28.6 연습문제
  • 29장 프로세스 그룹, 세션, 작업 제어
    • 29.1 개요
    • 29.2 프로세스 그룹
    • 29.3 세션
    • 29.4 터미널 제어와 프로세스 제어
    • 29.5 포그라운드와 백그라운드 프로세스 그룹
    • 29.6 SIGHUP 시그널
    • 29.7 작업 제어
    • 29.8 정리
    • 29.9 연습문제
  • 30장 프로세스 우선순위와 스케줄링
    • 30.1 프로세스 우선순위(nice 값)
    • 30.2 실시간 프로세스 스케줄링 개요
    • 30.3 실시간 프로세스 스케줄링 API
    • 30.4 CPU 친화도
    • 30.5 정리
    • 30.6 연습문제
  • 31장 프로세스 자원
    • 31.1 프로세스 자원 사용
    • 31.2 프로세스 자원 한도
    • 31.3 구체적인 자원 한도 세부사항
    • 31.4 정리
    • 31.5 연습문제
  • 32장 데몬
    • 32.1 개요
    • 32.2 데몬 생성
    • 32.3 데몬 작성의 지침서
    • 32.4 데몬을 다시 초기화하기 위해 SIGHUP 사용
    • 32.5 syslog를 사용한 메시지와 에러 기록
    • 32.6 정리
    • 32.7 연습문제
  • 33장 안전한 특권 프로그램 작성
    • 33.1 set-user-ID나 set-group-ID 프로그램이 필요한가?
    • 33.2 최소 특권으로 운영하기
    • 33.3 프로그램 실행 시 주의사항
    • 33.4 중요한 정보의 노출 피하기
    • 33.5 프로세스 제한
    • 33.6 시그널과 경쟁 상태 인지
    • 33.7 파일 오퍼레이션과 파일 I/O 실행 시 위험성
    • 33.8 입력이나 환경을 믿지 말자
    • 33.9 버퍼 오버런 인지
    • 33.10 서비스 거부 공격 인지
    • 33.11 리턴 상태 검사와 안전하게 실패하기
    • 33.12 정리
    • 33.13 연습문제
  • 34장 능력
    • 34.1 능력을 사용하는 이유
    • 34.2 리눅스 능력 기능
    • 34.3 프로세스와 파일 능력 기능
    • 34.4 현대적인 능력 기능 구현
    • 34.5 exec() 동안 프로세스 능력 기능 변경
    • 34.6 사용자 ID 변경 프로세스 능력의 효과
    • 34.7 프로그램적으로 프로세스 능력 변경
    • 34.8 능력 기능만의 환경 생성
    • 34.9 프로그램에 요구되는 능력 기능 찾기
    • 34.10 파일 능력 기능이 없는 이전의 커널과 시스템
    • 34.11 정리
    • 34.12 연습문제
  • 35장 로그인 계정
    • 35.1 utmp와 wtmp 파일의 개요
    • 35.2 utmpx API
    • 35.3 utmpx 구조
    • 35.4 utmp와 wtmp 파일에서 정보 추출
    • 35.5 로그인 이름 추출: getlogin()
    • 35.6 로그인 세션을 위한 utmp와 wtmp 파일 갱신
    • 35.7 lastlog 파일
    • 35.8 정리
    • 35.9 연습문제
  • 36장 공유 라이브러리 기초
    • 36.1 오브젝트 라이브러리
    • 36.2 정적 라이브러리
    • 36.3 공유 라이브러리 개요
    • 36.4 공유 라이브러리 생성과 사용(첫 번째 단계)
    • 36.5 공유 라이브러리의 유용한 툴
    • 36.6 공유 라이브러리 버전과 이름 짓기 규칙
    • 36.7 공유 라이브러리 설치하기
    • 36.8 호환과 비호환 라이브러리
    • 36.9 공유 라이브러리 업그레이드하기
    • 36.10 오브젝트 파일에 라이브러리 검색 디렉토리 경로 지정하기
    • 36.11 실행 시에 공유 라이브러리 찾기
    • 36.12 실행 시 심볼 해석
    • 36.13 공유 라이브러리 대신 정적 라이브러리 사용하기
    • 36.14 정리
    • 36.15 연습문제
  • 37장 공유 라이브러리의 고급 기능
    • 37.1 동적으로 라이브러리 적재하기
    • 37.2 심볼의 가시성 조절하기
    • 37.3 링커 버전 스크립트
    • 37.4 함수의 초기화와 마무리
    • 37.5 공유 라이브러리 미리 로딩하기
    • 37.6 동적 링커 감시하기: LD_DEBUG
    • 37.7 정리
    • 37.8 연습문제
  • 부록
  • A 시스템 호출 추적하기
  • B 명령행 옵션 파싱하기
  • C NULL 포인터 캐스팅하기
  • D 커널 설정
  • E 추가 정보
  • F 연습문제 해답

  • [리눅스 API의 모든 것 Vol. 2 고급 리눅스 API 목차]
  • 1장 스레드: 소개
  • 2장 스레드: 스레드 동기화
  • 3장 스레드: 스레드 안전성과 스레드별 저장소
  • 4장 스레드: 스레드 취소
  • 5장 스레드: 기타 세부사항
  • 6장 프로세스 간 통신 개요
  • 7장 파이프와 FIFO
  • 8장 시스템 V IPC 소개
  • 9장 시스템 V 메시지 큐
  • 10장 시스템 V 세마포어
  • 11장 시스템 V 공유 메모리
  • 12장 메모리 매핑
  • 13장 가상 메모리 동작
  • 14장 POSIX IPC 소개
  • 15장 POSIX 메시지 큐
  • 16장 POSIX 세마포어
  • 17장 POSIX 공유 메모리
  • 18장 파일 잠금
  • 19장 소켓: 소개
  • 20장 소켓: 유닉스 도메인
  • 21장 소켓: TCP/IP 네트워크 기초
  • 22장 소켓: 인터넷 도메인
  • 23장 소켓: 서버 설계
  • 24장 소켓: 고급 옵션
  • 25장 터미널
  • 26장 대체 I/O 모델
  • 27장 가상 터미널

도서 오류 신고

도서 오류 신고

에이콘출판사에 관심을 가져 주셔서 고맙습니다. 도서의 오탈자 정보를 알려주시면 다음 개정판 인쇄 시 반영하겠습니다.

오탈자 정보는 다음과 같이 입력해 주시면 됩니다.

(예시) p.100 아래에서 3행 : '몇일'동안 -> 며칠동안

정오표

정오표

 2012년 7월 발행 오류/오탈자 

[ p120 첫 행 추가 ]
if(useErr)

[ p.62 10행 ]
x는 주 버전, y는 부 버전, y는 부 버전의 개정판 → x는 주 버전, y는 부 버전, z는 부 버전의 개정판

2016. 12. 8 수정사항

[p736: 리스트 26-4 좀비 자식 프로세스의 생성 (예제코드) 7행]
(cmd[CMDSIZE - 1]
= '\0';
->
cmd[CMD
SIZE - 1]
= '\0';

2016. 12. 12 수정사항

[p.823: 아래에서 1행]
int
->
int main(int argc, char *argv[]
)