修正多個用詞

"s/程序/程式/g" "s/性能/效能/g" "s/如下/以下/g" "s/加載/載入/g" "s/獲取/取得/g" "s/服務器/伺服器/g" "s/信息/訊息/g" "s/註釋/註解/g" "s/裏/裡/g" "s/構建/建立/g" "s/配置/設定/g"
This commit is contained in:
Ensky Lin
2014-11-24 22:51:16 +08:00
parent 9d0330915d
commit a795bf863a
61 changed files with 208 additions and 208 deletions

View File

@@ -1,5 +1,5 @@
## 多臺物理主機之間的容器互聯(暴露容器到真實網路中)
Docker 默認的橋接網卡是 docker0。它只會在本機橋接所有的容器網卡舉例來說容器的虛擬網卡在主機上看一般叫做 veth*** 而 Docker 只是把所有這些網卡橋接在一起,下:
Docker 默認的橋接網卡是 docker0。它只會在本機橋接所有的容器網卡舉例來說容器的虛擬網卡在主機上看一般叫做 veth*** 而 Docker 只是把所有這些網卡橋接在一起,下:
```
[root@opnvz ~]# brctl show
bridge name bridge id STP enabled interfaces

View File

@@ -7,8 +7,8 @@
![企業應用結構](../_images/enterprise_usage.png)
Docker 占用資源小,在一臺 E5 128 G 內存的服器上部署 100 個容器都綽綽有余,可以單獨抽一個容器或者直接在宿主物理主機上部署 samba利用 samba 的 home 分享方案將每個使用者的 home 目錄映射到開發中心和測試部門的 Windows 機器上。
Docker 占用資源小,在一臺 E5 128 G 內存的服器上部署 100 個容器都綽綽有余,可以單獨抽一個容器或者直接在宿主物理主機上部署 samba利用 samba 的 home 分享方案將每個使用者的 home 目錄映射到開發中心和測試部門的 Windows 機器上。
針對某個項目組,由架構師搭建好一個標準的容器環境供項目組和測試部門使用,每個開發工程師可以擁有自己單獨的容器,透過 `docker run -v` 將使用者的 home 目錄映射到容器中。需要提交測試時,只需要將代碼移交給測試部門,然後分配一個容器使用 `-v` 載測試部門的 home 目錄啟動即可。這樣,在公司內部的開發、測試基本就統一了,不會出現開發部門提交的代碼,測試部門部署不了的問題。
針對某個項目組,由架構師搭建好一個標準的容器環境供項目組和測試部門使用,每個開發工程師可以擁有自己單獨的容器,透過 `docker run -v` 將使用者的 home 目錄映射到容器中。需要提交測試時,只需要將代碼移交給測試部門,然後分配一個容器使用 `-v`測試部門的 home 目錄啟動即可。這樣,在公司內部的開發、測試基本就統一了,不會出現開發部門提交的代碼,測試部門部署不了的問題。
測試部門發布測試透過的報告後,架構師再一次檢測容器環境,就可以直接交由部署工程師將代碼和容器分別部署到生產環境中了。這種方式的部署橫向能的擴展性也極好。
測試部門發布測試透過的報告後,架構師再一次檢測容器環境,就可以直接交由部署工程師將代碼和容器分別部署到生產環境中了。這種方式的部署橫向能的擴展性也極好。

View File

@@ -1,10 +1,10 @@
## 使用 Supervisor 來管理程
Docker 容器在啟動的時候開啟單個程,比如,一個 ssh 或者 apache 的 daemon 服務。但我們經常需要在一個機器上開啟多個服務,這可以有很多方法,最簡單的就是把多個啟動命令方到一個啟動腳本面,啟動的時候直接啟動這個腳本,另外就是安裝程管理工具。
## 使用 Supervisor 來管理程
Docker 容器在啟動的時候開啟單個程,比如,一個 ssh 或者 apache 的 daemon 服務。但我們經常需要在一個機器上開啟多個服務,這可以有很多方法,最簡單的就是把多個啟動命令方到一個啟動腳本面,啟動的時候直接啟動這個腳本,另外就是安裝程管理工具。
本小節將使用程管理工具 supervisor 來管理容器中的多個程。使用 Supervisor 可以更好的控制、管理、重啟我們希望執行的程。在這我們演示一下如何同時使用 ssh 和 apache 服務。
本小節將使用程管理工具 supervisor 來管理容器中的多個程。使用 Supervisor 可以更好的控制、管理、重啟我們希望執行的程。在這我們演示一下如何同時使用 ssh 和 apache 服務。
### 配置
首先建立一個 Dockerfile內容和各部分的解釋下。
### 設定
首先建立一個 Dockerfile內容和各部分的解釋下。
```
FROM ubuntu:13.04
MAINTAINER examples@docker.com
@@ -21,20 +21,20 @@ RUN mkdir -p /var/run/sshd
RUN mkdir -p /var/log/supervisor
```
安裝 3 個軟件,還建立了 2 個 ssh 和 supervisor 服務正常執行所需要的目錄。
安裝 3 個軟件,還建立了 2 個 ssh 和 supervisor 服務正常執行所需要的目錄。
```
COPY supervisord.conf /etc/supervisor/conf.d/supervisord.conf
```
新增 supervisord 的配置文件,並復制配置文件到對應目錄下面。
新增 supervisord 的設定文件,並復制設定文件到對應目錄下面。
```
EXPOSE 22 80
CMD ["/usr/bin/supervisord"]
```
我們映射了 22 和 80 端口,使用 supervisord 的可執行路徑啟動服務。
我們映射了 22 和 80 端口,使用 supervisord 的可執行路徑啟動服務。
### supervisor配置文件內容
### supervisor設定文件內容
```
[supervisord]
nodaemon=true
@@ -44,7 +44,7 @@ command=/usr/sbin/sshd -D
[program:apache2]
command=/bin/bash -c "source /etc/apache2/envvars && exec /usr/sbin/apache2 -DFOREGROUND"
```
配置文件包含目錄和程,第一段 supervsord 配置軟件本身,使用 nodaemon 參數來執行。第二段包含要控制的 2 個服務。每一段包含一個服務的目錄和啟動這個服務的命令。
設定文件包含目錄和程,第一段 supervsord 設定軟件本身,使用 nodaemon 參數來執行。第二段包含要控制的 2 個服務。每一段包含一個服務的目錄和啟動這個服務的命令。
### 使用方法
建立鏡像。

View File

@@ -4,7 +4,7 @@
```
docker run -t -i -v /home:/opt/data --name mk_tomcat ubuntu /bin/bash
```
這條命令掛載本地 home 目錄到容器的 /opt/data 目錄,容器內目錄若不存在,則會自動建立。接下來就是 tomcat 的基本配置jdk 環境變量設置好之後,將 tomcat 程放到 /opt/apache-tomcat 下面
這條命令掛載本地 home 目錄到容器的 /opt/data 目錄,容器內目錄若不存在,則會自動建立。接下來就是 tomcat 的基本設定jdk 環境變量設置好之後,將 tomcat 程放到 /opt/apache-tomcat 下面
編輯 /etc/supervisor/conf.d/supervisor.conf 文件,新增 tomcat 項
```
[supervisord]
@@ -30,7 +30,7 @@ docker build tomcat tomcat
```
### 安裝 weblogic 鏡像
步驟和 tomcat 基本一致,這貼一下配置文件
步驟和 tomcat 基本一致,這貼一下設定文件
```
supervisor.conf
[supervisord]
@@ -54,7 +54,7 @@ CMD ["/usr/bin/supervisord"]
-v, --volume=[] Bind mount a volume (e.g. from the host: -v /host:/container, from docker: -v /container)
將本地磁盤映射到容器內部,它在主機和容器之間是實時變化的,所以我們更新程、上傳代碼只需要更新物理主機的目錄就可以了
將本地磁盤映射到容器內部,它在主機和容器之間是實時變化的,所以我們更新程、上傳代碼只需要更新物理主機的目錄就可以了
#### tomcat 和 weblogic 集群的實做
tomcat 只要開啟多個容器即可
@@ -64,18 +64,18 @@ docker run -d -v -p 205:22 -p 7004:8080 -v /home/data:/opt/data --name tm2 tomca
docker run -d -v -p 206:22 -p 7005:8080 -v /home/data:/opt/data --name tm3 tomcat /usr/bin/supervisord
```
說一下 weblogic 的配置,大家知道 weblogic 有一個域的概念。如果要使用常規的 administrator +node 的方式部署,就需要在 supervisord 中分別寫出 administartor server 和 node server 的啟動腳本,這樣做的優點是:
說一下 weblogic 的設定,大家知道 weblogic 有一個域的概念。如果要使用常規的 administrator +node 的方式部署,就需要在 supervisord 中分別寫出 administartor server 和 node server 的啟動腳本,這樣做的優點是:
* 可以使用 weblogic 的集群,同步等概念
* 部署一個集群應用程,只需要安裝一次應用到集群上即可
* 部署一個集群應用程,只需要安裝一次應用到集群上即可
缺點是:
* Docker 配置復雜了
* 沒辦法自動擴展集群的計算容量,如需新增節點,需要在 administrator 上先建立節點,然後再配置新的容器 supervisor 啟動腳本,然後再啟動容器
另外種方法是將所有的程都安裝在 adminiserver 上面,需要擴展的時候,啟動多個節點即可,它的優點和缺點和上一種方法恰恰相反。(建議使用這種方式來部署開發和測試環境)
* Docker 設定復雜了
* 沒辦法自動擴展集群的計算容量,如需新增節點,需要在 administrator 上先建立節點,然後再設定新的容器 supervisor 啟動腳本,然後再啟動容器
另外種方法是將所有的程都安裝在 adminiserver 上面,需要擴展的時候,啟動多個節點即可,它的優點和缺點和上一種方法恰恰相反。(建議使用這種方式來部署開發和測試環境)
```
docker run -d -v -p 204:22 -p 7001:7001 -v /home/data:/opt/data --name node1 weblogic /usr/bin/supervisord
docker run -d -v -p 205:22 -p 7002:7001 -v /home/data:/opt/data --name node2 weblogic /usr/bin/supervisord
docker run -d -v -p 206:22 -p 7003:7001 -v /home/data:/opt/data --name node3 weblogic /usr/bin/supervisord
```
這樣在前端使用 nginx 來做負載均衡就可以完成配置
這樣在前端使用 nginx 來做負載均衡就可以完成設定