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技术。

相关推荐
Learn-Python1 小时前
修改docker容器内文件后让其生效
运维·docker·容器
赵丙双2 小时前
docker restart 策略
docker·restart
工具罗某人2 小时前
docker实现redis-cluster模式集群部署
java·redis·docker
杨浦老苏4 小时前
轻量级RSS源处理中间件FeedCraft
人工智能·docker·ai·群晖·rss
Devin~Y4 小时前
大厂 Java 面试实战:从电商微服务到 AI 智能客服(含 Spring 全家桶、Redis、Kafka、RAG/Agent 解析)
java·spring boot·redis·elasticsearch·spring cloud·docker·kafka
樽酒ﻬق4 小时前
构筑容器化基石:Docker 稳定版本抉择、极速安装与配置全解
java·docker·运维开发
啦啦啦小石头5 小时前
Docker+Nvidia Container Toolkit 在ubuntu下离线安装
ubuntu·docker·eureka
Ares-Wang13 小时前
Linux》》systemd 、service、systemctl daemon-reload、systemctl restart docker
linux·运维·docker
苏渡苇16 小时前
Docker 网络完全指南
网络·docker·容器·docker容器·容器通信
斯普信云原生组18 小时前
Docker 开源软件应急处理方案及操作手册——镜像管理与构建故障
docker·容器·eureka