一机玩docker之一:数据盘安装docker

简介: 使用数据盘安装docker

条件

一台阿里云ECS,有系统盘,并绑定了数据云盘。

目标

  1. 安装docker服务。
  2. docker服务的数据存放在数据盘上。

一、挂载数据盘

阿里云云盘挂载ECS操作请参考网址

二、数据盘分区及格式化

a、查看磁盘

执行如下命令:

fdisk -l

命令执行后显示信息如下:

Disk /dev/vda: 42.9 GB, 42949672960 bytes, 83886080 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk label type: dos
Disk identifier: 0x0008d73a

   Device Boot      Start         End      Blocks   Id  System
/dev/vda1   *        2048    83884031    41940992   83  Linux

Disk /dev/vdb: 42.9 GB, 42949672960 bytes, 83886080 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes

注:

  1. 默认的数据盘显示为dev/vd?,其中 ? 是 a−z 的任一个字母。
  2. 本例中挂载了一个/dev/vdb的磁盘,40G容量,且未分区。

b、执行分区操作

执行如下命令:

fdisk /dev/vdb #fdisk命令后需输入磁盘名

命令执行后显示信息如下:

Welcome to fdisk (util-linux 2.23.2).

Changes will remain in memory only, until you decide to write them.
Be careful before using the write command.

Device does not contain a recognized partition table
Building a new DOS disklabel with disk identifier 0x56b3abc9.

Command (m for help): n #此处键入n表示创建新的磁盘分区
Partition type:
   p   primary (0 primary, 0 extended, 4 free)
   e   extended
Select (default p): #此处直接回车表示使用默认值p,创建主分区
Using default response p
Partition number (1-4, default 1): #此处直接回车表示使用默认值1,表示创建主分区1个
First sector (2048-83886079, default 2048): #此处直接回车表示使用默认值2048,表示新创建主分区起始扇区2048
Using default value 2048
Last sector, +sectors or +size{K,M,G} (2048-83886079, default 83886079): #此处直接回车表示使用默认值83886079,表示新创建主分区结束扇区83886079
Using default value 83886079
Partition 1 of type Linux and of size 40 GiB is set

Command (m for help): wq #此处输入wq,表示保存分区设定并退出分区命令
The partition table has been altered!

Calling ioctl() to re-read partition table.
Syncing disks.

c、执行格式化操作

执行如下命令:

mkfs.ext3 /dev/vdb1 #mkfs.ext3命令后需输入磁盘分区名

命令执行后显示信息如下:

mke2fs 1.42.9 (28-Dec-2013)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
2621440 inodes, 10485504 blocks
524275 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=4294967296
320 block groups
32768 blocks per group, 32768 fragments per group
8192 inodes per group
Superblock backups stored on blocks: 
    32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208, 
    4096000, 7962624

Allocating group tables: done                            
Writing inode tables: done                            
Creating journal (32768 blocks): done
Writing superblocks and filesystem accounting information: done   

三、数据盘挂载操作

a、手动挂载数据盘

执行如下命令:

mkdir /data #创建目录/data用于挂载数据盘
mount /dev/vdb1 /data #将磁盘分区/dev/vdb1挂载在/data目录下

b、启动时挂载数据盘

执行如下命令:

echo /dev/vdb1 /data ext3 defaults 1 1 >> /etc/fstab #将挂载命令增加到启动配置文件中

四、安装docker应用

a、将操作系统升级,同时更新最新的包发布源。

执行如下命令:

yum -y update #升级系统应用
yum -y install epel-release #更新yum安装源信息

b、查看最新的docker引擎安装包:

具体网址

c、下载并安装docker引擎。

执行如下命令:

mkdir -p /data/setup/ #在数据盘目录/data下创建安装包目录setup
cd /data/setup/ #进入安装包目录setup
wget https://yum.dockerproject.org/repo/main/centos/7/Packages/docker-engine-1.13.1-1.el7.centos.x86_64.rpm #下载安装docker安装rpm包
yum -y install docker-engine-1.13.1-1.el7.centos.x86_64.rpm #yum安装docker引擎

d、启动docker引擎,并设置为开机启动

执行如下命令:

systemctl start docker #启动docker服务
systemctl enable docker #设置docker服务为服务器重启后自动启动

e、将docker相关数据文件移动到数据盘

执行如下命令:

systemctl stop docker #停止docker服务
mv /var/lib/docker /data/ #将docker数据目录移动到/data目录下
ln -s /data/docker /var/lib/docker #制作软连接映射,将数据盘下的docker目录映射为原docker目录

f、配置镜像加速器

执行如下命令:

mkdir -p /etc/docker #创建目录/etc/docker
tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://yekyiho7.mirror.aliyuncs.com"]
}
EOF #在/etc/docker目录中创建文件daemon.json,并设定仓库镜像参数。
systemctl daemon-reload #加载上述参数

g、重新启动docker,并查看docker版本

执行如下命令:

systemctl start docker #启动docker服务
docker --version #查看docker服务版本

显示版本信息如下:

Docker version 1.13.1, build 092cba3
目录
相关文章
|
3月前
|
关系型数据库 应用服务中间件 nginx
Docker一键安装中间件(RocketMq、Nginx、MySql、Minio、Jenkins、Redis)
本系列脚本提供RocketMQ、Nginx、MySQL、MinIO、Jenkins和Redis的Docker一键安装与配置方案,适用于快速部署微服务基础环境。
|
1月前
|
关系型数据库 数据库 PostgreSQL
docker 安装 Postgres 17.6
本文介绍如何通过Docker安装和配置PostgreSQL 17.6。内容包括拉取镜像、导出配置文件、运行容器并挂载数据与配置文件目录,以及进入容器使用psql操作数据库的完整步骤,便于持久化管理和自定义配置。
180 4
docker 安装 Postgres 17.6
|
17天前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
166 7
|
17天前
|
Java Linux 虚拟化
【Docker】(1)Docker的概述与架构,手把手带你安装Docker,云原生路上不可缺少的一门技术!
1. Docker简介 1.1 Docker是什么 为什么docker会出现? 假定您在开发一款平台项目,您的开发环境具有特定的配置。其他开发人员身处的环境配置也各有不同。 您正在开发的应用依赖于您当前的配置且还要依赖于某些配置文件。 您的企业还拥有标准化的测试和生产环境,且具有自身的配置和一系列支持文件。 **要求:**希望尽可能多在本地模拟这些环境而不产生重新创建服务器环境的开销 问题: 要如何确保应用能够在这些环境中运行和通过质量检测? 在部署过程中不出现令人头疼的版本、配置问题 无需重新编写代码和进行故障修复
202 2
|
6月前
|
存储 安全 C++
Odoo 安装方式选择:源码安装 vs Docker
Odoo部署常采用源码编译或Docker容器化,但分别面临依赖复杂、版本风险和服务化难题,以及镜像臃肿和扩展受限的问题。Websoft9提出混合方案,融合两者优势:通过智能环境适配、三阶段部署流程(环境预检、混合模式选择、持久化配置)及声明式YAML配置,实现高效、灵活的双模运行时。此方案显著降低依赖冲突解决时间(从83分钟至0),生产环境构建耗时缩短至8分钟,并达100% CVE漏洞修复率,适合ERP定制开发与规模化部署的企业需求。
|
4月前
|
存储 NoSQL MongoDB
Docker中安装MongoDB并配置数据、日志、配置文件持久化。
现在,你有了一个运行在Docker中的MongoDB,它拥有自己的小空间,对高楼大厦的崩塌视而不见(会话丢失和数据不持久化的问题)。这个MongoDB的数据、日志、配置文件都会妥妥地保存在你为它精心准备的地方,天旋地转,它也不会失去一丁点儿宝贵的记忆(即使在容器重启后)。
496 4
|
3月前
|
Linux Docker Windows
windows docker安装报错适用于 Linux 的 Windows 子系统必须更新到最新版本才能继续。可通过运行 “wsl.exe --update” 进行更新。
适用于 Linux 的 Windows 子系统需更新至最新版本(如 wsl.2.4.11.0.x64.msi)以解决 2025 年 Windows 更新后可能出现的兼容性问题。用户可通过运行 “wsl.exe --update” 或访问提供的链接下载升级包进行更新。
1148 0