国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

最簡單的dockerfile使用教程 - 創建一個支持SSL的Nginx鏡像

xiaolinbang / 2323人閱讀

摘要:為此我首先需要創建一個針對的配置文件。的作用是指定基準鏡像。該以后面指定的鏡像為基礎,在其上進行定制。存在一個特殊的鏡像,名為。它是一個虛擬的概念,表示一個空白的鏡像。直接使用會讓鏡像體積更加小巧。

什么是dockerfile?簡單的說就是一個文本格式的腳本文件,其內包含了一條條的指令(Instruction),每一條指令負責描述鏡像的當前層(Layer)如何構建。

下面通過一個具體的例子來學習dockerfile的寫法。

新建一個dbuild文件夾,創建一個自定義的Nginx首頁,邏輯很簡單,顯示一個自定義的圖片文件train.jpg.

我想基于標準的Nginx鏡像做一些修改,讓Nginx支持SSL。SSL(Secure Sockets Layer 安全套接層),及其繼任者傳輸層安全(Transport Layer Security,TLS)是為網絡通信提供安全及數據完整性的一種安全協議。TLS與SSL在傳輸層對網絡連接進行加密。

為此我首先需要創建一個針對SSL的配置文件。

cat << "__EOF" > ssl.conf
server {
listen       443 ssl;
server_name  localhost;

ssl_certificate /etc/nginx/ssl/nginx.crt;
ssl_certificate_key /etc/nginx/ssl/nginx.key;

location / {
root   /usr/share/nginx/html;
index  index.html index.htm;
}
}
__EOF

使用如下命令創建nginx.key和nginx.crt文件:

openssl req -x509 -nodes -newkey rsa:4096 -keyout nginx.key -out nginx.crt -days 365 -subj "/CN=$(hostname)"

一切就緒之后,下面就應該創建dockerfile了:

FROM nginx:stable

# copy the custom website into the image
COPY train.jpg /usr/share/nginx/html/
COPY index.html /usr/share/nginx/html/

# copy the SSL configuration file into the image
COPY ssl.conf /etc/nginx/conf.d/ssl.conf

# download the SSL key and certificate into the image
COPY nginx.key /etc/nginx/ssl/nginx.key
COPY nginx.crt /etc/nginx/ssl/nginx.crt

# expose the https port
EXPOSE 443

所有dockerfile第一行指令必定是FROM XXXX。

FROM的作用是指定基準鏡像。該dockerfile以FROM后面指定的鏡像為基礎,在其上進行定制。

在 Docker Store 上有很多高質量的官方鏡像,主要分為以下三大類:

開箱即用的服務類的鏡像,比如網絡服務器nginx ,也有數據庫服務器諸如redis 、 mongo 、mysql 等;

方便開發、構建、運行各種語言應用的鏡像,如 node 、 openjdk 、 python 等。

相對前兩大類更為基礎的操作系統鏡像,如ubuntu 、 debian 、 centos 等

當然您如果不愿意基于這些官方已有鏡像開始鏡像構建,而是想從頭開始,這也是可以的。Docker存在一個特殊的鏡像,名為 scratch 。它是一個虛擬的概念,

表示一個空白的鏡像。

直接使用FROM scratch 會讓鏡像體積更加小巧。

接下來的一系列copy指令都很好理解。

dockerfile開發完畢之后,執行命令:

docker build -t jerry-nginx:1.0 .

意思是基于當前目錄開始構建鏡像,注意末尾的.必不可少,代表“當前目錄”。

通過docker build執行輸出的日志可以觀察到里面每一行的指令被逐行執行:

最后一行日志提示標簽為jerry-nginx:1.0的景象被成功構建。

用下面的命令基于剛剛制作好的鏡像運行一個容器:

docker run -d -p 443:443 -p 1082:80 jerry-nginx:1.0

基于http協議訪問沒有問題:

http://localhost:1082

基于https訪問也能正常工作:

https://localhost:443

要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/27595.html

相關文章

  • Angular 容器部署

    摘要:很多人反應很難訪問,所以轉移到阿里云服務器上,因此做了一次完整的容器部署。在容器化過程中,我們并未配置任何等,只是保留服務所需的配置項而已,而這一部分我們可以放在反向代理層完成。 很多人反應很難訪問 Github Page,所以 ng-alain.com 轉移到阿里云服務器上,因此做了一次完整的 Angular 容器部署。 以下我會闡述 ng-alain 整個過程,其中包括 Docke...

    tracy 評論0 收藏0
  • Angular 容器部署

    摘要:很多人反應很難訪問,所以轉移到阿里云服務器上,因此做了一次完整的容器部署。在容器化過程中,我們并未配置任何等,只是保留服務所需的配置項而已,而這一部分我們可以放在反向代理層完成。 很多人反應很難訪問 Github Page,所以 ng-alain.com 轉移到阿里云服務器上,因此做了一次完整的 Angular 容器部署。 以下我會闡述 ng-alain 整個過程,其中包括 Docke...

    alighters 評論0 收藏0
  • 30 分鐘快速入門 Docker 教程

    摘要:分鐘快速入門教程一歡迎來到世界與虛擬化在沒有的時代,我們會使用硬件虛擬化虛擬機以提供隔離。倉庫分為公開倉庫和私有倉庫,最大的公開倉庫是官方倉庫,國內的公開倉庫也有很多選擇,例如阿里云等。 30 分鐘快速入門 Docker 教程 一、歡迎來到 Docker 世界 1. Docker 與虛擬化 在沒有 Docker 的時代,我們會使用硬件虛擬化(虛擬機)以提供隔離。這里,虛擬機通過在操作系...

    LucasTwilight 評論0 收藏0
  • 建立博客,使用Docker部署Ghost+MySQL+Nginx

    摘要:接下來是系統需要的配置文件,文件分別在變化時被使用,這樣編寫一套啟動文件不僅部署可用,也可用于主題或應用開發。文件內容設置了反向代理啟用協議以及規定上傳文件大小。本案例的博客地址原文出處最后配置一下網站,也使用了自己開發的主題。 為什么是Ghost、Docker 這個問題很容易得到回答,因為ghost快又簡約,而且使用node.js開發,使用起來體驗十分良好。我自己曾經用過不少的博客系...

    JinB 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<