windows11下基于docker單機部署ceph集群

windows下基于docker單機部署ceph集群

  1. 創建ceph專用網絡
docker network create --driver bridge --subnet 172.20.0.0/16 ceph-network
  1. 查看是否創建成功(查看創建狀態)
docker network inspect ceph-network
  1. 拉取鏡像:(鏡像源自行選擇)
docker pull ceph/daemon:latest-luminous
# 查看鏡像
docker images
  1. 搭建 monitor 節點(監控集群狀態)
# 創建本地目錄
New-Item -ItemType Directory -Force -Path ./etc/ceph
New-Item -ItemType Directory -Force -Path ./var/lib/ceph
New-Item -ItemType Directory -Force -Path ./var/log/ceph# 運行容器
docker run -d --name ceph-mon --network ceph-network --ip 172.20.0.10 -e CLUSTER=ceph -e WEIGHT=1.0 -e MON_IP=172.20.0.10 -e MON_NAME=ceph-mon -e CEPH_PUBLIC_NETWORK=172.20.0.0/16 -v ${PWD}/etc/ceph:/etc/ceph -v ${PWD}/var/lib/ceph/:/var/lib/ceph/ -v ${PWD}/var/log/ceph/:/var/log/ceph/ ceph/daemon:latest-luminous mon
  1. 搭建 osd 節點(對象存儲節點)
# 執行命令獲取密鑰環
docker exec ceph-mon ceph auth get client.bootstrap-osd -o /var/lib/ceph/bootstrap-osd/ceph.keyring# 修改配置文件,使用 PowerShell 追加內容到文件
$configPath = "${PWD}/etc/ceph/ceph.conf"
"osd max object name len = 256`nosd max object namespace len = 64" | Out-File -FilePath $configPath -Append -Encoding UTF8# 創建 OSD 本地目錄
New-Item -ItemType Directory -Force -Path ./var/lib/ceph/osd/1
New-Item -ItemType Directory -Force -Path ./var/lib/ceph/osd/2
New-Item -ItemType Directory -Force -Path ./var/lib/ceph/osd/3# 分別啟動三個容器來模擬集群
docker run -d --privileged=true --name ceph-osd-1 --network ceph-network --ip 172.20.0.11 -e CLUSTER=ceph -e WEIGHT=1.0 -e MON_NAME=ceph-mon -e MON_IP=172.20.0.10 -e OSD_TYPE=directory -v ${PWD}/etc/ceph:/etc/ceph -v ${PWD}/var/lib/ceph/:/var/lib/ceph/ -v ${PWD}/var/lib/ceph/osd/1:/var/lib/ceph/osd ceph/daemon:latest-luminous osd
docker run -d --privileged=true --name ceph-osd-2 --network ceph-network --ip 172.20.0.12 -e CLUSTER=ceph -e WEIGHT=1.0 -e MON_NAME=ceph-mon -e MON_IP=172.20.0.10 -e OSD_TYPE=directory -v ${PWD}/etc/ceph:/etc/ceph -v ${PWD}/var/lib/ceph/:/var/lib/ceph/ -v ${PWD}/var/lib/ceph/osd/2:/var/lib/ceph/osd ceph/daemon:latest-luminous osd
docker run -d --privileged=true --name ceph-osd-3 --network ceph-network --ip 172.20.0.13 -e CLUSTER=ceph -e WEIGHT=1.0 -e MON_NAME=ceph-mon -e MON_IP=172.20.0.10 -e OSD_TYPE=directory -v ${PWD}/etc/ceph:/etc/ceph -v ${PWD}/var/lib/ceph/:/var/lib/ceph/ -v ${PWD}/var/lib/ceph/osd/3:/var/lib/ceph/osd ceph/daemon:latest-luminous osd
  1. 搭建 mgr 節點(管理節點,可打開管理面板)
docker run -d --privileged=true --name ceph-mgr --network ceph-network --ip 172.20.0.14 -e CLUSTER=ceph -p 7000:7000 --pid=container:ceph-mon -v ${PWD}/etc/ceph:/etc/ceph -v ${PWD}/var/lib/ceph/:/var/lib/ceph/ ceph/daemon:latest-luminous mgr# 開啟管理界面
docker exec ceph-mgr ceph mgr module enable dashboard
  1. 搭建 rgw 節點(ceph網關,可以搭建多個)
# 執行命令獲取密鑰環
docker exec ceph-mon ceph auth get client.bootstrap-rgw -o /var/lib/ceph/bootstrap-rgw/ceph.keyring# 運行 RGW 容器
docker run -d --privileged=true --name ceph-rgw --network ceph-network --ip 172.20.0.15 -e CLUSTER=ceph -e RGW_NAME=ceph-rgw -p 7480:7480 -v ${PWD}/var/lib/ceph/:/var/lib/ceph/ -v ${PWD}/etc/ceph:/etc/ceph ceph/daemon:latest-luminous rgw
  1. 檢查 ceph 狀態
docker exec ceph-mon ceph -s

集群已經部署完畢,下面是用于開發的步驟:在這里插入圖片描述

  1. 測試添加 rgw 用戶,生成 access_key 和 secret_key 用于訪問
docker exec ceph-rgw radosgw-admin user create --uid="test" --display-name="test user"

生成結果如:


PS C:\WINDOWS\system32> docker exec ceph-rgw radosgw-admin user create --uid="test" --display-name="test user"
{"user_id": "test","display_name": "test user","email": "","suspended": 0,"max_buckets": 1000,"auid": 0,"subusers": [],"keys": [{"user": "test","access_key": "7367PT68J5OCWA84XXXXX","secret_key": "ieAuUzUJJ9Wa9SBTGSnloaIjS8eD8p9z2zXXXXX"}],"swift_keys": [],"caps": [],"op_mask": "read, write, delete","default_placement": "","placement_tags": [],"bucket_quota": {"enabled": false,"check_on_raw": false,"max_size": -1,"max_size_kb": 0,"max_objects": -1},"user_quota": {"enabled": false,"check_on_raw": false,"max_size": -1,"max_size_kb": 0,"max_objects": -1},"temp_url_keys": [],"type": "rgw"
}

開發使用:
可以直接通過代碼進行操作:

package cephimport ("gopkg.in/amz.v1/aws""gopkg.in/amz.v1/s3""log"cfg "filestore-server/config"
)var cephConn *s3.S3// GetCephConnection : 獲取ceph連接
func GetCephConnection() *s3.S3 {if cephConn != nil {return cephConn}// 1. 初始化ceph的一些信息auth := aws.Auth{AccessKey: cfg.Config.CephConfig.CephAccessKey,SecretKey: cfg.Config.CephConfig.CephSecretKey,}curRegion := aws.Region{Name:                 "default",EC2Endpoint:          cfg.Config.CephConfig.CephGWEndpoint,S3Endpoint:           cfg.Config.CephConfig.CephGWEndpoint,S3BucketEndpoint:     "",S3LocationConstraint: false,S3LowercaseBucket:    false,Sign:                 aws.SignV2,}// 2. 創建S3類型的連接return s3.New(auth, curRegion)
}// GetCephBucket : 獲取指定的bucket對象
func GetCephBucket(bucket string) *s3.Bucket {conn := GetCephConnection()b := conn.Bucket(bucket)// 檢查存儲桶是否存在_, err := b.List("", "", "", 0)if err != nil {if s3err, ok := err.(*s3.Error); ok && s3err.StatusCode == 404 {log.Printf("存儲桶 %s 不存在,嘗試創建...", bucket)// 創建存儲桶err = b.PutBucket(s3.PublicRead)if err != nil {log.Printf("創建存儲桶 %s 失敗: %v", bucket, err)return nil}log.Printf("存儲桶 %s 創建成功", bucket)} else {log.Printf("訪問存儲桶 %s 出錯: %v", bucket, err)return nil}}return b
}// PutObject : 上傳文件到ceph集群
func PutObject(bucket string, path string, data []byte) error {buck := GetCephBucket(bucket)return buck.Put(path, data, "octet-stream", s3.PublicRead)
}

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

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

相關文章

使用DataGrip連接安裝在Linux上的Redis

目錄 一、前言 二、開放防火墻端口 三、使用DataGrip連接安裝在Linux上的Redis 一、前言 在學習黑馬Redis從入門到實戰的視頻,完成了Redis在linux上的安裝配置之后,我們可以使用圖形化界面方便操作使用redis數據庫。在24年JavaWebAI學習時連接MySQL數…

MySQL的union、union all導致排序失效

今天練習SQL,使用union all 連接各個查詢導致我的各個查詢排序失效,最后發現使用union all后會忽略各個模塊的order by,只有最外層的order by才會生效原SQL如下:( selectexam_id tid,count(distinct uid) uv, count(uid) pv frome…

LVS 集群技術實踐:NAT 與 DR 模式的配置與對比

1 實驗環境規劃 實驗目標是搭建一個負載均衡集群,通過 LVS 調度器將流量分發到兩臺真實服務器(RS1 和 RS2)。2.網絡配置3 實驗步驟關閉防火墻和 SELinux安裝 HTTP 服務(在 RS21和 RS2 上):sudo systemctl s…

YOLOv8中添加SENet注意力機制

注意力機制(Attention Mechanism)是深度學習中的一種方法,在圖像處理領域,尤其是在卷積神經網絡(CNN)和視覺Transformer等架構中。圖像數據具有局部相關性,注意力機制可以幫助模型聚焦于圖像中更重要的區域,從而提升處理效果。 SENet(Squeeze-and-Excitation Network)…

SpringBoot五分鐘快速入門指南

使用 Spring Boot 構建應用 本指南提供了關于Spring Boot如何幫助您加速應用開發的一些示例。隨著您閱讀更多 Spring 入門指南,您將看到 Spring Boot 的更多用例。本指南旨在讓您快速了解 Spring Boot。如果您想創建自己的基于 Spring Boot 的項目,請訪問 Spring Initializr…

docker,防火墻關閉后,未重啟docker,導致端口映射失敗

首先,看這篇文章前,建議先把網上其他的文章說的方法嘗試一遍!!! 1. 現象 docker啟動某一個容器,然后映射端口時顯示失敗2. 解決 把網上的方法嘗試一遍之后,最后發現是防火墻的問題!&…

事務處理與AOP(web后端筆記第四期)

p.s.這是萌新自己自學總結的筆記,如果想學習得更透徹的話還是請去看大佬的講解 目錄事務spring事物管理事物屬性--回滾事物屬性--傳播行為(propagation)AOP一些核心概念通知類型通知的執行順序切入點表達式executionannotation連接點事務 事物是一組操作的集合&…

第36周———— RNN實現阿爾茨海默病診斷

目錄 前言 1.檢查GPU 2.查看數據 3.劃分數據集 4.創建模型與編譯訓練 ????5.編譯及訓練模型 6.結果可視化 7.模型預測 8.總結: 前言 🍨 本文為🔗365天深度學習訓練營中的學習記錄博客 🍖 原作者:K同學啊 1.檢查G…

equals和hashcode方法重寫

在 Java 中,當你需要基于對象的內容而非引用地址來判斷兩個對象是否相等時,就需要重寫equals和hashCode方法。以下是具體場景和實現原則:一、為什么需要同時重寫這兩個方法?equals方法:默認比較對象的內存地址&#xf…

Excel批量生成SQL語句 Excel批量生成SQL腳本 Excel拼接sql

Excel批量生成SQL語句 Excel批量生成SQL腳本 Excel拼接sql一、情境描述在Excel中有標準的格式化數據,如何快速導入到數據庫中呢?有些工具支持Excel導入的,則可以快速導入數據---例如Navicat;如果不支持呢,如果將Excel表…

金和OA C6 DelTemp.aspx 存在XML實體注入漏洞(CVE-2025-7523)

免責聲明 本文檔所述漏洞詳情及復現方法僅限用于合法授權的安全研究和學術教育用途。任何個人或組織不得利用本文內容從事未經許可的滲透測試、網絡攻擊或其他違法行為。 前言:我們建立了一個更多,更全的知識庫。每日追蹤最新的安全漏洞,追中25HW情報。 更多詳情: http…

Android性能優化之啟動優化

一、啟動性能瓶頸深度分析 1. 冷啟動階段耗時分布階段耗時占比關鍵阻塞點進程創建15%fork進程 加載ZygoteApplication初始化40%ContentProvider/庫初始化Activity創建30%布局inflate 視圖渲染首幀繪制15%VSync信號等待 GPU渲染2. 高頻性能問題 初始化風暴:多個庫…

中國優秀開源軟件及企業調研報告

中國優秀開源軟件及企業調研報告 引言 當前中國開源生態呈現蓬勃發展態勢,技術創新領域尤為活躍,其中人工智能大模型成為開源動作的核心聚焦方向。2025年上半年,國內AI領域開源生態迎來密集爆發,頭部科技企業相繼推出重要開源舉…

C++語法 匿名對象 與 命名對象 的詳細區分

目錄一、匿名對象的本質定義二、匿名對象的調用邏輯:即生即用的設計三、與命名對象的核心差異四、匿名對象的典型應用場景五、匿名對象的潛在風險與規避六、總結:匿名對象的價值定位在 C 類與對象的知識體系中,匿名對象是一種容易被咱們忽略&…

【Fedora 42】Linux內核升級后,鼠標滾輪失靈,libinput的鍋?

解決: 最近在玩Fedora 42,升級了一次給俺鼠標滾輪干失靈了。原因可能是 libinput 升級后與Fedora升級后的某些配置有沖突?(搞不懂) sudo dnf downgrade libinput降級 libinput (1.28.901-1.fc42 -> 1.28.0-1.fc42) …

虛擬機centos服務器安裝

創建虛擬機選擇鏡像啟動 移除舊的repo文件: sudo rm -f /etc/yum.repos.d/CentOS-Base.repo下載阿里云的repo文件: 對于CentOS 7: sudo wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo清除緩存并生…

【js(1)一文解決】var let const

var let const!在 ES6 之前,JavaScript 只有兩種作用域: 全局變量 與 函數內的局部變量一、var1. 函數級作用域,有變量提升二、let(ES6新增)1. 塊級作用域,不會影響外部作用域2.let 關鍵字在不同…

論螺旋矩陣

螺旋矩陣題型總結。我刷了幾道螺旋矩陣相關的題目,這里我們介紹一下一些常見的解法。 螺旋矩陣 方形矩陣 當我們遇到n*n的方形矩陣時,可以用一種特殊的解法來遍歷實現,以下面這道題為例: 59. 螺旋矩陣 II 我們可以定義幾個變…

數學金融與金融工程:學科差異與選擇指南

在金融領域的學習中,數學金融與金融工程常被混淆。兩者雖同屬 “金融 量化” 交叉方向,但在研究側重、培養路徑上有顯著區別。結合學科特點與行業實踐,幫大家理清兩者的核心差異,以便更精準地選擇方向。一、核心差異:…

包管理工具npm cnpm yarn的使用

包管理工具 1. 什么是包管理工具? 包管理工具是用于管理和安裝 Node.js 項目依賴的工具。它們提供了一種結構化的方式來管理項目的依賴關系,使得項目的依賴管理變得更加便捷和可靠。 2. 常見的包管理工具有哪些? npm(Node Package Manager):是 Node.js 的默認包管理工…