로그인회원가입장바구니고객센터마이페이지회사소개
kangcom
전체
Home >   >   > 

파이썬 병렬 프로그래밍

 [threading, multiprocessing, PP, Celery, asyncio 모듈 이해와 활용]
   
지은이 얀 팔라흐   |   출판사 에이콘  |   발행일 2016년 10월 28일
 
클릭하시면 큰 도서이미지를 보실 수 있습니다.
판매가 14,000원12,600원 10%
마일리지 5% 700원
발행일 2016-10-28
ISBN 8960779202 | 9788960779204
기타정보 번역서 | 148쪽 | 일반
예상출고일 금일 가능 (근무일기준)
배송비 2,000원 (20,000원이상 무료배송)
   
프로그래밍언어
종합지수 0p
   
이 책의 원서
  Parallel Programming with Python
Packt Publishing | Jan Palach
 

[요약 ]

고성능 병렬 컴퓨팅 시스템을 개발하고 유지 보수하기 위해 필요한 모든 내용을 다룬다. 먼저 병렬, 동시성, 분산의 개념부터 병렬화와 관련된 문제점과 대안을 살펴본 후, 파이썬의 스레드 기반 threading 모듈과 프로세스 기반 multiprocessing 모듈, 병렬 태스크를 수행하는 패러럴 파이썬(PP)과 분산 처리를 위한 셀러리(celery), 비동기 프로그래밍이 가능한 asyncio 모듈을 설명한다. 각 파이썬 모듈 사용법에 대한 명쾌한 이해를 돕기 위해 피보나치 수열 계산과 웹 수집기 구현 방법을 사례로 들어 간결하게 풀어나간다.


[ 이 책에서 다루는 내용 ]

■ 병렬화 문제 관련 기술
■ 파이썬 코드를 구현하기 위한 패러럴 파이썬 모듈 통합
■ 간단한 문제에 관한 병렬 해결책 실행.
■ 파이프와 큐를 이용한 프로세스 간의 통신
■ 셀러리 분산 태스크 큐 사용
■ 파이썬 asyncio 모듈을 이용한 비동기 I/O 구현
■ 스레드에 안전한 구조 생성


[이 책의 대상 독자]

능숙한 파이썬 프로그래머며 간단한 방법으로 병렬 애플리케이션에서 가용 컴퓨팅 리소스를 활용하고 싶다면, 이 책은 당신을 위한 책이다. 이 책을 최대한 활용하기 위해서는 파이썬 개발에 대한 기본 지식이 필요하다.


[ 이 책의 구성 ]

1장, ‘병렬, 동시성, 분산 프로그래밍 문맥 설명’에서는 병렬 프로그래밍 모델의 개념, 장단점과 구현을 다룬다. 덧붙여 병렬 솔루션을 구현하기 위한 몇몇 파이썬 라이브러리를 제시한다.
2장, ‘병렬 알고리즘 설계’에서는 병렬 알고리즘을 설계하기 위한 몇 가지 기술에 관해 논의한다.
3장, ‘병렬화 문제 확인’에서는 병렬과 관련된 문제를 예시로 소개한 후, 이 문제를 병렬 조각으로 나눌 수 있는지 분석한다.
4장, ‘threading과 concurrent.futures 모듈 사용’에서는 3장, ‘병렬화 문제 확인’에서 제시한 각 문제를 threading과 concurrent.futures 모듈을 사용해 구현하는 방법을 설명한다.
5장, ‘multiprocessing과 ProcessPoolExecutor 모듈 사용’에서는 3장, ‘병렬화 문제 확인’에서 제시한 각 문제를 multiprocessing과 ProcessPoolExecutor 모듈을 사용해 구현하는 방법을 설명한다.
6장, ‘패러렐 파이썬 활용’에서는 3장, ‘병렬화 문제 확인’에서 제시한 각 문제를 병렬 파이썬 모듈을 사용해 구현하는 방법을 제시한다.
7장, ‘셀러리를 이용한 태스크 분산’에서는 3장, ‘병렬화 문제 확인’에서 제시한 각 문제를 셀러리 분산 태스크 큐를 사용해 구현하는 방법을 제시한다.
8장, ‘비동기 프로그래밍’에서는 asyncio 모듈을 사용하는 방법과 비동기 프로그래밍에 관한 방법을 설명한다.


[ 지은이의 말 ]

몇 달 전 팩트출판사 전문 기획자에게 파이썬을 이용한 병렬 프로그래밍에 관한 책을 써달라는 연락을 받았다. 기존에는 책을 쓰겠다는 생각은 전혀 없었으며, 갑작스러웠기에 어떻게 해야만 할지, 책을 구상하는 것이 얼마나 복잡할 것인지, 작업 일정을 어떻게 맞춰야 할지 막막하기만 했다. 하지만 며칠 동안 고민하다가 결국 미션을 받아들였는데, 개인적으로 많이 배울 수 있고, 전 세계 독자에게 파이썬 지식을 전파할 수 있는 완벽한 기회가 될 것이라고 생각했고 내 인생의 여정에 가치가 있는 유산으로 남았으면 하는 바람이 있었기 때문이다.
이번 작업의 첫 단계는 주제 결정이었다. 모든 독자를 쉽게 만족시킬 수 없겠지만, 이론과 실무를 조합한 파이썬 병렬 프로그래밍을 소개한 이 작은 책에는 제안했던 주제가 골고루 안배됐다고 믿는다. 이번 작업은 모험이었다. 첫 장에서 정의한 예제의 문제를 풀 수 있는 방법을 보여준 후, 책의 분량을 감안해 제공한 도구를 사용해 해결하는 새로운 포맷을 사용했다. 독자가 파이썬이 제공하는 여러 가지 모듈을 분석하고 질문하게 해주는 매우 흥미로운 포맷이라고 생각한다.
모든 장에 약간의 이론을 넣었는데, 사례를 따라가기 위한 몇 가지 기본 지식을 제공하도록 맥락을 구성했다. 이 책이 파이썬 병렬 프로그래밍 세계 속으로 모험할 때 도움이 되기를 진심으로 바란다. 그만큼 완벽하게 집필하려고 노력했다.

1장. 병렬, 동시성, 분산 프로그래밍 문맥 설명
__병렬 프로그래밍을 왜 사용하는가
__일반적인 병렬화
__병렬 프로그래밍에서의 통신
____공유 상태 이해
____메시지 전달 이해
__병렬 프로그래밍 문제점 확인
____교착상태
____기아상태
____경쟁 조건
__파이썬 병렬 프로그래밍 도구 찾기
____파이썬 threading 모듈
____파이썬 multiprocessing 모듈
____패러렐 파이썬 모듈
____셀러리: 분산 태스크 큐
__파이썬 GIL에 관한 주의 사항
__요약

2장. 병렬 알고리즘 설계
__분할 정복 기법
__데이터 분해 사용
__파이프라인으로 태스크 분해
__프로세스 매핑
____독립 태스크 식별
____데이터 교환이 필요한 태스크 식별
____부하 분산
__요약

3장. 병렬화 문제 확인
__여러 입력으로 가장 높은 피보나치 값 얻기
__웹 수집
__요약

4장. threading과 concurrent.futures 모듈 사용
__스레드 정의
____스레드 사용에 따른 장단점
____스레드의 다른 종류 이해
____스레드 상태 정의
____thread과 _thread 중 하나를 선택
__여러 입력으로 피보나치 수열 항을 얻기 위해 스레드 사용
__concurrent.futures 모듈을 이용해 웹 수집
__요약

5장. multiprocessing과 ProcessPoolExecutor 모듈 사용
__프로세스 개념 이해
____프로세스 모델 이해
________프로세스 상태 정의
____다중처리 통신 구현
____multiprocessing.Pipe 사용
____multiprocessing.Queue 이해
__여러 입력으로 피보나치 수열 항을 얻는 multiproce ssing 사용
__ProcessPoolExecutor를 이용한 웹 수집
__요약

6장. 패러렐 파이썬 활용
__프로세스 간 통신 이해
____네임드 파이프 살펴보기
____파이썬으로 네임드 파이프 사용
________네임드 파이프에 쓰기
________네임드 파이프 읽기
________PP 발견
__SMP 아키텍처에서 PP를 이용해 피보나치 수열 항 계산
__PP를 이용해 분산 웹 수집기 만들기
__요약

7장. 셀러리를 이용한 태스크 분산
__셀러리 이해
____왜 셀러리를 사용하는가
__셀러리 아키텍처 이해
____태스크로 작업
____메시지 전송(브로커) 발견
____작업자 이해
____결과 뒷단 이해
__환경 설정
____클라이언트 머신 설정
____서버 머신 설정
__간단한 태스크 디스패치
__셀러리로 피보나치 수열 항 얻기
__태스크 타입으로 큐 정의
__셀러리를 이용해 분산 웹 수집기 만들기
__요약

8장. 비동기 프로그래밍
__블록킹, 논블록킹, 비동기 연산 이해
____블록킹 연산 이해
____논블록킹 연산 이해
____비동기 연산 이해
__이벤트 루프 이해
____폴링 함수
____이벤트 루프 사용
__asyncio 사용
____동시 실행 루틴과 asyncio.Future 이해
________동시 실행 루틴과 asyncio.Future 사용
________asyncio.Task 사용
________호환성이 없는 라이브러리를 asyncio와 함께 사용하기
__요약

얀 팔라흐(Jan Palach)
경력 13년차의 소프트웨어 개발자다. C++, 자바, 파이썬 기술을 사용해 민간 회사를 위해 과학 시각화와 백엔드단을 개발해왔다. 브라질의 리우데자네이루(Rio de Janeiro)에 있는 에스따씨오 데 사(Estacio de Sa) 대학교에서 정보 시스템 학위, 파라나 주 연방 기술(Parana State Federal Technological) 대학교에서 석사 학위를 받았다. 현재는 C++ 시스템을 구현하는 통신 부문에 속한 민간 기업에서 수석 시스템 분석가로 근무하고 있다. 기술적으로 열광하는 파이썬과 얼랭으로 재미있게 실험하기를 좋아한다. 자연스러운 호기심으로 새로운 기술에 도전해 공부하고, 낯선 사람을 만나고, 다른 문화에 대해 배우기를 좋아한다.

등록된 서평이 없습니다.
SQL 전문가 가이드 [The Guide for SQL Professional](2013 Edition)...
한국데이터베이스진흥원
선택된 상품을 찜하실 수 있습니다. 선택된 상품을 바로구매 하실 수 있습니다.
개발자가 반드시 알아야 할 자바 성능 튜닝 이야기...
이상민
선택된 상품을 찜하실 수 있습니다. 선택된 상품을 바로구매 하실 수 있습니다.
자바 네트워크 소녀 Netty(네티)...
정경석
선택된 상품을 찜하실 수 있습니다. 선택된 상품을 바로구매 하실 수 있습니다.
 
전체평균(0)
회원평점   회원서평수 0
에이콘 출판사의 신간
도커 컨테이너
크리스토퍼 네거스 저
27,000원
(10%↓+5%)
 
유니티 애니메이션 에센셜
앨런 톰 저
18,000원
(10%↓+5%)
 
안드로이드 카드보드 VR 프로젝트
조나단 리노위즈, 매트 쇤 저
27,000원
(10%↓+5%)
 
자바 딥러닝의 핵심
유스케 스고모리 저
22,500원
(10%↓+5%)
 
안드로이드 모바일 앱 모의해킹
조정원, 김명근, 조승현, 류진영, 김광수 저
36,000원
(10%↓+5%)
 
이메일주소수집거부