[第二十三篇]——Docker 安裝 Apache之SpringCloud大型企業分散式微服務雲架構原始碼
Docker 安裝 Apache
方法一、docker pull httpd
查詢 上的 httpd 映象:
可以透過 Sort by 檢視其他版本的 httpd,預設是最新版本 httpd:latest。
此外,我們還可以用 docker search httpd 命令來檢視可用版本:
xxx@xxx:~/apache$ docker search httpd NAME DESCRIPTION STARS OFFICIAL AUTOMATED httpd The Apache HTTP Server .. 524 [OK] centos/httpd 7 [OK]rgielen/httpd-image-php5 Docker image for Apache... 1 [OK]microwebapps/httpd-frontend Httpd frontend allowing... 1 [OK]lolhens/httpd Apache httpd 2 Server 1 [OK]publici/httpd httpd:latest 0 [OK]publicisworldwide/httpd The Apache httpd webser... 0 [OK]rgielen/httpd-image-simple Docker image for simple... 0 [OK]solsson/httpd Derivatives of the offi... 0 [OK]rgielen/httpd-image-drush Apache HTTPD + Drupal S... 0 [OK]learninglayers/httpd 0 [OK]sohrabkhan/httpd Docker httpd + php5.6 (... 0 [OK]aintohvri/docker-httpd Apache HTTPD Docker ext... 0 [OK]alizarion/httpd httpd on centos with mo... 0 [OK]...
這裡我們拉取官方的映象
xxx@xxx:~/apache$ docker pull httpd
等待下載完成後,我們就可以在本地映象列表裡查到REPOSITORY為httpd的映象。
xxx@xxx:~/apache$ docker images httpd REPOSITORY TAG IMAGE ID CREATED SIZE httpd latest da1536b4ef14 23 seconds ago 195.1 MB
方法二、透過 Dockerfile 構建
建立 Dockerfile
首先,建立目錄apache,用於存放後面的相關東西。
xxx@xxx:~$ mkdir -p ~/apache/www ~/apache/logs ~/apache/conf
www 目錄將對映為 apache 容器配置的應用程式目錄。
logs 目錄將對映為 apache 容器的日誌目錄。
conf 目錄裡的配置檔案將對映為 apache 容器的配置檔案。
進入建立的 apache 目錄,建立 Dockerfile。
FROM debian:jessie# add our user and group first to make sure their IDs get assigned consistently, regardless of whatever dependencies get added#RUN groupadd -r www-data && useradd -r --create-home -g www-data www-dataENV HTTPD_PREFIX /usr/local/apache2 ENV PATH $PATH:$HTTPD_PREFIX/bin RUN mkdir -p "$HTTPD_PREFIX" \ && chown www-data:www-data "$HTTPD_PREFIX"WORKDIR $HTTPD_PREFIX# install httpd runtime dependencies# \ && apt-get install -y --no-install-recommends \ libapr1 \ libaprutil1 \ libaprutil1-ldap \ libapr1-dev \ libaprutil1-dev \ libpcre++0 \ libssl1.0.0 \ && rm -r /var/lib/apt/lists/* ENV HTTPD_VERSION 2.4.20 ENV HTTPD_BZ2_URL RUN buildDeps=' \ ca-certificates \ curl \ bzip2 \ gcc \ libpcre++-dev \ libssl-dev \ make \ ' \ set -x \ && apt-get update \ && apt-get install -y --no-install-recommends $buildDeps \ && rm -r /var/lib/apt/lists/* \ \ && curl -fSL "$HTTPD_BZ2_URL" -o httpd.tar.bz2 \ && curl -fSL "$HTTPD_BZ2_URL.asc" -o httpd.tar.bz2.asc \ # see && export GNUPGHOME="$(mktemp -d)" \ && gpg --keyserver ha.pool.sks-keyservers.net --recv-keys A93D62ECC3C8EA12DB220EC934EA76E6791485A8 \ && gpg --batch --verify httpd.tar.bz2.asc httpd.tar.bz2 \ && rm -r "$GNUPGHOME" httpd.tar.bz2.asc \ \ && mkdir -p src \ && tar -xvf httpd.tar.bz2 -C src --strip-components=1 \ && rm httpd.tar.bz2 \ && cd src \ \ && ./configure \ --prefix="$HTTPD_PREFIX" \ --enable-mods-shared=reallyall \ && make -j"$(nproc)" \ && make install \ \ && cd .. \ && rm -r src \ \ && sed -ri \ -e 's!^(\s*CustomLog)\s+\S+!\1 /proc/self/fd/1!g' \ -e 's!^(\s*ErrorLog)\s+\S+!\1 /proc/self/fd/2!g' \ "$HTTPD_PREFIX/conf/httpd.conf" \ \ && apt-get purge -y --auto-remove $buildDeps COPY httpd-foreground /usr/local/bin/ EXPOSE 80 CMD ["httpd-foreground"]
Dockerfile檔案中 COPY httpd-foreground /usr/local/bin/ 是將當前目錄下的httpd-foreground複製到映象裡,作為httpd服務的啟動指令碼,所以我們要在本地建立一個指令碼檔案httpd-foreground
#!/bin/bashset -e# Apache gets grumpy about PID files pre-existingrm -f /usr/local/apache2/logs/httpd.pidexec httpd -DFOREGROUND
賦予 httpd-foreground 檔案可執行許可權。
xxx@xxx:~/apache$ chmod +x httpd-foreground
透過 Dockerfile 建立一個映象,替換成你自己的名字。
xxx@xxx:~/apache$ docker build -t httpd .
建立完成後,我們可以在本地的映象列表裡查詢到剛剛建立的映象。
xxx@xxx:~/apache$ docker images httpd REPOSITORY TAG IMAGE ID CREATED SIZE httpd latest da1536b4ef14 23 seconds ago 195.1 MB
使用 apache 映象
執行容器
docker run -p 80:80 -v $PWD/www/:/usr/local/apache2/htdocs/ -v $PWD/conf/httpd.conf:/usr/local/apache2/conf/httpd.conf -v $PWD/logs/:/usr/local/apache2/logs/ -d httpd
命令說明:
-p 80:80: 將容器的 80 埠對映到主機的 80 埠。
-v $PWD/www/:/usr/local/apache2/htdocs/: 將主機中當前目錄下的 www 目錄掛載到容器的 /usr/local/apache2/htdocs/。
-v $PWD/conf/httpd.conf:/usr/local/apache2/conf/httpd.conf: 將主機中當前目錄下的 conf/httpd.conf 檔案掛載到容器的 /usr/local/apache2/conf/httpd.conf。
-v $PWD/logs/:/usr/local/apache2/logs/: 將主機中當前目錄下的 logs 目錄掛載到容器的 /usr/local/apache2/logs/。
檢視容器啟動情況:
xxx@xxx:~/apache$ docker ps CONTAINER ID IMAGE COMMAND ... PORTS NAMES79a97f2aac37 httpd "httpd-foreground" ... 0.0.0.0:80->80/tcp sharp_swanson
透過瀏覽器訪問
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70006413/viewspace-2791566/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- [第二十四篇]——Docker 命令大全之SpringCloud大型企業分散式微服務雲架構原始碼DockerSpringGCCloud分散式微服務架構原始碼
- 4、【創業必備企業架構】SpringCloud大型企業分散式微服務雲架構原始碼之MySQL 連線創業架構SpringGCCloud分散式微服務原始碼MySql
- SpringCloud大型企業分散式微服務雲架構原始碼之【資料結構】-排序-希爾排序SpringGCCloud分散式微服務架構原始碼資料結構排序
- 關於SpringCloud大型網際網路分散式企業微服務雲架構SpringGCCloud分散式微服務架構
- SpringCloud大型企業分散式微服務雲架構原始碼之Springboot 重點知識點整理GCCloud分散式微服務架構原始碼Spring Boot
- 【分散式微服務企業快速架構】SpringCloud分散式、微服務、雲架構快速開發平臺分散式微服務架構SpringGCCloud
- SpringCloud大型企業分散式微服務雲架構原始碼之CAS SSO單點登入服務端環境搭建SpringGCCloud分散式微服務架構原始碼服務端
- SpringCloud企業分散式微服務雲架構快速開發平臺原始碼SpringGCCloud分散式微服務架構原始碼
- 25、【創業必備企業架構】SpringCloud分散式微服務雲架構原始碼之MySQL 匯出資料創業架構SpringGCCloud分散式微服務原始碼MySql
- SpringCloud大型企業分散式微服務雲架構原始碼+CAS SSO單點登入服務端環境搭建SpringGCCloud分散式微服務架構原始碼服務端
- Spring Cloud大型網際網路分散式企業微服務雲架構SpringCloud分散式微服務架構
- springcloud微服務分散式雲架構-SpringCloud簡介SpringGCCloud微服務分散式架構
- springcloud微服務分散式雲架構簡介SpringGCCloud微服務分散式架構
- SpringCloud大型企業分散式微服務雲架構原始碼+CAS SSO單點登入客戶端環境搭建SpringGCCloud分散式微服務架構原始碼客戶端
- 微服務分散式架構之redis篇微服務分散式架構Redis
- (一)springcloud微服務分散式雲架構-SpringCloud簡介SpringGCCloud微服務分散式架構
- 企業分散式微服務雲架構快速開發平臺原始碼分散式微服務架構原始碼
- Spring Cloud雲服務架構 - 企業分散式微服務雲架構構建SpringCloud架構分散式微服務
- (三)springcloud微服務分散式雲架構-SpringCloud整合專案簡介SpringGCCloud微服務分散式架構
- 精華【分散式微服務雲架構dubbo+zookeeper+springmvc+mybatis+shiro+redis】分散式大型網際網路企業架構!分散式微服務架構SpringMVCMyBatisRedis
- Spring Cloud微服務分散式雲架構 - 整合企業架構的技術點SpringCloud微服務分散式架構
- 整合spring cloud雲服務架構 - 企業分散式微服務雲架構構建SpringCloud架構分散式微服務
- JAVA漢諾塔遞迴 之SpringCloud企業分散式微服務雲架構快速開發平臺Java遞迴SpringGCCloud分散式微服務架構
- (四)整合spring cloud雲服務架構 - 企業分散式微服務雲架構構建SpringCloud架構分散式微服務
- (二)spring cloud微服務分散式雲架構-整合企業架構的技術點SpringCloud微服務分散式架構
- (二)spring cloud微服務分散式雲架構 - 整合企業架構的技術點SpringCloud微服務分散式架構
- (二)微服務分散式雲架構 - spring cloud整合企業架構的技術點微服務分散式架構SpringCloud
- 11.Spring Cloud 分散式、微服務、雲架構企業快速開發架構之Linux 磁碟管理SpringCloud分散式微服務架構Linux
- 三十三、java版 SpringCloud分散式微服務雲架構之Java HashSetJavaSpringGCCloud分散式微服務架構
- java版 SpringCloud分散式微服務雲架構之Java Iterator(迭代器)JavaSpringGCCloud分散式微服務架構
- Spring Cloud微服務分散式雲架構SpringCloud微服務分散式架構
- SpringCloud分散式微服務雲架構 第六篇: 分散式配置中心(Spring Cloud Config)SpringGCCloud分散式微服務架構
- SpringCloud分散式微服務雲架構 第七篇: 高可用的分散式配置中心(Config)SpringGCCloud分散式微服務架構
- Spring Cloud分散式微服務雲架構原始碼分析 — EurekaSpringCloud分散式微服務架構原始碼
- 構建Spring Cloud微服務分散式雲架構SpringCloud微服務分散式架構
- 7.Spring Cloud 分散式、微服務、雲架構企業快速開發架構之Linux 遠端登入SpringCloud分散式微服務架構Linux
- springCloud分散式微服務雲架構 第十二篇: 斷路器聚合監控SpringGCCloud分散式微服務架構
- 三十四、java版 SpringCloud分散式微服務雲架構之Java Iterator(迭代器)JavaSpringGCCloud分散式微服務架構