-- 會員 / 註冊 --  
 帳號:
 密碼:
  | 註冊 | 忘記密碼
3/26 新書到! 3/19 新書到! 3/14 新書到! 12/12 新書到!
購書流程Q & A站務留言版客服信箱
3ds MaxMayaRhinoAfter EffectsSketchUpZBrushPainterUnity
PhotoShopAutoCadMasterCamSolidWorksCreoUGRevitNuke
C#CC++Java遊戲程式Linux嵌入式PLCFPGAMatlab
駭客資料庫搜索引擎影像處理FluentVR+ARANSYS深度學習
單晶片AVROpenGLArduinoRaspberry Pi電路設計CadenceProtel
HadoopPythonStm32CortexLabview手機程式AndroidiPhone
可查書名,作者,ISBN,3dwoo書號
詳細書籍分類

Docker容器實戰:原理、架構與應用

( 簡體 字)
作者:廖煜,晏東類別:1. -> 作業系統 -> Docker
譯者:
出版社:電子工業出版社Docker容器實戰:原理、架構與應用 3dWoo書號: 45628
詢問書籍請說出此書號!

有庫存
NT售價: 275

出版日:11/1/2016
頁數:276
光碟數:0
站長推薦:
印刷:黑白印刷語系: ( 簡體 版 )
加入購物車 加到我的最愛
(請先登入會員)
ISBN:9787121302442
作者序 | 譯者序 | 前言 | 內容簡介 | 目錄 | 
(簡體書上所述之下載連結耗時費功, 恕不適用在台灣, 若讀者需要請自行嘗試, 恕不保證)
作者序:

譯者序:

前言:

為什么要寫這本書?
在2013年3月,Docker項目正式開源。短短的三年中,Docker已經迅速普及開來,云計算、大數據、互聯網等相關IT技術公司紛紛開始擁抱Docker。在硅谷,有200多家Docker相關的創業公司。Google、Microsoft、AWS、IBM等大型技術公司都已經加入Docker生態圈,開始使用Docker,并為Docker社區共享。OpenStack、Hadoop等云計算、大數據框架也開始向Docker遷移。
在國內,從Docker誕生之日起,各大技術公司和極客們就開始緊密關注這項技術。從2014年下半年開始,陸續有公司開始把現有系統遷移到Docker平臺。BAT、華為、新浪、京東都有Docker相關產品上線。Docker的普及愈演愈烈,大有掀起第二次云計算革命之勢。
筆者從2014年年初開始接觸Docker,一下就被Docker的輕量性、便捷性所吸引。通過在實際項目中使用Docker,發現Docker天生就是要解決敏捷開發、持續集成、持續發布、動態遷移、動態伸縮等互聯網、云計算、大數據行業普遍存在的問題。通過把產品容器化,加速了開發、測試、發布的流程,產品發布時間從半天減少到47秒。通過鏡像提交產品,解決了開發、測試、發布的環境異構性問題,使產品可以平滑地在各個部門之間傳遞。
在Docker的實際使用中,筆者遇到了很多棘手的問題,花費了大量的時間研究、分析、測試、解決這些問題。同時,筆者也發現很多初學者正在重復筆者走過的一些彎路。究其原因,是目前國內沒有一本詳細介紹Docker實戰的書籍。因此,筆者決定把自己的一些經驗總結出來,編撰成書,為廣大讀者服務。
本書有何特色?
1.配置詳細
本書涵蓋Docker Daemon、Docker存儲驅動、Docker鏡像倉庫的所有配置選項,并對每個選項都有詳細的介紹。
2.注重實踐性
本書從實踐出發,介紹在實際應用場景中應該如何定制Docker。詳細介紹鏡像制作的步驟、指令和最佳實踐,各種存儲驅動的區別和使用場合,以及Docker Daemon各種擴展功能和接口的使用方法,并列舉了典型鏡像的使用方法。
3.對Docker框架和原理進行分析
本書深入淺出地介紹Docker使用的核心技術:Namespace、CGroups和UnionFS。方便讀者理解Docker原理,并在實際應用中可以更好地使用Docker。
4.項目案例典型,實戰性強,有較高的應用價值
本書中的第11章和第12章專門從實踐出發,詳細介紹鏡像和容器的使用,并列出詳細步驟,方便讀者快速上手。
5.提供完善的技術支持和售后服務
本書提供專門的技術支持郵箱:book@ghostcloud.cn。讀者在閱讀本書過程中有任何疑問都可以通過該郵箱獲得幫助。
本書內容及知識體系
第1篇 Docker基礎知識介紹(第1∼3章)
本篇介紹云計算的歷史和基本概念,Docker的安裝和基本使用。幫助讀者對Docker有一個基本的了解,并搭建自己的Docker環境。
第2篇 Docker的基本使用(第4∼7章)
本篇介紹Docker的構架、Docker的工作方式、下載鏡像、制作鏡像、運行容器、配置容器網絡、在容器中實現數據持久化、備份還原遷移容器卷、關聯容器代碼做持續集成、查找鏡像、下載鏡像、上傳鏡像等內容。
第3篇 Docker的高級使用(第8∼13章)
本篇主要介紹Docker中的存儲驅動、配置Docker Daemon、制作鏡像和搭建倉庫等內容。
Docker鏡像提供了豐富的應用,對于Docker的流行起了重要作用。本篇詳細介紹如何制作鏡像,為讀者介紹基本指令和最佳實踐。Docker鏡像和容器有非常緊密的聯系,本篇詳細介紹兩者的關系。
鏡像和容器是通過Docker的存儲驅動管理的。Docker中有多種存儲驅動,每種存儲驅動在性能、可擴展性、安全性上有差別,不同應用場景應該選擇不同的存儲驅動。本篇詳細介紹各種存儲驅動,為讀者在實際應用中選擇存儲驅動做指導。
Docker Daemon是Docker管理鏡像和容器的核心,除基本功能外,還提供很多擴展功能和接口。本篇詳細介紹每種擴展功能和接口的具體使用方法。
第4篇 Docker常見問題(第14章)
本篇主要總結Docker學習中遇到的一些問題,為讀者提供統一的解釋。
適合閱讀本書的讀者
?在校計算機相關專業的學生;
?Docker初學者;
?基于UNIX/Linux環境的系統運維人員;
?基于UNIX/Linux環境的測試人員;
?基于UNIX/Linux環境的開發人員;
?系統構架師;
?CTO;
?互聯網行業的開發、測試、運維人員;
?初創公司的技術人員;
?云計算、大數據行業的技術人員。
閱讀本書的建議
?沒有云計算背景知識的讀者,建議從第1章順次閱讀。
?對于還沒有使用過Docker的讀者,建議從第2章開始閱讀,首先搭建自己的實驗環境。
?對于特別關注Docker在存儲方面的讀寫速度、穩定性、安全性的讀者,建議詳細閱讀第8章。
?對于需要在特定環境下定制Docker Daemon的讀者,建議詳細閱讀第9章,學習如何修改Docker Daemon的配置,以適應具體應用場景。
?對于希望在開發、測試、部署中使用Docker鏡像提交產品的開發人員和運維人員,建議詳細閱讀第10章和第11章,學習如何制作鏡像。
?對于希望直接使用容器提供服務的讀者,可以詳細閱讀第12章,學習如何使用官方鏡像運行容器。
?對于需要建立私有倉庫管理鏡像的讀者,可以詳細閱讀第13章,學習搭建私有鏡像倉庫。
?每章中都介紹詳細的配置選項,讀者需要通過實驗,深刻理解和熟練地使用這些選項。
?讀者可以首先通讀一遍本書,對Docker使用過程有一個大概的了解,然后根據自己的應用場景,詳細閱讀相關章節。
內容簡介:

本書介紹了Docker容器技術的背景和基本原理,以及如何定制化符合用戶要求的Docker Daemon,增加安全性、提高效率。.鏡像提供了千差萬別的服務,每一個鏡像都是要滿足用戶的某種需求。如何制作出體積小、安全性高、可配置性強的鏡像是困擾很多開發者的問題,書中詳細介紹了相關解決方案。本書的最后還介紹了各種流行的開源項目,讓讀者了解Docker生態圈。

目錄:

第1篇 Docker基礎知識介紹
第1章 云計算簡介 2
1.1 虛擬化技術的分類和歷史 3
1.1.1 硬件級虛擬化歷史 3
1.1.2 操作系統級虛擬化歷史 4
1.2 云計算服務模式 4
1.3 Docker介紹 5
1.3.1 Docker主要解決什么問題 6
1.3.2 Docker的歷史 6
1.3.3 Docker是什么 6
1.4 Linux快速入門 7
1.4.1 選取什么發行版本 7
1.4.2 使用圖形界面還是命令行界面 8
1.4.3 英文還是中文 8
1.4.4 安裝Ubuntu 14.04 8
1.4.5 Linux常用工具 11
1.4.6 啟用root 用戶 12
1.4.7 使用vim 12
1.4.8 配置網絡 13
1.4.9 啟用SSH Server 13
1.4.10 通過客戶端遠程連接Linux主機 14
1.4.11 免密碼登錄Linux主機 15
1.4.12 安裝軟件 15
1.4.13 公有云主機快速入門 16
1.4.14 購買云主機 17
1.4.15 連接到云主機 19
1.5 習題 21
第2章 Docker的安裝 22
2.1 在Ubuntu下安裝Docker 22
2.1.1 前置條件 22
2.1.2 更新apt源 23
2.1.3 Ubuntu 14.04特殊處理 24
2.1.4 正式安裝 24
2.2 在CentOS下安裝 26
2.2.1 前置條件 26
2.2.2 更新yum 26
2.2.3 添加倉庫 26
2.2.4 正式安裝 26
2.3 通過Ghostcloud進行安裝 27
2.3.1 注冊Ghostcloud賬號 28
2.3.2 接入新主機 28
2.3.3 獲取安裝腳本 28
2.3.4 驗證Docker安裝是否成功 30
2.3.5 運行第一個容器 30
2.4 通過官方的安裝腳本安裝 31
2.5 在非Linux系統下安裝Docker 32
2.6 習題 32
第3章 使用Docker 33
3.1 運行hello-world 33
3.2 容器和鏡像 35
3.2.1 什么是容器 35
3.2.2 什么是鏡像 35
3.2.3 容器和鏡像的關系 36
3.3 Docker入門操作 36
3.3.1 查看Docker基本信息 36
3.3.2 下載第一個基礎鏡像 37
3.3.3 運行一個含shell終端的容器 38
3.3.4 查看容器運行 38
3.3.5 運行長時間容器 38
3.3.6 查看所有容器 39
3.4 習題 40
第2篇 Docker的基本使用
第4章 Docker深入解析 42
4.1 Docker的架構 42
4.2 Docker如何工作 43
4.2.1 Docker Image工作方式 43
4.2.2 Docker Registry工作方式 44
4.2.3 容器工作方式 44
4.2.4 底層的技術 45
4.3 Docker Client和Daemon 46
4.4 通過容器運行Web應用 47
4.4.1 使用國內倉庫 48
4.4.2 拉取apache-php鏡像 48
4.4.3 運行鏡像 48
4.4.4 網頁訪問 48
4.4.5 修改頁面內容 49
4.4.6 持久化容器 50
4.5 鏡像制作 50
4.5.1 查看本機鏡像 50
4.5.2 獲取鏡像的三種方式 51
4.5.3 查找DockerHub鏡像 51
4.5.4 查找其他倉庫鏡像 52
4.5.5 push鏡像 54
4.5.6 根據Dockerfile編譯鏡像 55
4.5.7 刪除鏡像 56
4.6 docker run命令 56
4.6.1 docker run的語法格式 56
4.6.2 前后臺運行 57
4.6.3 容器的標識 57
4.6.4 PID設置 58
4.6.5 UTS(--uts)設置 58
4.6.6 IPC(--ipc)設置 59
4.6.7 網絡設置 59
4.6.8 重啟策略(--restart) 60
4.6.9 Clean up (--rm) 61
4.6.10 CGroups控制 61
4.6.11 特權模式和Capabilities 61
4.6.12 日志驅動(--log-driver) 62
4.6.13 覆蓋image的默認參數 62
4.7 習題 63
第5章 容器的網絡 64
5.1 容器自帶網絡 64
5.2 網絡詳情 65
5.3 用戶自定義網絡 67
5.3.1 橋接網絡 67
5.3.2 Overlay網絡 68
5.4 習題 71
第6章 容器的數據 72
6.1 數據卷 72
6.1.1 創建一個數據卷 72
6.1.2 映射一個外部卷 73
6.2 使用數據型容器 73
6.3 備份、還原和遷移數據卷 73
6.4 容器和代碼進行關聯 74
6.5 習題 74
第7章 鏡像倉庫 75
7.1 倉庫相關的Docker命令 75
7.1.1 登錄 75
7.1.2 查找 76
7.1.3 拉取 76
7.1.4 提交 76
7.2 習題 76
第3篇 Docker的高級使用
第8章 鏡像和容器的存儲結構 78
8.1 鏡像、容器和存儲驅動的關系 78
8.1.1 鏡像和鏡像層 78
8.1.2 鏡像存儲方式 80
8.1.3 一個遷移例子 81
8.1.4 容器和容器層 82
8.1.5 寫時復制策略 83
8.1.6 使用共享技術減小鏡像體積 83
8.1.7 使用復制技術加快容器啟動時間 86
8.1.8 數據卷和存儲驅動 90
8.2 如何選擇存儲驅動 90
8.2.1 存儲設備和存儲驅動 92
8.2.2 如何存儲驅動 92
8.3 AUFS存儲驅動 94
8.3.1 AUFS中的鏡像 94
8.3.2 AUFS中的容器讀寫 95
8.3.3 在AUFS中刪除文件 95
8.3.4 如何配置AUFS 96
8.3.5 鏡像的存儲方式 96
8.3.6 容器的存儲方式 97
8.3.7 AUFS的性能 99
8.4 Devicemapper存儲驅動 99
8.4.1 Devicemapper中的鏡像 100
8.4.2 Devicemapper中的讀操作 101
8.4.3 Devicemapper中的寫操作 102
8.4.4 如何配置Devicemapper 103
8.4.5 在生產環境中配置direct-lvm模式 104
8.4.6 Devicemapper的存儲方式 107
8.4.7 動態擴容loop-lvm模式下的thin pool 108
8.4.8 動態擴容direct-lvm模式下的thin pool 110
8.4.9 Devicemapper的性能 110
8.5 Btrfs存儲驅動 111
8.5.1 Btrfs中的鏡像 112
8.5.2 Btrfs的存儲方式 114
8.5.3 Btrfs中的讀寫 114
8.5.4 如何配置Btrfs 115
8.5.5 Btrfs的性能 116
8.6 ZFS存儲驅動 117
8.6.1 ZFS中的鏡像 117
8.6.2 ZFS中的讀寫 118
8.6.3 如何配置ZFS 119
8.6.4 ZFS的性能 121
8.7 Overlay存儲驅動 122
8.7.1 Overlay中的鏡像 122
8.7.2 Overlay2中的鏡像 125
8.7.3 Overlay中的讀寫 127
8.7.4 如何配置Overlay/Overlay2 127
8.7.5 Overlay的性能 128
8.8 習題 129
第9章 定制Docker Daemon 130
9.1 修改Docker Daemon的三種方式 130
9.1.1 直接啟動Docker Daemon 132
9.1.2 修改Docker Daemon啟動項 132
9.1.3 自定義Docker Daemon配置文件 135
9.2 倉庫相關配置 137
9.2.1 --disable-legacy-registry選項 137
9.2.2 --registry-mirror選項 138
9.2.3 --insecure-registry選項 139
9.3 安全相關配置 139
9.3.1 -p, --pidfile選項 139
9.3.2 -H, --host選項 139
9.3.3 --tls, --tlscacert, --tlscert, --tlskey, --tlsverify選項 141
9.4 日志相關 145
9.4.1 -D,--debug選項 145
9.4.2 --log-level選項 145
9.4.3 --log-driver和--log-opt選項 146
9.5 存儲相關配置 148
9.5.1 -g, --graph選項 148
9.5.2 --storage-driver選項 148
9.5.3 --storage-opt選項 149
9.6 網橋相關配置 154
9.6.1 --bip選項 154
9.6.2 --fixed-cidr,--fixed- cidr-v6選項 154
9.6.3 --mtu選項 155
9.6.4 -b, --bridge選項 155
9.7 容器與外部通信 156
9.7.1 --ip-forward選項 156
9.7.2 --iptables選項 156
9.7.3 --ip, --ipv6選項 156
9.8 其他網絡配置 157
9.8.1 --default-gateway、--default-gateway-v6選項 157
9.8.2 --dns,--dns-opt,--dns-search選項 158
9.9 execdriver配置 158
9.9.1 --exec-opt選項 158
9.9.2 --exec-root選項 159
9.10 其他配置 159
9.11 習題 159
第10章 如何編寫Dockerfile 160
10.1 本地編譯鏡像 160
10.2 dockerignore文件 162
10.3 Dockerfile格式 163
10.4 Dockerfile指令詳解 163
10.4.1 FROM指令 163
10.4.2 MAINTAINER指令 164
10.4.3 RUN指令 164
10.4.4 CMD指令 164
10.4.5 LABEL指令 165
10.4.6 EXPOSE指令 166
10.4.7 ENV指令 166
10.4.8 ADD指令 168
10.4.9 COPY指令 169
10.4.10 ENTRYPOINT指令 170
10.4.11 VOLUME指令 173
10.4.12 USER指令 174
10.4.13 WORKDIR指令 174
10.4.14 ARG指令 175
10.4.15 ONBUILD指令 177
10.4.16 STOPSIGNAL指令 178
10.5 CMD、ENTRYPOINT和RUN的區別 178
10.6 習題 179
第11章 Dockerfile最佳實踐 181
11.1 基本原則 181
11.2 Dockerfile指令最佳實踐 183
11.2.1 FROM指令最佳實踐 183
11.2.2 RUN指令最佳實踐 183
11.2.3 CMD指令最佳實踐 185
11.2.4 EXPOSE指令最佳實踐 186
11.2.5 ENV指令最佳實踐 188
11.2.6 ADD和COPY指令最佳實踐 189
11.2.7 ENTRYPOINT指令最佳實踐 191
11.2.8 VOLUME指令最佳實踐 194
11.2.9 UESR指令最佳實踐 196
11.2.10 使用gosu工具 196
11.2.11 WORKDIR指令最佳實踐 198
11.2.12 ONBUILD指令最佳實踐 199
11.3 如何減小鏡像體積 199
11.4 一些官方鏡像的Dockerfile 205
11.4.1 Golang鏡像 205
11.4.2 Perl鏡像 208
11.4.3 Hy鏡像 209
11.4.4 Rails鏡像 210
11.5 習題 211
第12章 使用容器提供服務 212
12.1 使用容器提供數據庫服務 212
12.1.1 使用容器提供MySQL 212
12.1.2 使用容器提供MongoDB 215
12.2 如何使用容器提供Web服務 217
12.2.1 使用容器提供Apache HTTP服務 217
12.2.2 使用容器提供Django服務 218
12.2.3 使用容器提供Gitlab服務 219
12.3 如何使用容器提供編程環境 220
12.3.1 使用容器提供Java環境 221
12.3.2 使用容器提供Golang環境 222
12.4 習題 225
第13章 建立私有鏡像倉庫 226
13.1 鏡像倉庫配置詳解 227
13.2 version選項 231
13.3 log選項 231
13.4 hooks選項 231
13.5 storage選項 232
13.5.1 filesystem選項 233
13.5.2 azure選項 234
13.5.3 gcs選項 234
13.5.4 s3選項 234
13.5.5 swift選項 235
13.5.6 oss選項 236
13.5.7 delete選項 237
13.5.8 cache選項 237
13.5.9 maintenance選項 237
13.5.10 redirect選項 238
13.6 auth選項 238
13.6.1 silly選項 239
13.6.2 token選項 239
13.6.3 htpasswd選項 239
13.7 middleware選項 240
13.8 reporting選項 241
13.8.1 bugsnag選項 241
13.8.2 newrelic選項 241
13.9 http選項 242
13.9.1 tls選項 242
13.9.2 debug選項 243
13.9.3 headers選項 243
13.10 notifications選項 243
13.11 redis選項 244
13.12 health選項 245
13.12.1 storagedriver選項 245
13.12.2 file選項 246
13.12.3 http選項 246
13.12.4 tcp選項 246
13.13 proxy選項 247
13.14 鏡像倉庫配置實例 247
13.14.1 啟動容器數據持久化 247
13.14.2 使用文件系統保存鏡像 248
13.14.3 使用對象存儲保存鏡像 248
13.14.4 通過中間件使用
CDN服務 249
13.15 習題 250
第4篇 Docker常見問題
第14章 Docker常見問題 252
14.1 Docker基礎問題 252
14.1.1 什么是虛擬化技術 252
14.1.2 虛擬化有哪些分類 252
14.1.3 Docker目前支持哪些操作系統 253
14.1.4 哪種系統最適合運行Docker 253
14.1.5 Docker有什么好處 253
14.1.6 容器化技術是什么時候出現的 253
14.1.7 Docker和虛擬機有什么區別 253
14.1.8 使用Docker容器需要什么基礎知識 254

14.1.9 如何學習Docker 254
14.2 Docker高級問題 255
14.2.1 Docker是否安全 255
14.2.2 如何修改已經運行的容器 255
14.2.3 容器有哪些網絡模式 255
14.2.4 容器如何進行持久化 256
14.2.5 為什么進入容器,但退出后容器就停止了 256
14.2.6 容器停止了,如何分析原因 256
14.2.7 Link容器是什么意思 256
14.2.8 容器環境變量有什么用途 256
14.2.9 容器中CPU、磁盤IO、網絡損耗大嗎 257
14.3 鏡像相關 257
14.3.1 什么是Dockerfile 257
14.3.2 Dockerfile書寫的最佳實踐是什么 257
14.3.3 容器運行中Entrypoint和CMD的區別 258
14.3.4 Docker中容器鏡像的區別 258
14.3.5 Docker的鏡像倉庫有哪些 259
14.3.6 如何擁有私有倉庫 259
14.4 Docker三劍客 260
14.4.1 什么是Docker Machine 260
14.4.2 什么是Docker Compose 260
14.4.3 什么是Docker Swarm 260
14.5 習題 260
序: