Porter: 一个由 Kubernetes 驱动的 PaaS 系统(Heroku 开源平替版)

公众号关注 「奇妙的 Linux 世界」

设为「星标」,每天带你玩转 Linux !

7b03e43c3c19129f4c594856cebce92e.png

Porter 是一个由 Kubernetes 驱动的 PaaS 系统,可以在你自己的云供应商中运行。Porter 尝试将 Heroku 的使用经验带到你自己的 AWS/GCP 账户中,同时将你的基础设施升级为 Kubernetes。

概述

像 Heroku 这样的传统 PaaS 非常适合最大限度地减少不必要的 DevOps 工作,但随着应用程序的增长,它并不能提供足够的灵活性。自定义网络规则、资源限制和成本是开发人员将其应用程序从 Heroku 迁出的常见原因。

Porter 为你自己的云提供商带来了传统 PaaS 的简单性,同时保留了 Kubernetes 的可配置性。Porter 建立在流行的 Kubernetes 包管理器 helm 之上,并与 kubectl 等标准 Kubernetes 管理工具兼容,从一开始就为成熟的 DevOps 工作做好了准备。只需要点击几下即可将应用程序部署到你的云提供商中,Porter 将为你配置和管理底层基础架构 - 只需指向你的存储库,Porter 将处理其余的工作,从构建你的应用程序到自动扩展它。

9182a3aa8c7fef3e981333e5be96b4ee.png

在底层,Porter 运行在 Kubernetes 之上。Porter 配置和管理每个云提供商的原生 Kubernetes 产品(AWS 上的 EKS、GCP 上的 GKE 和 Digital Ocean Kubernetes),同时抽象出所有的复杂性。

可能你会觉得 Porter 在 Kubernetes 之上运行太过复杂,对于不了解 Kubernetes 的团队来说,Kubernetes 会有一定的门槛。除了一些基本概念之外,你不需要了解任何关于 Kubernetes 的知识即可使用 Porter。Kubernetes 恰好是提供 PaaS 体验的最佳底层。事实上,大多数 PaaS 实际上都是在 Kubernetes 之上运行的,尽管这些细节对最终用户来说是隐藏的。如果你的团队已经熟悉 Kubernetes,Porter 可以成为简化你现有操作的内部部署平台。

特性

  • 可以在自己的云控制台中一键开通 Kubernetes 集群:AWS、GCP、Digital Ocean

  • 简单部署任何公共或私有的 Docker 镜像

  • 为非容器化应用使用 buildpacks 进行 CI/CD

  • 类似于 Heroku 的操作界面,用于监控应用程序状态、日志和历史记录

  • 应用程序可以方便回滚到以前部署的版本

  • 零宕机部署和健康检查

  • 监控每次部署的 CPU、内存和网络使用情况

  • 一键式插件市场(例如 MongoDB、Redis、PostgreSQL)

7962ccb1aacf9f6cc6da1a290ef95038.png

对于熟悉 Kubernetes 和 Helm 的用户:

  • 可以将现有 Kubernetes 集群直接连接到 Porter 使用

  • 通过界面可视化、部署和配置 Helm Charts

  • 深入了解版本,包括修订历史和组件图

  • 回滚/更新现有版本,包括编辑原始 values.yaml 文件

e431df6ae449dd1a08e23350495b57e1.png

使用

最简单的方式就是直接使用 Porter 提供的在线云服务 https://dashboard.getporter.dev/,直接登录注册。然后创建一个项目并配置你的云服务商的相关凭证,Porter 会在你的云服务中自动配置 Kubernetes 集群。

如果你没有云服务商也可以连接现有的 Kubernetes 集群,下载 Porter CLI 工具,然后将你现有 Kubernetes 集群的 kubeconfig 连接到 Porter 即可:

2bf57422e548defbd3c2042f7139b84c.png

配置上 Kubernetes 集群后就可以选择部署服务,支持 Web 服务、Worker 与 Job 任务:

0b1bc76cb910db2dc94d201e07a95e1b.png

比如选择一个 Web 服务,如果你连接了 GitHub,那么可以选择部署一个仓库,也可以直接指定一个 Docker 镜像地址:

44fa3b2b863b069430601be55c053636.png

如果你使用的 Porter 的云服务,部署完成后会为你的应用自动添加一个二级域名,通过该地址即可访问到部署的服务:

194b62e3c53cd12057d234869887200e.png

如果你的集群中安装了 Prometheus,还可以对应用进行监控:

d2110db463cd99546cf50a70af6557ff.png

而且还可以配置自动扩缩容:

e6ce3340679d3cae88e15ff6fbf553c7.png

如果你需要本地进行开发测试,可以直接 Clone 仓库代码:

git clone https://github.com/porter-dev/porter

然后执行 make start-dev 命令即可在本地启动服务,不过需要在 docker/.env文件中添加下如下两个环境变量,否则本地启动后无法正常使用:

WELCOME_FORM_WEBHOOK=https://www.qikqiak.com
DISABLE_ALLOWLIST=true

关于 Porter 的更多信息可以查看官方文档 https://docs.porter.run 了解更多信息。

仓库地址:https://github.com/porter-dev/porter

本文转载自:「Github爱好者」,原文:https://tinyurl.com/7b5x5wxm,版权归原作者所有。欢迎投稿,投稿邮箱: editor@hi-linux.com。

f21362d636baaacb29e0edf21688d217.gif

最近,我们建立了一个技术交流微信群。目前群里已加入了不少行业内的大神,有兴趣的同学可以加入和我们一起交流技术,在 「奇妙的 Linux 世界」 公众号直接回复 「加群」 邀请你入群。

17b12713cdd1c521b70956b2c5b5a58f.png

你可能还喜欢

点击下方图片即可阅读

77ceea417d0c3ea240369ff4ef89ccf9.png

Kubernetes 开源负载均衡器 OpenELB 使用指南

1798c88cd4fbf52446bc21276b051e21.png
点击上方图片,『美团|饿了么』外卖红包天天免费领

d1e654eb3f6717ae1c1662033040c438.png

更多有趣的互联网新鲜事,关注「奇妙的互联网」视频号全了解!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值