search
HomeOperation and MaintenanceDockerHow to store docker deployment ceph

This article will introduce in detail how to use Docker to deploy and store Ceph.

Ceph is an open source distributed storage system with high availability and strong scalability. It can run on ordinary hardware and supports a variety of storage protocols, such as Block, Object and File. Docker is a popular containerization platform that enables rapid deployment and management of applications. Using Ceph with Docker, we can easily run Ceph in a container and use it as a storage backend.

Below we will introduce how to use Docker to deploy Ceph and store it:

  1. Install Docker

Before we start, we need to install Docker first. You can install the corresponding Docker according to your own operating system version. For specific installation methods, please refer to Docker official documentation.

  1. Create a Ceph image

To run Ceph in Docker you need to create an image first. You can use a Dockerfile to build an image, or you can download an existing Ceph image from Docker Hub.

The method of using Dockerfile to build an image is as follows:

FROM ceph/daemon:latest

Save the above code as a Dockerfile, and then execute the following command to build the image:

docker build -t myceph .

where myceph represents the custom image name .

  1. Deploying Ceph

Before deploying Ceph, you need to create a network to ensure that Ceph-related containers can communicate with each other. You can use the following command to create a Docker network named ceph_network:

docker network create ceph_network

Then use the following command to run Ceph:

docker run -d --net=ceph_network --name=mon myceph /bin/bash -c "ceph-mon --mkfs -i myname && ceph-mon -i myname"
docker run -d --net=ceph_network --name=mgr myceph ceph-mgr -i myname
docker run -d --net=ceph_network --name=osd1 -v /dev/sdb:/dev/sdb -v /data:/var/lib/ceph/osd/ceph-0 myceph /bin/bash -c "ceph-osd --mkfs --osd-uuid myuuid && ceph-osd -i 0"

Among them, mon means the monitor, mgr means the manager, and osd1 means the first data node, /dev/sdb represents the hard disk device, and /data represents the directory used to store data.

  1. Configuring Ceph

After Ceph deployment is completed, some configuration is required. You can use the following command to create a Ceph user:

ceph auth get-or-create client.docker mon 'allow r' mgr 'allow r' osd 'allow rwx pool=data'

and then use this user for access in the application.

  1. Storing data

Ceph supports multiple storage protocols, such as Block, Object and File. The following uses Block storage as an example for explanation.

You can use the following command to create a Pool in Ceph:

ceph osd pool create mypool 50

Then use the following command to create a block device in the Pool:

rados -p mypool create myblock --size 1024

Finally use the following command to The block device is mapped locally:

rbd map mypool/myblock

Now you can write data to the block device and use the device to read and write in the application.

Summary

This article introduces how to use Docker to deploy Ceph and store it. From creating images, deploying Ceph, configuring Ceph to storing data, it comprehensively demonstrates how to use Ceph in Docker. Hope this article is helpful to you.

The above is the detailed content of How to store docker deployment ceph. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Why Use Docker? Benefits and Advantages ExplainedWhy Use Docker? Benefits and Advantages ExplainedApr 25, 2025 am 12:05 AM

The reason for using Docker is that it provides an efficient, portable and consistent environment to package, distribute, and run applications. 1) Docker is a containerized platform that allows developers to package applications and their dependencies into lightweight, portable containers. 2) It is based on Linux container technology and joint file system to ensure fast startup and efficient operation. 3) Docker supports multi-stage construction, optimizes image size and deployment speed. 4) Using Docker can simplify development and deployment processes, improve efficiency and ensure consistency across environments.

Docker in Action: Real-World Examples and Use CasesDocker in Action: Real-World Examples and Use CasesApr 24, 2025 am 12:10 AM

Docker's application scenarios in actual projects include simplifying deployment, managing multi-container applications and performance optimization. 1.Docker simplifies application deployment, such as using Dockerfile to deploy Node.js applications. 2. DockerCompose manages multi-container applications, such as web and database services in microservice architecture. 3. Performance optimization uses multi-stage construction to reduce the image size and monitor the container status through health checks.

Docker vs. Kubernetes: Use Cases and ScenariosDocker vs. Kubernetes: Use Cases and ScenariosApr 23, 2025 am 12:11 AM

Select Docker in a small project or development environment, and Kubernetes in a large project or production environment. 1.Docker is suitable for rapid iteration and testing, 2. Kubernetes provides powerful container orchestration capabilities, suitable for managing and expanding large applications.

Docker on Linux: Containerization for Linux SystemsDocker on Linux: Containerization for Linux SystemsApr 22, 2025 am 12:03 AM

Docker is important on Linux because Linux is its native platform that provides rich tools and community support. 1. Install Docker: Use sudoapt-getupdate and sudoapt-getinstalldocker-cedocker-ce-clicotainerd.io. 2. Create and manage containers: Use dockerrun commands, such as dockerrun-d--namemynginx-p80:80nginx. 3. Write Dockerfile: Optimize the image size and use multi-stage construction. 4. Optimization and debugging: Use dockerlogs and dockerex

Docker: The Containerization Tool, Kubernetes: The OrchestratorDocker: The Containerization Tool, Kubernetes: The OrchestratorApr 21, 2025 am 12:01 AM

Docker is a containerization tool, and Kubernetes is a container orchestration tool. 1. Docker packages applications and their dependencies into containers that can run in any Docker-enabled environment. 2. Kubernetes manages these containers, implementing automated deployment, scaling and management, and making applications run efficiently.

Docker's Purpose: Simplifying Application DeploymentDocker's Purpose: Simplifying Application DeploymentApr 20, 2025 am 12:09 AM

The purpose of Docker is to simplify application deployment and ensure that applications run consistently in different environments through containerization technology. 1) Docker solves the environmental differences problem by packaging applications and dependencies into containers. 2) Create images using Dockerfile to ensure that the application runs consistently anywhere. 3) Docker's working principle is based on images and containers, and uses the namespace and control groups of the Linux kernel to achieve isolation and resource management. 4) The basic usage includes pulling and running images from DockerHub, and the advanced usage involves managing multi-container applications using DockerCompose. 5) Common errors such as image building failure and container failure to start, you can debug through logs and network configuration. 6) Performance optimization construction

Linux and Docker: Docker on Different Linux DistributionsLinux and Docker: Docker on Different Linux DistributionsApr 19, 2025 am 12:10 AM

The methods of installing and using Docker on Ubuntu, CentOS, and Debian are different. 1) Ubuntu: Use the apt package manager, the command is sudoapt-getupdate&&sudoapt-getinstalldocker.io. 2) CentOS: Use the yum package manager and you need to add the Docker repository. The command is sudoyumininstall-yyum-utils&&sudoyum-config-manager--add-repohttps://download.docker.com/lin

Mastering Docker: A Guide for Linux UsersMastering Docker: A Guide for Linux UsersApr 18, 2025 am 12:08 AM

Using Docker on Linux can improve development efficiency and simplify application deployment. 1) Pull Ubuntu image: dockerpullubuntu. 2) Run Ubuntu container: dockerrun-itubuntu/bin/bash. 3) Create Dockerfile containing nginx: FROMubuntu;RUNapt-getupdate&&apt-getinstall-ynginx;EXPOSE80. 4) Build the image: dockerbuild-tmy-nginx. 5) Run container: dockerrun-d-p8080:80

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

SecLists

SecLists

SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Atom editor mac version download

Atom editor mac version download

The most popular open source editor