写点什么

如何使用 Kubernetes 在实践中部署微服务?

  • 2020-05-18
  • 本文字数:3220 字

    阅读完需:约 11 分钟

如何使用Kubernetes在实践中部署微服务?

由于早期单体架构复杂性逐渐增加、部署速度逐渐变慢,极大程度阻碍了企业技术创新。因此,为了改善这一问题,微服务成为部分企业的切实所需。


尽管近两年来,微服务发展势头迅猛,但围绕着容器能否很好地实施微服务依旧存在争议。在本文中,我们首先回顾一下领先的容器管理和服务编排框架 Kubernetes。如今,Kubernetes 和微服务几乎是同义词,所以最好彻底了解它们是如何组合在一起的。

Kubernetes 的优势

与微服务本身非常相似,容器近年来已成为现代可扩展架构中不可或缺的一部分。与微服务一样,容器已经流行起来,因为它们为开发过程提供了真正的好处:它们可靠,易于扩展,并提供了一个很好的抽象,隔离了 Web 服务的核心组件。


特别是,一种容器化技术已远远超过其他技术。这是正确的,我们的微服务之旅的下一站是看看 Kubernetes 和 Docker,它是现代微服务设施的主力。简单地说,Kubernetes 是现代基于容器的 DevOps 和微服务以及容器携手并进的黄金标准。



随着容器化技术的兴起,有几种竞争技术可用于管理大型 Docker 部署和基于容器的服务。你可能还记得其中一些退役的解决方案:Docker Swarm、Apache Mesos、OpenStack Magnum 等。然而,现在 Kubernetes 已经淘汰了竞争对手。它是唯一的 AWS、Azure、Google Cloud 原生自带,同时 RedHat 和 Pivotal 等许多私有云供应商也提供的容器化解决方案。


Kubernetes 能够如此迅速地获得如此多的优势,根因在于它能够将配置与编排分开。这种复杂程度应该不足为奇,因为 Kubernetes 来自谷歌的内部项目 Borg,它是谷歌在分布式系统上的数十年经验总结。使用 Kubernetes,你可以指定服务的外观、实例数、冗余类型、服务所在位置。然后,该工具自动计算从现状到创建该服务需要进行哪些更改。可以把它想象成 SQL,你没有指定数据库如何添加或转换每个行。你可以指定数据的外观,数据库会指出如何实现数据。Kubernetes 也是一样的。

Kubernetes 的特点

Kubernetes 提供的是将容器视为服务定义的能力。Kubernetes 可以处理纯容器。即使你想在不进入微服务领域的情况下只部署容器,Kubernetes 在管理和部署方面也能为你提供很多帮助。你在集群中的服务器上安装 Kubernetes 软件,Kubernetes 主进程将自动部署你的软件。


除了基本的容器外,Kubernetes 还可以使用它所称的 Pod。Pod 是由一个或多个服务组成的单独定义。Pod 可以包含从单独运行的单个服务器到完整的多容器服务,例如数据库容器与键值存储和一个包含在一起的 http 服务器相结合。Pod 是 Kubernetes 的基本构建块。


最后一个元素是服务。在 Kubernetes 中,服务就像是将 Pod 组合到应用程序中的配方。虽然 Pod 是具有生命周期的具体部署,但服务更抽象。它描述了一个单独的组件,如后端或数据库。


结合所有这些能力的是 Kubernetes 命令行工具 kubectl。虽然 Kubernetes 提供的抽象很棒,但命令行工具非常强大,允许你使用 kubectl 命令描述对架构的复杂更改。总而言之,kubectl CLI 工具包含近 50 种不同的命令,用于处理在修改基于容器的微服务部署过程中出现的所有情况(你总会出现出错的时候)。

动手实践

虽然高层次描述很有帮助,但实际上没有什么比实际部署 Kubernetes 服务能更好的理解它的了。我们在这里没有做任何高深的东西,只是展示如何部署一个简单的“Hello World”服务,但它应该是有益的。


我们在 Go 中编写了一个简单的服务器,用“Hello World”响应 http 请求。代码非常简单:


package main   import (   "fmt"   "log"   "net/http"   "os")func handler(w http.ResponseWriter, r *http.Request) {   log.Print("Hello world received a request.")   version := os.Getenv("VERSION")   if version == "" {      version = "v1"   }   log.Println(version)   fmt.Fprintf(w, "Hello world %s\n",version)}func main() {   log.Print("Hello world sample started.")   http.HandleFunc("/api/hello", handler)   port := os.Getenv("PORT")   if port == "" {   port = "8080"   }   log.Fatal(http.ListenAndServe(fmt.Sprintf(":%s", port), nil))}
复制代码


运行它的第一步是将其构建到 Docker 容器中。为此,我们从基础 Go Docker 镜像开始构建以下 Dockerfile。


# Use the official Golang image to create a build artifact.# https://hub.docker.com/_/golangFROM golang as builder# Copy local code to the container image.WORKDIR /go/src/github.com/haseebh/hello-worldCOPY . .RUN go build -o helloworld-v1 main/helloworld-v1.go# Use a Docker multi-stage build to create a lean production image.# https://docs.docker.com/develop/develop-images/multistage-build/#use-multi-stage-buildsFROM alpineCOPY --from=builder /go/src/github.com/haseebh/hello-world-v1 /helloworld-v1ENV PORT 8080# Run the web service on container startup.CMD ["/helloworld-v1"]
复制代码


现在我们只需要构建它。选择一个镜像 tag,然后运行以下两个 Docker 命令来构建和保存镜像:


# Build the container on your local machinedocker build -t <image-tag> .
# Push the container to docker registrydocker push <image-tag>
复制代码


在我们部署之前还有一步。虽然我们已经定义了将进入我们的 Pod 的内容,但我们还没有定义我们的服务。让我们做一个简单的服务定义,称为 Hello Service。我们将它保存在 hello-service.yml 服务定义文件中。


apiVersion: v1kind: Servicemetadata:   name: helloworld-v1spec:   ports:      - port: 80      protocol: TCP      targetPort: 8080    selector:       app: helloworld-v1    type: LoadBalancer---apiVersion: apps/v1kind: Deploymentmetadata:   name: helloworld-v1   labels:      app: helloworld-v1spec:   replicas: 1   selector:      matchLabels:         app: helloworld-v1   template:      metadata:         labels:            app: helloworld-v1      spec:         containers:            - name: helloworld-kubernetes            # replace <image-tag> with your actual image              image: <image-tag>              ports:                - containerPort: 8080
复制代码


现在我们已经拥有了所需的一切。我们的镜像已经构建,我们已经根据它定义了一项服务。现在我们终于可以使用 Kubernetes 来部署它了。我们将使用 kubectl 命令行工具将其部署在我们的集群上:


kubectl apply -f helloworld-go-v1.yaml
复制代码


要获取服务负载均衡器 IP,请运行以下命令:


kubectl get svc helloworld-v1 -o wide
复制代码


记下外部 IP。


现在,当我们访问负载均衡器地址时,我们可以看到已部署的服务。它并不多,但“Hello World”向我们展示了这一切都奏效了!

关键组件

构建此服务使我们能够演示大多数主要的 Kubernetes 组件。首先,我们布置了 Dockerfile 来为服务创建代码。要在 Kubernetes 中实际创建服务,我们需要使用 YAML 来定义它。我们的定义采用我们定义的镜像并提供一些关键信息:应该部署的位置,版本以及其他配置信息。


之后,我们在 Pod 上部署了该服务。在 Kubernetes 模型中,Pod 与容器密切相关。许多部署(如我们的部署)使用单个 Pod 进行服务。严格来说,Kubernetes 不管理容器,它管理。有时这些容器与 Pod 有一对一的关系,有时候有多个容器关联到一个 Pod。


最后,我们看到了编排的原则。在定义了我们希望如何部署 API 之后,我们只是将配置文件推送到 Kubernetes 并完成其余工作。使用 kubectl,我们能够指定我们想要的架构,Kubernetes 负责其余的工作。当我们稍后查看更复杂的示例时,通过多个版本和复杂的部署,我们将更清楚地看到这个简单想法的强大功能。

深入了解

部署简单的服务只是一个开始。Kubernetes 原生支持微服务,它能用很好的方式来部署基本的,甚至更复杂的微服务架构,而不会有太多的麻烦。但要真正利用微服务的可扩展性,你还需要知道更多。


2020-05-18 18:034653

评论

发布
暂无评论
发现更多内容

“数聚赋能”,让实时数据中台成为惠企、惠民政策服务应用的源头活水

tapdata

数据中台 数字政务 实时数据 智慧政务

Android C++系列:vector最佳实践

轻口味

c++ android 4月月更

一文看懂博睿数据AIOps场景、算法和能力

博睿数据

Tapdata Cloud 2.1.4 来啦:数据连接又上新,PolarDB MySQL、轻流开始接入,可自动标记不支持的字段类型

tapdata

SaaS 云数据库 Real Time DaaS polarDB DaaS

服务器与普通台式机的对比及发展趋势

Finovy Cloud

gpu 云服务器 GPU服务器 GPU算力

多商户商城系统如何对接电商收付通?

CRMEB

「可视化案例Vol.3」数字孪生可视化园区,开启园区智慧管理新篇章

ThingJS数字孪生引擎

物联网 可视化 数字孪生

时序数据库 VS 工业实时数据库

CnosDB

IoT 时序数据库 开源社区 CnosDB infra

没日没夜做需求,就能交出满分答卷吗?

LigaAI

敏捷开发 需求

yarn add electron安装失败

空城机

YARN Electron

【国产】ETL自动化调度运维管理平台 TASKCTL 8.0 分布式部署

敏捷调度TASKCTL

Docker DevOps 国产开源 大数据运维 TASKCTL

高级Java面试经验总结:多家大厂简历优化+面试题目+面经+薪酬等

Java架构追梦

Java 程序员 面试 后端开发

看端点科技如何以行业实践探索企业数字化转型新路径

科技热闻

低代码之火,何以燎原?

BeeWorks

算法交易的最佳编程语言是什么?

非凸科技

rust 编程语言 交易系统 策略

最佳实践 | 运维效率提升10倍的秘诀

星汉未来

DevOps 云原生 智能运维

向着阳光的华为,淬火而行的哪吒

脑极体

全网最细的短网址系统设计与实战

星牛君

MySQL redis 布隆过滤器 Java EE

新品发布 | OpenHarmony面向教育行业的发行版+大赛预告来了~

拓维信息

活动 操作系统 OpenHarmony OpenAtom OpenHarmony OpenHarmony 3.1 Release

TOGAF 10新鲜出炉了!

涛哥 数字产品和业务架构

企业架构 TOGAF

Flutter 网络请求 Dio 拦截器详解

岛上码农

flutter ios 安卓开发 4月月更 跨平台应用

IDC最新报告:澳鹏AI全生命周期数据解决方案在市场上具独特优势

澳鹏Appen

人工智能 大数据 数据标注 训练数据 数据训练

PlatoFarm生态进展不断,通缩推动PLATO价值提升

小哈区块

ImageKnife组件,让小白也能轻松搞定HarmonyOS图片开发

HarmonyOS开发者

HarmonyOS ArKUI 3.0

基于云效AppStack实现环境管理 | 开箱即用

阿里云云效

阿里云 研发管理 研发 应用交付 环境管理

直播回顾:SIMD 指令集在 OpenJDK 中的现状与未来 | 龙蜥技术

OpenAnolis小助手

Java Openjdk simd arm 龙蜥社区

浅谈商业模式---《北大-真格创业课》笔记(30/100)

hackstoic

商业模式 创业公司

观测云新增俄勒冈站点,布局全球可观测服务网络

观测云

首版架构师全栈”成长笔记“一经发布就获得一致好评,我不允许你没看过

Java架构追梦

Java 程序员 java面试 后端开发

2022,「大厂云」还在找新着力点

ToB行业头条

博云首批通过欧拉技术测评,联合解决方案通过验证

BoCloud博云

新闻

如何使用Kubernetes在实践中部署微服务?_文化 & 方法_Rancher_InfoQ精选文章