阿里云「飞天发布时刻」2024来啦!新产品、新特性、新能力、新方案,等你来探~ 了解详情
写点什么

怎样为 k8s 找到最合适的 PaaS 解决方案?

  • 2020-05-01
  • 本文字数:3018 字

    阅读完需:约 10 分钟

怎样为k8s找到最合适的PaaS解决方案?

本文最初发布于 Bram Dingelstad 的个人博客,经原作者授权由 InfoQ 中文站翻译并分享。


我们可能遇到过这样的情况。团队中有人发现一个 bug,这个 bug 很特殊,与你经常遇到的软件 bug 不同。这不是一个普通的 bug,而是非常个人化的 bug:hype-driven developer。


它发端于小的事情,然后试图将团队推向一个新技术方向或项目中的一个小模块。在了解它之前,你已埋头于某个奇怪项目的高级文档中。这些文档仅用 3 个简单的步骤就解决了你的业务案例。然而,当你试图找到一种方法去做那些琐碎的事情时,却似乎需要更多的步骤。


我们都有这样的时刻:在过去一年,一个名为 Kubernetes 的项目成为许多人的关注焦点之一。有些公司发现其有着巨大作用,还有些公司还没有发现其价值,并在这个过程中将自己搞得“遍体鳞伤”。


而我正处于中间位置。我正在做类似事情,并且做好了踩坑准备。在此之前,先让我们看看如何在 k8s 上部署一个简单的、类似于 PaaS 的平台。

找到一个完美的类 PaaS 平台

那么,我们从哪里开始?肯定有一种简单方法能找到这样的东西,也许,我们从简单的 DuckDuckGo 搜索开始。



DuckDuckGo 搜索没啥用


显然,k8s 不是 PaaS。我想基于 k8s 构建一个 PaaS,当然不是把它当作一个 PaaS 来使用。


然后,我们在 HackerNews 上搜索一下。第一个查询找到一篇失效文章。此外,我在 GitHub 上偶然发现一个很棒的列表。在进行更广泛的搜索后,我针对自己的应用场景列出一个可能的候选项目列表。



还有很多其他选择,我尝试过其中一些,还有一些是针对大企业的。

我的应用场景

Quest Vault,我们在 DigitalOcean droplet 上安装一个简单的 Wordpress 来运行我们的电商网站。尽管能通过运行一些简单的 bash 脚本实现部署,并在本地运行测试/过渡服务器的副本,但是,我想构建一个基于行业技术的平台,而不是一些 bash 脚本。编写这些 bash 脚本很有趣,并且拥有自己的部署技术栈也很简单,但是,我希望 Quest Vault 能拥有一个“豪华些”的东西,一个标准的、让我们不必为使用的工具操心的东西。

一些必要条件

现在,我想在办公室运行k3s的 garbage server 上测试这些项目。K3s 有一个到 DigitalOcean droplet 的反向代理,而不是在互联网上访问。这意味着项目应该支持内部部署


我还希望能完全抽象出 k8s。这意味着我不想处理太多的 yaml 或者一直部署 helm charts,我想多考虑下应用程序,并且通过 CLI 就可以做到。


简而言之:我想要的是,只要按一个按钮,它就工作


我们的应用程序有很多活动组件,有些只是简单脚本,有些则是为游戏客户端提供通信的大型应用程序。不管是什么,我们的平台需要支持大量不同的应用程序类型。这通常意味着支持通过 Dockerfile 进行部署


我们计划运行的大多数应用程序都与状态密切相关。以 Wordpress 为例,我们需要一个存储图片的地方。我们还有很多需要存储的应用内照片拍摄。我们需要一种方法使我们的应用程序具有某种形式的持久化


我喜欢的项目很多,但是一个好项目和一个伟大项目的区别在于社区和行业的采用。拥有自己的 bash 脚本和在 GitHub 上有 3 个活动用户的项目几乎没有区别。如果你搞砸了,或者无论出于什么原因需要一些建议,你都希望能从一个活跃的社区获得帮助

项目清单速览

Knative

我的 Knative 经验有一个不错的开头!当读过关于它的文章后,我很高兴地得知:我能运行一个平台,谷歌在其平台内部就把它用于他们自己的类似 PaaS 的部署。考虑到谷歌创造了 k8s,这一定非常合适!它的安装过程比预期困难得多。


似乎没有什么简单方法来安装这个平台,而且,无法轻松地使用一个平台会是将来的一个风险。

OpenFaaS Cloud

安装非常简单!我很快就让这个平台运行了起来。它满足我的大多数需求,不过,它似乎更像是实现 OpenFaas 的一种有趣方式,而不是完全成熟的 PaaS 可选方案。我不知道如何将我们的用例放到这个特别的平台上。如果你正在搭配使用耦合度比较低的项目或比较小的功能,这是一个很好的选择!

Convox

Convox 看起来很棒!几名前 Heroku 工程师,在 k8s 上构建的一个平台。似乎完美!我想尝试一下,马上就开始在 DigitalOcean k8s 集群上部署它。开发体验非常棒!


然而,他们似乎并不支持平台的内部部署版本。此外,除一些早期采用者外,这个项目似乎没有一个非常大的社区。相比而言,这个项目不是很出名,最终我放弃它,去寻找另一种选择。

Garden

这是一个非常酷的项目。我喜欢它,一家小型的独立公司开发的一个创新型解决方案。安装起来很简单,而且他们的方法对 k8s 做了很好的抽象,但是他们也允许你通过经典的 k8s 方式来保持某种形式的控制,比如 yaml 文件。我真的很愿意用它,效果很好!


然而,我确实注意到,它的一些 CLI 还不是很完善,但是,我认为这只是些小瑕疵,并不能代表最终产品。

Rio

这个项目符合所有条件。一个真正容易使用的 CLI?是的。不再以任何方式与 k8s 交互?是的。使用 Dockerfile 进行部署?是的!它们还提供了大量其他平台没有实现或实现得很差的特性。来自 Rancher 的 Rio 似乎从他们活跃的社区得到了大量支持。

在 garbage server 上进行安装设置

我快速地为 k3s 实例设置好反向代理,并开始设置 Rio。


参照他们 GitHub 页面上的快速入门指南,这个过程变得超级简单:


# Setting up the reverse proxy to k3sssh -nNTL 6443:localhost:6443 droplet &
# Installing Riocurl -sfL https://get.rio.io | sh -
# Running the example projectrio run https://github.com/rancher/rio-demo
复制代码


这样就行。我超级激动,希望马上看一下,现有的基础设施能否同样轻松地迁移。


Rio 的默认安装允许你使用他们的 rDNS 服务on-rio.io,这个服务很酷,但不需要把我的 garbage server 放在反向代理后面。我还没有使用 Linkerd 的经验,所以现在只是禁用它。使用命令rio install --disable-feature rdns,letsencrypt,linkerd重新安装后,我获得了想要的结果。


接下来,通过 kubectl 安装自定义的ClusterDomain,这让我能使用on-rio.io之外的另一个域。最后,我安装了dnsmasq,并创建了一个名为app.rio的假域名,我的应用程序会在这个域名上解析。这将让我能轻松地在 garbage server 上测试到应用程序的连接。


apiVersion: admin.rio.cattle.io/v1kind: ClusterDomainmetadata:  name: app.riospec:  httpPort: 80
复制代码


我还得想办法从 DigitalOcean droplet 连接到这个集群。我从 garbage server 上的80端口反向代理到8080端口上的 droplet。Rio 使用 80 端口安装了 Gloo 的gateway-proxy


最后一步,我设置了 nginx 配置,使其指向 Gloo 网关:


server {    listen 80;    server_name your.domain.name;    location / {        proxy_http_version 1.1;        proxy_set_header Host $host;        proxy_pass http://localhost:8080;    }}
复制代码


这有两件重要的地方需要注意,分别是proxy_http_version 1.1proxy_set_header Host


proxy_http_version非常重要,因为基于 Envoy 的 Gloo 不支持 http_version 1.0 上的网关,而只支持 1.1 上的网关。否则,它会返回一个426 Upgrade Required错误。


Host头对于实现PublicDomain非常重要。需要注意的是,要添加一个PublicDomain,它必须与server_name或被代理的Host 头匹配,否则 Gloo 无法识别我要访问的是哪个服务。


rio domain register your.domain.name rio-demo
复制代码


这就是我寻找最合适的 Kubernetes PaaS 解决方案的冒险。


英文原文:


Finding the right PaaS for k8s


2020-05-01 07:0018505
用户头像

发布了 689 篇内容, 共 398.7 次阅读, 收获喜欢 1498 次。

关注

评论 1 条评论

发布
用户头像
感觉翻译得不怎么好,我还是去读原文吧,感谢分享
2020-05-05 22:55
回复
没有更多了
发现更多内容

电影台词反向搜索视频片段,这个工具也太好用了吧|33 台词

彭宏豪95

效率 效率工具 电影

2021阿里总监最新手码BAT等大厂面经!GitHub已标星86.2K

比伯

Java 编程 架构 面试 程序人生

话题讨论 | mongodb拥有十大核心优势,为何国内知名度不是很高?

杨亚洲(专注MongoDB及高性能中间件)

MySQL 数据库 mongodb 话题讨论 分布式数据库mongodb

电力行业区块链技术应用和产业布局

CECBC

区块链

为什么不推荐使用汉字作为密码?

不脱发的程序猿

程序人生 密码学 28天写作 二月春节不断更

JVM又曾放过谁,垃圾终将被回收!

Simon郎

Java 大数据 架构 后端 JVM

浅谈nodejs进程和线程

梁龙先森

大前端 nodejs 2月春节不断更

阿里巴巴云原生应用安全防护实践与 OpenKruise 的新领域

阿里巴巴云原生

容器 运维 云原生 k8s 调度

为图片添加Emoji,微信这隐藏功能让你不花冤枉钱

彭宏豪95

微信 效率 效率工具 emoji

话题讨论 | 比特币攻击重现江湖,你准备好了吗?

程序员架构进阶

话题讨论 28天写作 2月春节不断更 话题王者 勒索攻击

窝家恶补三月,字节跳动三面,终于喜提offer!分享面试感受

Java架构之路

Java 程序员 架构 面试 编程语言

算力蜂系统开发|算力蜂软件APP开发

系统开发

话题讨论 | 现实中程序员是怎样飞快敲代码的?

xcbeyond

程序人生 话题讨论

架构设计篇之微服务实战笔记(三)

小诚信驿站

架构师 刘晓成 小诚信驿站 28天写作 架构师成长笔记

有赞 Flink 实时任务资源优化探索与实践

Apache Flink

flink

Laravel来信|Event

LeastCoding

laravel Event 观察者模式

什么!?金三银四,2021年阿里最新面试题惨遭泄露?

Java架构之路

Java 程序员 架构 面试 编程语言

还愁追不到女神吗?一键生成舔狗日记,一秒速成舔狗之王

不脱发的程序猿

程序人生 28天写作 二月春节不断更 舔狗文化

用Stylish精简极客时间专栏页面

Tao

CSS

人人矿场APP开发|人人矿场系统软件开发

系统开发

颠覆技术-智能合约的说明文

CECBC

区块链

流媒体传输协议之 RTMP

阿里云视频云

TCP 音视频 RTMP 传输协议 流媒体;

GitHub上已获赞百万!阿里架构师10年磨一剑打造的Java面试小抄(2021版)开源分享

Java架构师迁哥

使用doom-emacs三个月后, 春节期间从零配置一份自己的emacs(附详细文档)

lmymirror

2021最新百度/平安/蚂蚁金服/腾讯/拼多多面经总结(附答案解析)

比伯

Java 编程 架构 面试 计算机

Java岗四面字节跳动成功之前,我都刷了那些面试题以及做了那些准备!

Java架构之路

Java 程序员 架构 面试 编程语言

架构师不至于“架构”-《架构师应该知道的37件事》阅读笔记

Harris

读书笔记 架构 架构师

泰山版震撼来袭!阿里巴巴2021年Java程序员面试指导小册已开源

Java架构追梦

Java 架构 面试 金三银四 跳槽

一文读懂区块链产业最新发展趋势

CECBC

大数据

话题讨论 | 程序员是做前端开发好,还是后端开发好呢?

xcbeyond

程序人生 话题讨论

微信十年,弹指一挥间

彭宏豪95

微信 产品 互联网 写作

怎样为k8s找到最合适的PaaS解决方案?_文化 & 方法_Bram Dingelstad_InfoQ精选文章