将Stratos(一个多集群UI)添加到Backstage开发者门户框架的实践指南
译自Backstage Multicluster UI for Cloud Foundry and Kubernetes,作者 Sylvain Kalache。
开源项目且CNCF孵化项目Backstage已成为许多公司平台工程工具包的核心部分。这是有充分理由的。该框架专为构建开发者门户而设计,通过其应用商店提供大量的插件目录,并易于创建您自己的插件。
在本文中,我将展示如何将Stratos——一个支持Cloud Foundry、Kubernetes、EKS、AKS、GKE等的开源多集群UI——集成到Backstage中。虽然该项目已经存在7年了,但由于多云增长和平台工程需要将基础设施的每个部分整合在一个屋檐下,它最近受到了广泛关注。
Backstage自建插件
虽然Backstage社区已经拥有超过200个插件,但该工具的优势还在于它提供了一种简单的方法,可以通过您自己的插件来构建和集成任何基础设施或软件开发工具。虽然有很多Backstage插件,但它们可以分为两大类:前端插件在Backstage应用程序上显示UI,后端插件管理服务器端操作。您可以通过在Backstage应用程序文件夹中键入yarn new
来查看Backstage提供的所有不同的插件模板。
创建我们的Backstage插件
首先,您需要安装Backstage应用程序(请按照此处的安装说明进行操作)。使用yarn start
和yarn start-backend
命令启动您的应用程序前端和后端。接下来,您将通过在Backstage项目的根目录下键入以下命令来创建前端插件:
系统将提示您输入插件ID。它可以是任何字符串。在我的例子中,我将它命名为stratos
。
? Enter the ID of the plugin [required] stratos Creating frontend plugin @internal/backstage-plugin-stratos Checking Prerequisites: availability plugins/stratos ✔ creating temp dir ✔ Executing Template: templating .eslintrc.js.hbs ✔ [...] 🎉 Successfully created plugin
您可以通过调用curl -I http://localhost:3000/stratos/
或将URL粘贴到浏览器中来检查您的插件是否运行良好。每个Backstage插件都被视为一个独立的Web应用程序,这使其非常强大,但也存在学习曲线。为简单起见,我将使用Backstage提供的现有示例模板来构建我的插件。如果您将其用于生产环境,则此处是正确构建插件的文档。
我们将编辑现有的Stratos组件文件以集成我们的iframe以嵌入Stratos界面。为此,我们将编辑文件plugins/stratos/src/components/ExampleComponent/ExampleComponent.tsx
并在其中粘贴以下内容。
importReactfrom'react';import{Typography,Grid}from'@material-ui/core';import{Header,Page,Content,}from'@backstage/core-components';import{ExampleFetchComponent}from'../ExampleFetchComponent';exportconstExampleComponent=()=>(<PagethemeId="tool"><Headertitle="Backstage + Stratos = ❤️"/><Content><iframesrc="http://localhost:8080/"width="100%"height="100%"style={{border: 0}}/></Content></Page>);
我不会详细介绍配置文件,但需要注意的是,我们使用lay-src="http://localhost:8080/"
提供iframe服务,这会将Stratos界面显示到Backstage中。 我们与Backstage的工作完成了;现在,让我们开始使用Stratos。
部署Stratos
有三种方法可以部署Stratos:Cloud Foundry、Kubernetes或Docker。我将使用Docker方式,您可以通过运行以下命令来启动Stratos:docker run -p 5443:5443 splatform/stratos:stable
。
根据您部署和配置Stratos的方式,您可能能够直接将其提供到Backstage iframe中。在我们的例子中,Docker容器中的证书已过期,并且没有简单的解决方法;我们需要在Stratos前面放置一个代理。Backstage提供了一个内置的代理可以完成这项工作,但是根据您部署Stratos的方式,您可能无法获得有效的解决方案。我不会在本文中详细介绍,但在这段视频中,我演示了如何使用Backstage代理流量,并介绍了您可能面临的挑战。
我们将使用Nginx进行代理,以创建一个易于构建的解决方案。以下是我们Nginx配置所需的内容:
server { listen8080 default_server; listen [::]:8080 default_server; location/ { proxy_pass https://localhost:5443/; proxy_set_header Host $host; proxy_hide_header X-Frame-Options; } location ~* \.(js|css|png|jpg|jpeg|svg|woff|woff2|ico)$ { proxy_pass https://localhost:5443; proxy_set_header Host $host; proxy_hide_header X-Frame-Options; } }
此Nginx配置文件分为两个主要部分:第一部分用于服务动态内容和静态资源。如前所述,代理使我能够通过iframe提供Stratos服务;以下是一些要点:
listen 8080 default_server;
— Stratos 通过HTTPS提供服务,并且当使用当前Docker镜像时,它没有有效的SSL证书,这对iframe来说是个问题。我使用Nginx通过HTTP提供流量来解决这个问题。proxy_hide_header X-Frame-Options;
— Stratos在其响应头中包含同源策略,阻止浏览器在iframe中显示页面。此Nginx指令删除包含该安全策略的头。
启动Nginx,刷新插件页面后,您应该会看到以下内容。
将Stratos集成到Backstage中,可以提供多集群Cloud Foundry和Kubernetes环境的简化、集中视图,从而简化基础设施管理。Stratos被Comcast和TwentyFive等知名最终用户使用。虽然此设置旨在用于演示——而不是生产——但它突出了Backstage强大的插件生态系统如何为可扩展和协作的平台工程奠定基础。