利用 Docker 和 Kubernetes 实现微服务部署

简介: 【10月更文挑战第2天】利用 Docker 和 Kubernetes 实现微服务部署

引言

随着云计算的发展,越来越多的应用程序采用微服务架构来构建。微服务架构强调将单一的大规模应用程序拆分成一组小的服务,每个服务都运行在其自己的进程中,并且彼此之间通过轻量级通信机制(通常是HTTP资源API)进行通信。这种架构的好处在于它使得开发、维护和服务扩展变得更加容易。然而,管理多个服务实例的生命周期也变得更加复杂。这时,容器技术和编排工具如 Docker 和 Kubernetes 成为了管理微服务的关键技术。

Docker 简介

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。

容器化一个简单应用

假设我们有一个简单的 Python Web 应用,我们想将其容器化以便更好地管理和部署。

from flask import Flask
app = Flask(__name__)

@app.route("/")
def hello_world():
    return "<p>Hello, World!</p>"

if __name__ == '__main__':
    app.run(host='0.0.0.0')

接下来,我们需要创建一个 Dockerfile 来描述如何构建 Docker 镜像。

# 使用官方 Python 运行时作为父镜像
FROM python:3.8-slim

# 设置工作目录
WORKDIR /app

# 将当前目录的内容复制到容器的工作目录中
COPY . .

# 安装依赖包
RUN pip install --no-cache-dir flask

# 使端口对外界系统完全可见
EXPOSE 5000

# 在容器启动时运行应用
CMD ["python", "app.py"]

使用 docker build 命令来构建镜像:

docker build -t my-python-app .

构建成功后,可以使用 docker run 命令来启动容器:

docker run -p 4000:5000 my-python-app

Kubernetes 入门

Kubernetes(简称 k8s)是一个开源的系统,用于自动化部署、扩展以及管理容器化的应用。它提供了容器化应用的部署、维护和扩展机制。

使用 Minikube 进行本地开发

Minikube 是一个工具,可以在本地环境中运行一个单节点的 Kubernetes 集群。

首先安装 Minikube:

curl -Lo minikube https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64
chmod +x minikube
sudo mv minikube /usr/local/bin

安装完 Minikube 后,可以启动一个集群:

minikube start

一旦集群准备好,就可以部署之前创建的 Docker 镜像了。首先,需要将镜像推送到 Docker Hub 或者其他私有仓库:

docker tag my-python-app username/my-python-app
docker push username/my-python-app

然后编写一个 Kubernetes Deployment 文件来部署应用:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-python-app
spec:
  replicas: 3
  selector:
    matchLabels:
      app: my-python-app
  template:
    metadata:
      labels:
        app: my-python-app
    spec:
      containers:
      - name: my-python-app
        image: username/my-python-app
        ports:
        - containerPort: 5000

使用 kubectl apply 命令来创建 Deployment:

kubectl apply -f deployment.yaml

为了使服务可以从外部访问,还需要创建一个 Service:

apiVersion: v1
kind: Service
metadata:
  name: my-python-app-service
spec:
  selector:
    app: my-python-app
  ports:
    - protocol: TCP
      port: 80
      targetPort: 5000
  type: NodePort

同样地,使用 kubectl apply 来创建 Service:

kubectl apply -f service.yaml

结论

本文介绍了如何使用 Docker 来容器化一个简单的 Python Web 应用,并且使用 Kubernetes 在本地 Minikube 集群中部署这个应用。虽然这里只是一个简单的例子,但它展示了如何将传统应用转变为现代云原生应用的一部分。在实际生产环境中,还需要考虑更多方面,比如安全、监控、日志记录以及持续集成/持续部署(CI/CD)。掌握这些技能对于现代软件工程师来说至关重要。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
5天前
|
存储 Kubernetes 对象存储
部署DeepSeek但GPU不足,ACK One注册集群助力解决IDC GPU资源不足
借助阿里云ACK One注册集群,充分利用阿里云强大ACS GPU算力,实现DeepSeek推理模型高效部署。
|
5天前
|
消息中间件 监控 RocketMQ
Docker部署RocketMQ5.2.0集群
本文详细介绍了如何使用Docker和Docker Compose部署RocketMQ 5.2.0集群。通过创建配置文件、启动集群和验证容器状态,您可以快速搭建起一个RocketMQ集群环境。希望本文能够帮助您更好地理解和应用RocketMQ,提高消息中间件的部署和管理效率。
152 91
|
6天前
|
存储 NoSQL Redis
Docker 部署 Redis
在使用 Docker 部署 Redis 时,为实现数据持久化,需正确挂载容器内的数据目录到宿主机。推荐命令如下: ``` docker run -d --name redis -v /mnt/data/redis:/data -p 6379:6379 redis ``` 该命令将宿主机的 `/mnt/data/redis` 目录挂载到容器的 `/data` 目录,确保 Redis 数据持久化。此路径更通用,适合大多数场景。避免使用不匹配的挂载路径,如 `/var/lib/redis` 或 `/mnt/data/redis` 到非默认目录,以防止数据无法正确持久化。
|
21天前
|
存储 关系型数据库 MySQL
美团面试:MySQL为什么 不用 Docker部署?
45岁老架构师尼恩在读者交流群中分享了关于“MySQL为什么不推荐使用Docker部署”的深入分析。通过系统化的梳理,尼恩帮助读者理解为何大型MySQL数据库通常不使用Docker部署,主要涉及性能、管理复杂度和稳定性等方面的考量。文章详细解释了有状态容器的特点、Docker的资源隔离问题以及磁盘IO性能损耗,并提供了小型MySQL使用Docker的最佳实践。此外,尼恩还介绍了Share Nothing架构的优势及其应用场景,强调了配置管理和数据持久化的挑战。最后,尼恩建议读者参考《尼恩Java面试宝典PDF》以提升技术能力,更好地应对面试中的难题。
|
13天前
|
JavaScript 前端开发 Docker
如何通过pm2以cluster模式多进程部署next.js(包括docker下的部署)
通过这些步骤,可以确保您的Next.js应用在多核服务器上高效运行,并且在Docker环境中实现高效的容器化管理。
72 44
|
10天前
|
存储 Kubernetes 测试技术
企业级LLM推理部署新范式:基于ACK的DeepSeek蒸馏模型生产环境落地指南
本教程演示如何在ACK中使用vLLM框架快速部署DeepSeek R1模型推理服务。
|
11天前
|
存储 人工智能 弹性计算
NVIDIA NIM on ACK:优化生成式AI模型的部署与管理
本文结合NVIDIA NIM和阿里云容器服务,提出了基于ACK的完整服务化管理方案,用于优化生成式AI模型的部署和管理。
|
5天前
|
人工智能 Kubernetes 异构计算
大道至简-基于ACK的Deepseek满血版分布式推理部署实战
本教程演示如何在ACK中多机分布式部署DeepSeek R1满血版。
|
1月前
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
58 23
|
25天前
|
SQL Java Maven
docker部署apollo
docker部署apollo步骤