百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Docker的前世今生【面试必看】

nanshan 2024-12-02 23:24 5 浏览 0 评论

Docker 是一个开源的容器化平台,可以帮助开发者自动化应用的部署、扩展和管理。通过Docker,开发者能够将应用及其所有依赖项打包成一个轻量级的容器,从而确保应用在不同环境中的一致性和可移植性。

Docker的核心概念:

  1. 容器(Container)
  2. 容器是轻量级的、独立的可执行软件包,包含了运行应用所需的所有代码、库和依赖项。每个容器在系统中相互隔离,并且与宿主操作系统保持隔离。
  3. 镜像(Image)
  4. 镜像是一个只读的模板,用于创建容器。镜像通常包含应用程序及其所有依赖项,是容器的构建基础。你可以把镜像当作容器的蓝图。
  5. Dockerfile
  6. Dockerfile 是一个文本文件,包含了一系列指令,用于自动化构建Docker镜像。它定义了如何安装依赖、复制文件、配置环境等步骤。
  7. Docker Hub
  8. Docker Hub 是一个公共的云端镜像仓库,你可以从Docker Hub中拉取公共镜像,或者将自己的镜像上传到Docker Hub,方便共享和分发。
  9. Docker Compose
  10. Docker Compose 是一个工具,用于定义和管理多容器Docker应用。通过一个 docker-compose.yml 文件,你可以在一个命令下启动多个服务容器,方便进行集成测试和部署。

常用的Docker命令:

  • docker run:启动一个容器,如果镜像不存在,会自动从Docker Hub拉取镜像。
  • docker run -d --name mycontainer myimage
  • docker build:根据Dockerfile构建镜像。
  • docker build -t myimage .
  • docker ps:列出正在运行的容器。
  • docker ps
  • docker stop:停止一个正在运行的容器。
  • docker stop mycontainer
  • docker logs:查看容器的日志输出。
  • docker logs mycontainer
  • docker exec:在正在运行的容器内执行命令。
  • docker exec -it mycontainer /bin/bash
  • docker-compose up:启动由 docker-compose.yml 文件定义的多容器应用。
  • docker-compose up
  • docker-compose down:停止并删除由 docker-compose.yml 文件定义的容器、网络和卷。
  • docker-compose down

为什么使用Docker?

  • 可移植性:Docker容器可以在任何安装了Docker的系统上运行,无论底层的操作系统是什么。
  • 隔离性:每个容器相互隔离,避免了依赖冲突和环境不一致的问题。
  • 一致性:通过Docker,开发、测试和生产环境可以保持一致,减少“在我机器上能跑”的问题。
  • 可扩展性:Docker非常适合与Kubernetes、Docker Swarm等编排工具一起使用,用于跨多个服务器扩展应用。

一个典型的Docker工作流:

  1. 创建Dockerfile:定义应用和环境的构建方式。
  2. 构建镜像:使用 docker build 构建镜像。
  3. 启动容器:使用 docker run 从镜像启动容器。
  4. 如果有多个服务需要协作,可以在 docker-compose.yml 文件中定义服务,并通过 docker-compose up 管理这些服务。

使用Docker


使用Docker的流程大致可以分为以下几个步骤:从安装Docker,到构建镜像、运行容器、使用Docker Compose管理多容器应用。接下来我将详细讲解这些步骤。

1. 安装Docker

首先,你需要在你的计算机上安装Docker。Docker支持多种操作系统,包括Linux、macOS和Windows。你可以根据你的操作系统选择相应的安装步骤。

Linux(以Ubuntu为例)

# 更新APT索引
sudo apt-get update

# 安装必要的软件包
sudo apt-get install apt-transport-https ca-certificates curl software-properties-common

# 添加Docker的官方GPG密钥
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -

# 设置Docker的稳定版本源
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"

# 更新APT索引
sudo apt-get update

# 安装Docker CE(Community Edition)
sudo apt-get install docker-ce

# 启动Docker服务
sudo systemctl start docker

# 设置开机启动Docker
sudo systemctl enable docker

# 验证安装是否成功
sudo docker --version

查看全部

macOS和Windows

  • 可以通过Docker官方提供的Docker Desktop下载安装包。
  • 安装完成后,你可以通过图形化界面来管理Docker,或通过命令行工具(Terminal/PowerShell)来操作。

2. 基本命令

安装完成后,你可以使用Docker的命令行工具(docker)来操作容器。以下是一些常用的Docker命令:

查看Docker版本

docker --version

拉取(下载)镜像

从Docker Hub(或其他镜像仓库)拉取镜像。比如拉取官方的 nginx 镜像:

docker pull nginx

运行容器

从拉取的镜像中运行一个容器。例如,运行 nginx 容器:

docker run -d -p 8080:80 --name mynginx nginx

这里的 -d 参数表示后台运行容器,-p 参数将宿主机的端口 8080 映射到容器的端口 80。--name 参数用来指定容器的名称。

查看正在运行的容器

docker ps

这个命令会列出所有正在运行的容器。

停止容器

docker stop mynginx

删除容器

docker rm mynginx

这将删除一个已停止的容器。

查看容器日志

docker logs mynginx

进入容器的命令行

如果你想进入容器内部,可以使用 docker exec 命令:

docker exec -it mynginx /bin/bash

这会启动一个交互式的Bash shell。

3. 构建和管理Docker镜像

你可以通过 Dockerfile 来定义镜像的构建过程。一个简单的 Dockerfile 例子如下:

创建一个Dockerfile

假设你想要构建一个运行Python应用的镜像。你可以创建一个 Dockerfile 文件,内容如下:

# 使用官方的Python镜像作为基础镜像
FROM python:3.8-slim

# 设置工作目录
WORKDIR /app

# 将当前目录的代码复制到容器中
COPY . /app

# 安装依赖
RUN pip install -r requirements.txt

# 设置容器启动命令
CMD ["python", "app.py"]

构建镜像

在包含 Dockerfile 的目录中,运行以下命令来构建镜像:

docker build -t my-python-app .

这会根据 Dockerfile 构建一个名为 my-python-app 的镜像。

运行镜像

构建完成后,可以运行这个镜像:

docker run -d --name mypythonapp my-python-app

4. 使用Docker Compose管理多容器应用

如果你的应用涉及多个服务(例如数据库、缓存、Web应用等),你可以使用 docker-compose.yml 文件来定义这些服务并启动它们。Docker Compose 是一个工具,用于定义和运行多容器Docker应用。

安装Docker Compose

Docker Compose 通常会随Docker一起安装。如果没有安装,可以使用以下命令安装:

sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose

创建docker-compose.yml文件

假设你需要运行一个Web应用和一个数据库,创建一个 docker-compose.yml 文件,内容如下:

version: '3'
services:
  web:
    image: my-python-app
    ports:
      - "5000:5000"
  db:
    image: postgres
    environment:
      POSTGRES_USER: user
      POSTGRES_PASSWORD: password

启动应用

在 docker-compose.yml 文件所在的目录中,运行以下命令来启动所有服务:

docker-compose up -d

查看应用状态

查看运行中的容器和服务状态:

docker-compose ps

停止应用

docker-compose down

5. 删除镜像和容器

  • 删除镜像
  • docker rmi my-python-app
  • 删除未使用的容器和镜像
  • docker system prune

这将删除所有停止的容器、未使用的网络、悬挂的镜像等。

小结

使用Docker的步骤通常是:

  1. 安装Docker。
  2. 使用 docker pull 拉取镜像。
  3. 使用 docker run 启动容器。
  4. 使用 Dockerfile 创建自定义镜像。
  5. 使用 docker-compose 管理多容器应用。

相关推荐

在 Ubuntu 上安装 Zabbix(以 Zabbix 6.4 LTS 版本为例)

Zabbix是一个流行的开源监控解决方案,能够监控各种网络参数和服务器健康状态。一、环境准备系统要求Ubuntu20.04/22.04LTS至少2GBRAM(生产环境建议4GB+)至少1...

如何在 Ubuntu 24.04 服务器上安装 Apache Solr

ApacheSolr是一个免费、开源的搜索平台,广泛应用于实时索引。其强大的可扩展性和容错能力使其在高流量互联网场景下表现优异。Solr基于Java开发,提供了分布式索引、复制、负载均衡及自...

如何在 Ubuntu 24.04 LTS 或 22.04/20.04 上安装 Apache Maven

Maven是由Apache托管的开源工具,用于管理Java项目。它包含一个项目对象模型(POM):一个配置文件(XML),其中包含项目的基本信息,包括配置、项目依赖项等。Maven可以处理...

Cursor的终极对手——Trae Pro最新系统提示词

前段时间,字节的AI编程神器Trae国际版,终于甩出了Pro订阅计划!很多对它又爱又恨的小伙伴,直呼:终于等到你。爱它,是因为Trae长期免费+体验真香;恨它?还不是那该死的排队等待,...

AI系统提示词:V0(ai代码提示)

以下是对V0系统提示词(SystemPrompt)的分部分讲解与解读,帮助你理解其核心内容和设计意图。V0系统提示词##CoreIdentity-Youarev0,Vercel&...

8岁男童失踪第13天,搜救人员发现可疑水库,更恶心的事情发生了

Lookingatyourrequest,Ineedtorewritethearticleaboutthe8-year-oldmissingboywhilemaking...

docker常用指令及安装rabbitMQ(docker安装zabbix)

一、docker常用指令启动docker:systemctlstartdocker停止docker:systemctlstopdocker重启docker:systemctlrestart...

三步教你用Elasticsearch+PyMuPDF实现PDF大文件秒搜!

面对100页以上的大型PDF文件时,阅读和搜索往往效率低下。传统关系型数据库在处理此类数据时容易遇到性能瓶颈,而Elasticsearch凭借其强大的全文检索和分布式架构,成为理想解决方案。通过...

ElasticSearch中文分词插件(IK)安装

坚持原创,共同进步!请关注我,后续分享更精彩!!!前言ElasticSearch默认的分词插件对中文支持很不友好。一段话按规则会以每个中文字符来拆解,再分别建立倒排索引。如"中华人民共和国国歌...

SpringBoot使用ElasticSearch做文档对象的持久化存储?

ElasticSearch是一个基于Lucene的开源搜索引擎,广泛应用于日志分析、全文搜索、复杂查询等领域,在有些场景中使用ElasticSearch进行文档对象的持久化存储是一个很不错的选择...

Elasticsearch数据迁移方案(elasticsearch copyto)

前言最近小编要去给客户部署一套系统涉及到了Mysql和ES数据的迁移,下面就给大家分享一下ES数据迁移的几套方案,根据具体的使用场景来选择不同的迁移方案能使你事倍功半,话多说下面就一一介绍。Elast...

Rancher部署单体ElasticSearch(rancher2.5部署)

Rancher是k8s图形管理界面,之前曾有写文章介绍如何安装。ElasticSearch是热门搜索引擎,很多地方都有用到,常规安装部署略显繁琐,本文介绍在k8s下用rancher简易部署ES。1.在...

Elasticsearch在Java项目的搜索实践:从零开始构建高效搜索系统

Elasticsearch在Java项目中的搜索实践:从零开始构建高效搜索系统在现代的Java项目中,数据量激增,传统的数据库查询方式已经无法满足快速检索的需求。这时,Elasticsearch(E...

小白入门-Kibana安装(kibana安装配置)

一Kibana基础1.1介绍Kibana是一款免费且开放的前端应用程序,其基础是ElasticStack,可以为Elasticsearch中索引的数据提供搜索和数据可视化功能。Kiban...

Docker上使用Elasticsearch,Logstash,Kibana

在对一个项目做性能测试时我需要处理我们web服务器的访问日志来分析当前用户的访问情况。因此,我想这是试用ELK的一个好机会。ELK栈首先要注意的是使用它是非常简单的。从决定使用ELK到在本机上搭一个...

取消回复欢迎 发表评论: