Docker—— 鏡像構建原因

在現代軟件開發和運維中,Docker已成為一種非常流行的工具,它通過容器化應用程序來簡化部署過程。然而,默認的官方鏡像往往只能滿足基礎需求,無法涵蓋所有特定項目的具體要求。

原因說明
系統級改動無法通過 volume 實現修改用戶、刪除命令、安裝系統組件等只能在鏡像層完成
安全加固要求可復制、可驗證你不能讓每個節點手動執行一遍加固腳本,必須統一標準
合規性要求可追溯構建鏡像可以打標簽、記錄作者和時間,方便審計和版本管理

鏡像 vs Volume 的適用場景對比表

場景是否需要構建鏡像使用 Volume 是否足夠
修改系統組件(如安裝包、刪命令)必須構建鏡像不夠
用戶權限、安全策略調整必須構建鏡像不夠
日志配置、訪問控制等應用級配置可以用 volume足夠
數據持久化、網站靜態資源可以用 volume足夠
安全合規、標準化部署必須構建鏡像不夠

自定義HTTP鏡像

在 CentOS 7 容器中安裝 httpd,并提交為新鏡像 my-httpd-image

啟動容器并進入交互式 shell

docker run -it --name my-httpd-container centos:7 /bin/bash

這會創建一個名為 my-httpd-container 的容器,并進入它的 bash 環境。

在容器內安裝 httpd

curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repoyum clean all
yum makecacheyum install -y httpd

配置啟動服務

做一些簡單配置,比如添加一個測試頁面:

echo "Hello from Apache in Docker!" > /var/www/html/index.html

退出容器:

exit

提交容器為新鏡像

docker commit my-httpd-container my-httpd-image:latest

查看鏡像信息

docker images | grep my-httpd

你應該看到類似輸出:

my-httpd-image ? latest ? xxxxxxxxxxxx ? ... ?

運行該鏡像并啟動 Apache

為了運行這個鏡像并啟動 Apache,可以這樣運行:

docker run -d -p 8080:80 --name my-running-httpd my-httpd-image /usr/sbin/httpd -DFOREGROUND

解釋:

  • -d: 后臺運行

  • -p 8080:80: 映射宿主機端口 8080 到容器的 80 端口

  • /usr/sbin/httpd -DFOREGROUND: 強制 Apache 前臺運行(避免容器立即退出)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/88482.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/88482.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/88482.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

鋰電池自動化生產線的現狀與發展

鋰電池自動化生產線的概述鋰電池自動化生產線是指采用自動化設備和控制系統,實現鋰電池從原材料到成品的全流程自動化生產過程。隨著新能源產業的快速發展,鋰電池作為重要的儲能元件,其生產制造技術也在不斷進步。自動化生產線通過減少人工干…

java底層的native和沙箱安全機制

沙箱安全機制沙箱(Sandbox)安全機制是一種將程序或代碼運行在隔離環境中的安全技術,旨在限制其對系統資源(如文件系統、網絡、內存、其他進程等)的訪問權限,從而降低潛在惡意代碼帶來的風險。其核心思想是“…

【分享】文件擺渡系統適配醫療場景:安全與效率兼得

根據國家信息安全相關法規要求,醫院為了網絡安全,大多會采用網閘等隔離手段,將網絡隔離為內網和外網,但網絡隔離后,醫院的內外網間仍存在較為頻繁的文件擺渡需求。文件擺渡系統則是可以解決跨網絡或跨安全域文件傳輸中…

vscode 中的 mermaid

一、安裝軟件 Mermaid preview Mermaid support 二、運行命令 創建.md 文件右鍵選擇 ?Open Preview?(或按 CtrlShiftV) 三、流程圖 注意: 要md 文件要保留 mermaid 1. #mermaid-svg-nchqbvlWePe5KCwJ {font-family:"trebuchet ms"…

微服務引擎 MSE 及云原生 API 網關 2025 年 6 月產品動態

點擊此處,了解微服務引擎 MSE 產品詳情。

【TCP/IP】7. IP 路由

7. IP 路由7. IP 路由概述7.1 直接傳遞與間接傳遞7.2 IP 路由核心機制7.3 路由表7.3.1 路由表的構成7.3.2 信宿地址采用網絡地址的好處7.3.3 下一跳地址的優勢7.3.4 特殊路由表項7.3.5 路由算法7.4 靜態路由7.4.1 特點7.4.2 自治系統(AS)7.4.3 配置命令7…

xFile:高性能虛擬分布式加密存儲系統——Go

xFile:高性能虛擬分布式加密存儲系統 目錄xFile:高性能虛擬分布式加密存儲系統1 背景介紹2 設計初衷與目標3 項目簡介4 系統架構5 核心優勢1. 真正的分布式塊存儲2. 塊級加密與壓縮,安全高效3. 靈活的索引與元數據管理4. 多用戶與權限體系5. …

時序數據庫:高效處理時間序列數據的核心技術

時序數據庫概述時序數據庫(Time Series Database,TSDB)是一種專門為存儲、處理和查詢時間序列數據而優化的數據庫系統。隨著物聯網、金融科技、工業互聯網等領域的快速發展,時序數據呈現出爆炸式增長,傳統的關系型數據…

面試官:你再問TCP三次握手,我就要報警了!

CP三次握手和四次揮手,是面試官最愛問的“開場白”之一 別看它基礎,真要講清楚細節,分分鐘讓你冷汗直流! 這玩意兒就跟程序員相親一樣: 表面上問的是“你老家哪的” 實際上是在試探你有沒有房、有沒有車、能不能落…

RuoYi+Uniapp(uni-ui)開發商城系統

如果你正在考慮用 RuoYi 和 UniApp(uni-ui)搭建一套商城系統,那這套組合確實值得好好研究。它整合了 RuoYi 的快速開發能力和 UniApp 的跨平臺特性,在高效開發的同時還能兼顧多端適配的需求。下面從技術架構、功能模塊、開發實踐到…

面試150 二叉樹的最大高度

思路 考慮從遞歸出發,聯想遞歸三部曲:返回什么、傳入的參數是什么、遍歷的方式是什么。此題現在需要我們整個樹,并且需要從根節點出發,因此我們選擇先序遍歷即可。另一張辦法,則是選擇通過隊列實現層次遍歷&#xff0c…

從零實現一個GPT 【React + Express】--- 【2】實現對話流和停止生成

摘要 這是本系列文章的第二篇,開始之前我們先回顧一下上一篇文章的內容: 從零實現一個GPT 【React Express】— 【1】初始化前后端項目,實現模型接入SSE 在這一篇中,我們主要創建了前端工程和后端工程,這里貼一下我…

SEQUENCE在RAC多實例開啟CACHE的NEXTVAL數值亂序問題

問題說明 在多實例環境中可能會出現從Sequence所取出來的nextval是亂序的,比如第二次比第一次所取的數要小但這并不是我們所希望的。當程序邏輯Base on sequence.nextval數值所謂填充字段的大小來排序時,就會產生問題。 實際上就是由于多實例這一特性造成…

后臺管理系統-權限管理

在后臺管理系統當中,權限管理占著非常重要的位置,權限管理,顧名思義,就是用來管理用戶登錄后臺的權限。 在權限管理中有三個重要的名詞:賬號,角色,權限 賬號:通過賬號進入平臺&…

MySQL表的約束(5)

文章目錄前言一、空屬性二、默認值三、列描述四、zerofill五、主鍵六、自增長七、唯一鍵八、外鍵總結前言 真正約束字段的是數據類型,但是數據類型約束很單一,需要有一些額外的約束,更好的保證數據的合法性,從業務邏輯角度保證數據…

MyBatis:SQL與Java的智能橋梁

MyBatis:SQL 與 Java 的「智能翻譯官」 —— 用 極簡的方式 連接數據庫和 Java 對象,告別 JDBC 的繁瑣操作!核心定位:半自動化 ORM 框架對比項JDBC 原生操作MyBatis 解決方案SQL 編寫拼字符串(易出錯、難維護&#xff…

自動駕駛控制系統

目錄 控制系統概述 無人車控制架構設計 自動駕駛控制核心技術 車輛縱向控制 車輛橫向控制 自動駕駛控制方法 自動駕駛控制技術方案 人機交互系統 控制系統概述 控制技術是智能駕駛的關鍵,旨在環境感知技術的基礎之上,根據決策規劃出目標軌跡,通過縱向和橫向控制系統…

網絡安全基石:從弱口令治理到動態防御體系的構建

引言:數字時代的防御困局 在5G與物聯網技術全面落地的數字新基建時代,企業網絡資產規模呈現指數級增長。Verizon《2023年數據泄露調查報告》顯示,61%的安全事件直接源于憑證失竊,而其中81%的攻擊成功案例可溯源至初始口令強度的不…

Error: fatal: detected dubious ownership in repository at

這個錯誤是 Git 在新版中引入的一種 安全檢查機制,目的是防止不同用戶訪問同一個 Git 倉庫目錄,避免潛在的權限或安全問題。你的情況是:倉庫目錄是屬于另一個用戶。當前以管理員用戶 OVERSPREAD/Administrator 運行 Git。Git 為了安全起見&am…

嵌入式 數據結構學習 (六) 樹、哈希表與內核鏈表

一、樹(Tree)結構詳解1. 樹的基本概念樹的核心特性非線性結構:數據元素之間存在一對多的層次關系遞歸定義:樹的子樹仍然是樹專業術語:度(Degree):結點擁有的子樹數葉子結點:度為0的結點層次(Level):根為第1…