Docker实践与应用举例

引言

Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。本文将详细介绍 Docker 的基本概念、安装配置、基本命令,并通过一个实际的应用案例来演示如何使用 Docker。

Docker 基本概念

什么是 Docker?

Docker 是一个开源的容器化平台,它利用 Linux 内核的特性(如 Cgroups 和 Namespaces)来创建轻量级的、可移植的容器。Docker 容器包含了运行应用程序所需的所有依赖项,使得应用程序可以在不同的环境中一致地运行。

  • 镜像:类似于虚拟机的镜像,是一个只读的模板,包含了运行某个软件所需的所有内容,如代码、运行时、库、环境变量和配置文件。
  • 容器:容器是从镜像创建的运行实例,可以启动、停止、删除。容器之间是相互隔离的,但共享同一个操作系统的内核。
  • 仓库:存放Docker镜像的场所,类似于代码仓库,用于镜像的分发和共享。Docker Hub是最大的公开仓库,但用户也可以搭建私有仓库。

Docker安装与配置

以CentOS 7为例,Docker的安装步骤大致如下:

  1. 安装Docker引擎
    • 首先安装必要的软件包。
    • 添加Docker稳定版本的yum软件源。
    • 安装Docker CE。
  2. 配置Docker
    • 创建或修改/etc/docker/daemon.json文件,配置如镜像加速等。
    • 重启Docker服务。

实践案例

案例一:部署Nginx服务

  1. 拉取Nginx镜像

    复制代码

    bash复制代码

    |---|---------------------|
    | | docker pull nginx |

  2. 运行Nginx容器

    复制代码

    bash复制代码

    |---|-------------------------------------------------------|
    | | docker run --name nginx-container -p 80:80 -d nginx |

    这条命令会创建一个名为nginx-container的容器,并将容器的80端口映射到宿主机的80端口,实现Nginx服务的对外访问。

  3. 访问Nginx服务

    在浏览器中输入宿主机的IP地址,即可访问Nginx的默认页面。

案例二:使用Dockerfile创建并运行Redis容器

  1. 创建Dockerfile

    在项目的根目录下创建一个Dockerfile,内容如下:

    复制代码

    Dockerfile复制代码

    |---|------------------------|
    | | FROM redis |
    | | EXPOSE 6379 |
    | | CMD ["redis-server"] |

  2. 构建Redis镜像

    复制代码

    bash复制代码

    |---|------------------------------|
    | | docker build -t my-redis . |

  3. 运行Redis容器

    复制代码

    bash复制代码

    |---|-----------------------------------------------------------------|
    | | docker run --name my-redis-container -p 6379:6379 -d my-redis |

  4. 使用Redis客户端连接

    使用redis-cli或其他Redis客户端工具连接到宿主机的6379端口,即可进行Redis的操作。

案例三:使用Docker部署多服务应用

假设我们需要在一个Docker容器中同时运行SSH和Apache服务。我们可以使用Supervisor来管理这些服务。

  1. 创建Dockerfile

    复制代码

    Dockerfile复制代码

    |---|-------------------------------------------------------------------------------|
    | | FROM ubuntu:18.04 |
    | | RUN apt-get update && apt-get install -y openssh-server apache2 supervisor |
    | | RUN mkdir -p /var/run/sshd /var/log/supervisor |
    | | COPY supervisord.conf /etc/supervisor/conf.d/supervisord.conf |
    | | EXPOSE 22 80 |
    | | CMD ["/usr/bin/supervisord"] |

  2. 创建Supervisor配置文件supervisord.conf):

    复制代码

    ini复制代码

    |---|---------------------------------------------------------------------------------------------|
    | | [supervisord] |
    | | nodaemon=true |
    | | |
    | | [program:sshd] |
    | | command=/usr/sbin/sshd -D |
    | | |
    | | [program:apache2] |
    | | command=/bin/bash -c "source /etc/apache2/envvars && exec /usr/sbin/apache2 -DFOREGROUND" |

  3. 构建并运行容器

    复制代码

    bash复制代码

    |---|--------------------------------------------------------------------------------|
    | | docker build -t multi-service-container . |
    | | docker run --name multi-service -p 22:22 -p 80:80 -d multi-service-container |

    现在,你可以通过SSH和HTTP协议分别访问容器的SSH和Apache服务了。

总结

通过上述实践案例,我们可以看到Docker在部署和管理应用程序时的强大功能。无论是简单的Web服务还是复杂的多服务应用,Docker都能提供灵活、高效的解决方案。希望这篇文章能够帮助你更好地理解和应用Docker技术。

相关推荐
小陈phd13 小时前
混合知识库搭建:本地Docker部署Neo4j图数据库与Milvus向量库
数据库·docker·neo4j
Wpa.wk14 小时前
容器编排 - 了解K8s(pod, deployment,service,lable等概念)
经验分享·测试工具·docker·云原生·容器·kubernetes
Wpa.wk17 小时前
容器编排 - K8s - 配置文件参数说明和基础命令
经验分享·测试工具·docker·云原生·容器·kubernetes
LCG米19 小时前
基于PyTorch的TCN-GRU电力负荷预测:从多维数据预处理到Docker云端部署
pytorch·docker·gru
Warren9820 小时前
接口测试理论
docker·面试·职场和发展·eureka·ansible
杭州杭州杭州20 小时前
Docker
运维·docker·容器
等什么君!1 天前
Docker 数据卷:MySQL 数据同步实战
运维·docker·容器
礼拜天没时间.1 天前
《Docker实战入门与部署指南:从核心概念到网络与数据管理》:环境准备与Docker安装
运维·网络·docker·容器·centos
风流倜傥唐伯虎1 天前
Windows 版 Docker 的 Linux 环境(docker-desktop)与 builder-jammy-base:latest 镜像核心区别
linux·docker·容器
Ha_To1 天前
2026.1.30 搭建docker仓库
运维·docker·容器