搜尋
首頁運維Docker什麼是fastdfs與docker

fastdfs是一個開源的分散式檔案系統,功能包括檔案儲存、檔案同步、檔案存取等,解決了大容量儲存和負載平衡的問題;docker是一個開源的應用程式容器引擎,可以打包應用以及依賴套件到一個可移植的鏡像。

什麼是fastdfs與docker

本教學操作環境:linux7.3系統、docker-1.13.1版、Dell G3電腦。

什麼是fastdfs與docker

FastDFS 是用 c 語言寫的一款開源的分散式檔案系統。 FastDFS 為互聯網量身定制, 充分考慮了冗餘備份、負載平衡、線性擴容等機制,並專注於高可用、高效能等指標,使用FastDFS 很容易搭建一套高性能的文件伺服器集群提供文件上傳、下載等服務。

FastDFS 架構包括 Tracker server 和 Storage server。用戶端請求 Tracker server 進行文 件上傳、下載,透過 Tracker server 調度最終由 Storage server 完成檔案上傳下載。

Tracker server 作用是負載平衡和調度,透過 Tracker server 在檔案上傳時可以根據一些 策略找到 Storage server 提供檔案上傳服務。可以將 tracker 稱為追蹤伺服器或調度伺服器。

Storage server 作用是檔案存儲,客戶端上傳的檔案最終儲存在 Storage 伺服器上, Storageserver 沒有實作自己的檔案系統而是利用作業系統 的檔案系統來管理檔案。可以將 storage 稱為儲存伺服器。

什麼是fastdfs與docker

服務端兩個角色:

Tracker: 管理集群,tracker 也可以實現集群。每個 tracker 節點地位平等。收集 Storage 集群的狀態。

Storage: 實際儲存文件, Storage 分成多個群組,每個群組之間保存的文件是不同的。每 組內部可以有多個成員,組成員內部保存的內容是一樣的,組成員的地位是一致的,沒有 主從的概念。

2. 檔案上傳流程

上傳檔案流程

什麼是fastdfs與docker

#客戶端上傳檔案後儲存伺服器將檔案ID 傳回給客戶端,此文件ID 用於以後存取該文件的索引資訊。檔案索引資訊包括:群組名,虛擬磁碟路徑,資料兩級目錄,檔案名稱。

檔案名稱

group1/M00/00/00/wKi9hVz-GUKABj4gAAOTipWhnKM434.jpg

群組名稱:檔案上傳後所在的storage 群組名稱,在檔案上傳成功後有storage 伺服器傳回, 需要客戶端自行保存。

虛擬磁碟路徑:storage 配置的虛擬路徑,與磁碟選項 store_path*對應。如果配置了 store_path0 則是 M00,如果配置了 store_path1 則是 M01,以此類推。

資料兩級目錄:storage 伺服器在每個虛擬磁碟路徑下建立的兩級目錄,用於儲存資料 檔案。

檔名:與檔案上傳時不同。是由儲存伺服器根據特定資訊生成,檔案名稱包含:來源儲存 伺服器 IP 位址、檔案建立時間戳記、檔案大小、隨機數字和檔案拓展名稱等資訊。

3. 簡易FastDFS建置

簡易FastDFS

什麼是fastdfs與docker

4.使用Docker安裝FastDFS

#4.1 . 取得鏡像

可以利用現有的FastDFS Docker映像來運行FastDFS。

取得映像檔可以透過下載

docker image pull delron/fastdfs

也可是直接使用現有的映像備份檔案

docker load -i 文件路径/fastdfs_docker.tar

載入好鏡像後,就可以開啟執行FastDFS的tracker和storage了。

4.2. 執行tracker

執行下列指令開啟tracker 服務

docker run -dti --network=host --name tracker -v /var/fdfs/tracker:/var/fdfs delron/fastdfs tracker

我們將fastDFS tracker執行目錄對應到本機的/var/fdfs /tracker目錄中。

執行以下指令查看tracker是否執行起來

docker container ls

如果想停止tracker服務,可以執行下列指令

docker container stop tracker

停止後,重新執行tracker,可以執行下列指令

docker container start tracker

4.3. 執行storage

執行下列指令開啟storage服務

docker run -dti --network=host --name storage -e TRACKER_SERVER=10.211.55.5:22122 -v /var/fdfs/storage:/var/fdfs delron/fastdfs storage

TRACKER_SERVER=本機的ip位址:22122,本機ip位址不要使用127.0.0.1

我們將fastDFS storage運行目錄對應到本機的/var/fdfs/storage目錄中

執行以下指令查看storage是否運作起來

docker container ls

如果想要停止storage服務,可以執行以下命令

docker container stop storage

停止後,重新運行storage,可以執行以下命令

docker container start storage

注意:如果無法重新運行,可以刪除/var/fdfs/storage /data目錄下的fdfs_storaged.pid 文件,然後重新運行storage。

推薦學習:《docker影片教學

以上是什麼是fastdfs與docker的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
為什麼要使用Docker?解釋的好處和優勢為什麼要使用Docker?解釋的好處和優勢Apr 25, 2025 am 12:05 AM

使用Docker的原因是它提供高效、便攜且一致的環境來打包、分發和運行應用程序。 1)Docker是一種容器化平台,允許開發者將應用程序及其依賴項打包到輕量級、可移植的容器中。 2)它基於Linux容器技術和聯合文件系統,確保快速啟動和高效運行。 3)Docker支持多階段構建,優化鏡像大小和部署速度。 4)使用Docker可以簡化開發和部署流程,提高效率並確保跨環境的一致性。

Docker在行動:現實世界中的示例和用例Docker在行動:現實世界中的示例和用例Apr 24, 2025 am 12:10 AM

Docker在實際項目中的應用場景包括簡化部署、管理多容器應用和性能優化。 1.Docker簡化了應用部署,如使用Dockerfile部署Node.js應用。 2.DockerCompose管理多容器應用,如微服務架構中的Web和數據庫服務。 3.性能優化使用多階段構建減小鏡像大小,並通過健康檢查監控容器狀態。

Docker vs. Kubernetes:用例和方案Docker vs. Kubernetes:用例和方案Apr 23, 2025 am 12:11 AM

在小型項目或開發環境中選擇Docker,在大型項目或生產環境中選擇Kubernetes。 1.Docker適合快速迭代和測試,2.Kubernetes提供強大的容器編排能力,適合管理和擴展大型應用。

Linux上的Docker:Linux系統的容器化Linux上的Docker:Linux系統的容器化Apr 22, 2025 am 12:03 AM

Docker在Linux上重要,因為Linux是其原生平台,提供了豐富的工具和社區支持。 1.安裝Docker:使用sudoapt-getupdate和sudoapt-getinstalldocker-cedocker-ce-clicontainerd.io。 2.創建和管理容器:使用dockerrun命令,如dockerrun-d--namemynginx-p80:80nginx。 3.編寫Dockerfile:優化鏡像大小,使用多階段構建。 4.優化和調試:使用dockerlogs和dockerex

Docker:容器化工具,Kubernetes:編排者Docker:容器化工具,Kubernetes:編排者Apr 21, 2025 am 12:01 AM

Docker是容器化工具,Kubernetes是容器編排工具。 1.Docker打包應用及其依賴成容器,可在任何支持Docker的環境中運行。 2.Kubernetes管理這些容器,實現自動化部署、擴展和管理,使應用高效運行。

Docker的目的:簡化應用程序部署Docker的目的:簡化應用程序部署Apr 20, 2025 am 12:09 AM

Docker的目的是簡化應用部署,通過容器化技術確保應用在不同環境中一致運行。 1)Docker通過將應用和依賴打包到容器中,解決了環境差異問題。 2)使用Dockerfile創建鏡像,確保應用在任何地方一致運行。 3)Docker的工作原理基於鏡像和容器,利用Linux內核的命名空間和控制組實現隔離和資源管理。 4)基本用法包括從DockerHub拉取並運行鏡像,高級用法涉及使用DockerCompose管理多容器應用。 5)常見錯誤如鏡像構建失敗和容器無法啟動,可通過日誌和網絡配置調試。 6)性能優化建

Linux和Docker:不同Linux發行版的DockerLinux和Docker:不同Linux發行版的DockerApr 19, 2025 am 12:10 AM

在Ubuntu、CentOS和Debian上安裝和使用Docker的方法各有不同。 1)Ubuntu:使用apt包管理器,命令為sudoapt-getupdate&&sudoapt-getinstalldocker.io。 2)CentOS:使用yum包管理器,需添加Docker倉庫,命令為sudoyuminstall-yyum-utils&&sudoyum-config-manager--add-repohttps://download.docker.com/lin

掌握Docker:Linux用戶指南掌握Docker:Linux用戶指南Apr 18, 2025 am 12:08 AM

在Linux上使用Docker可以提高開發效率和簡化應用部署。 1)拉取Ubuntu鏡像:dockerpullubuntu。 2)運行Ubuntu容器:dockerrun-itubuntu/bin/bash。 3)創建包含nginx的Dockerfile:FROMubuntu;RUNapt-getupdate&&apt-getinstall-ynginx;EXPOSE80。4)構建鏡像:dockerbuild-tmy-nginx.。 5)運行容器:dockerrun-d-p8080:80

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器