Encore是一个用于构建分布式系统的开发平台,具有自动化的基础设施
Encore包括从本地开发到云端的端到端工具:
- 开源后端框架(支持TypeScript和Go),允许您直接在应用程序代码中声明式地定义API和基础设施语义。
- 开源本地开发环境,包含追踪、服务目录等多种工具。
- 云平台,可在您自己的AWS和GCP云上自动化DevOps和基础设施配置。
🏁 尝试Encore: 快速入门指南
💻 查看示例应用: 示例应用程序库
🚀 探索使用Encore构建的产品: 展示区
⭐ 为本仓库点星以帮助传播。
👋 有问题吗? 加入Discord上友好的开发者社区。
📞 看看Encore是否适合您的项目: 预约1对1介绍。
🍿 介绍视频
观看介绍视频,快速了解Encore概念和代码示例。
Encore简介
云服务使我们能够构建高度可扩展的应用程序,但往往导致糟糕的开发者体验——迫使开发人员在开发过程中管理大量复杂性,并进行大量重复的手动工作。
Encore专为解决这个问题而设计,为后端开发提供了一套完整的工具集——从本地开发和测试,到云基础设施管理和DevOps。
工作原理
Encore的开源后端框架支持TypeScript和Go,让您可以在应用程序代码中将服务、数据库、定时任务和发布/订阅等资源定义为类型安全的对象。
使用后端框架,您只需定义基础设施语义——即_影响应用程序行为的事物_——而不是_特定_云服务的配置。Encore解析您的应用程序并构建其逻辑架构和基础设施需求的图谱,然后自动生成样板代码并为每个环境编排相关基础设施。这意味着您的应用程序代码可以用于本地运行、在预览环境中测试,以及在AWS和GCP的云环境中配置和部署。
这完全消除了对单独的基础设施配置(如Terraform)的需求,提高了代码库和基础设施的标准化程度,并使您的应用程序默认可在云提供商之间移植。
当您的应用程序部署到云中时,不存在对Encore的运行时依赖,并且云中不运行任何专有代码。
示例:Hello World
定义微服务和API端点非常简单,只需不到10行代码就可以定义一个可生产就绪的可部署服务和API端点。
使用TypeScript后端框架,它看起来是这样的:
import { api } from "encore.dev/api";
export const get = api(
{ expose: true, method: "GET", path: "/hello/:name" },
async ({ name }: { name: string }): Promise<Response> => {
const msg = `Hello ${name}!`;
return { message: msg };
}
);
interface Response {
message: string;
}
使用Go后端框架,它看起来是这样的:
package hello
//encore:api public path=/hello/:name
func World(ctx context.Context, name string) (*Response, error) {
msg := fmt.Sprintf("Hello, %s!", name)
return &Response{Message: msg}, nil
}
type Response struct {
Message string
}
示例:使用发布/订阅
如果您想要一个发布/订阅主题,可以直接在应用程序代码中声明它,Encore将自动为每个环境配置基础设施并生成必要的样板代码:
- 本地开发使用NSQ
- GCP环境使用GCP Pub/Sub
- AWS环境使用SNS/SQS
使用TypeScript后端框架,它看起来是这样的:
import { Topic } "encore.dev/pubsub"
export interface SignupEvent {
userID: string;
}
export const signups = new Topic<SignupEvent>("signups", {
deliveryGuarantee: "at-least-once",
});
使用Go后端框架,它看起来是这样的:
import "encore.dev/pubsub"
type User struct { /* 字段... */ }
var Signup = pubsub.NewTopic[*User]("signup", pubsub.TopicConfig{
DeliveryGuarantee: pubsub.AtLeastOnce,
})
// 通过调用方法发布消息
Signup.Publish(ctx, &User{...})
在文档中了解更多
查看如何在文档中使用后端框架:
- 服务和API: Go / TypeScript
- 数据库: Go / TypeScript
- 定时任务: Go / TypeScript
- 发布/订阅: Go / TypeScript
- 缓存: Go / TypeScript(即将推出)
使用Encore:从本地到云端的端到端工作流程
Encore为开发过程的每个步骤提供专门的工具,从本地开发和测试到云端DevOps。这里我们将介绍流程各部分的主要功能。
本地开发
当您使用Encore CLI在本地运行应用程序时,Encore会解析您的代码并自动设置必要的本地基础设施。不再需要折腾Docker Compose!
您还可以获得内置工具,用于创建分布式系统和事件驱动应用程序时的高效工作流程:
- 本地环境与云环境匹配: Encore自动处理服务通信的语义和与不同类型基础设施服务的接口,使本地环境成为云环境的1:1表示。
- 跨服务类型安全: 使用Encore构建微服务应用时,在进行跨服务API调用时,您可以在IDE中获得类型安全和自动完成功能。
- 类型感知基础设施: 使用Encore,像Pub/Sub队列这样的基础设施在您的程序中是类型感知的对象。这在构建事件驱动应用时实现了端到端的类型安全。
- 密钥管理: 为所有环境内置密钥管理。
- 追踪: 本地开发仪表板提供本地追踪功能,帮助理解应用行为并发现错误。
- 自动生成API文档和客户端: Encore生成Go、TypeScript、JavaScript和OpenAPI规范的API文档和API客户端。
以下是展示本地开发仪表板的视频:
https://github.com/encoredev/encore/assets/78424526/4d066c76-9e6c-4c0e-b4c7-6b2ba6161dc8
测试
Encore提供了几个内置工具来帮助测试:
- 内置服务/API模拟: Encore提供内置支持模拟API调用,以及自动为您的服务生成模拟对象的接口。
- 本地测试基础设施: 在本地运行测试时,Encore自动提供专用测试基础设施以隔离单个测试。
- 本地测试追踪: 本地开发仪表板为测试提供分布式追踪,提供良好的可见性,便于了解发生的情况并更容易理解测试失败的原因。
- 预览环境: Encore自动为每个Pull Request配置预览环境,这是进行端到端测试时的有效工具。
DevOps
使用Encore,您可以将工程精力集中在产品上,避免花时间构建开发者平台。
Encore提供的一个核心功能是在您的云中自动配置基础设施。由于您的应用代码是应用基础设施需求的真实来源,因此无需编写Terraform、YAML或在云控制台中点击,您只需连接您的云账户并部署。这种方法还允许您随时更换基础设施,无需进行代码更改或手动更新基础设施配置文件。
部署时,Encore自动使用AWS和GCP上经过实战检验的云服务配置基础设施,例如:
- 计算: GCP Cloud Run、AWS Fargate、Kubernetes(GKE和EKS)
- 数据库: GCP Cloud SQL、AWS RDS
- 发布/订阅: GCP Pub/Sub、AWS SQS/SNS
- 缓存: GCP Memorystore、Amazon ElastiCache
- 密钥: GCP Secret Manager、AWS Secrets Manager
- 等等。
Encore还提供内置的DevOps工具,帮助自动化90%以上的日常DevOps工作:
- 自动最小权限IAM: Encore解析您的应用代码并设置最小权限IAM以匹配应用的需求。
- 基础设施跟踪和审批工作流: Encore跟踪所有它配置的基础设施,并在部署过程中提供审批工作流,以便管理员可以验证和批准所有基础设施变更。
- 云配置双向同步: Encore提供简单的UI进行配置更改,还支持同步您在AWS/GCP云控制台中进行的更改。
- 成本分析: 提供简单的概览,用于监控Encore在您的云中配置的所有基础设施的成本。
- 日志和指标: Encore自动提供日志记录、指标,并集成第三方工具,如Datadog和Grafana。
- 服务目录: Encore自动生成包含完整API文档的服务目录。
- 架构图: 为帮助入职和协作,Encore为您的应用生成架构图,包括基础设施依赖关系。
- 通过Encore的Terraform Provider扩展: 使用您需要的任何基础设施服务扩展您的系统,集成很简单,因为所有基础设施都在您的云中配置。Encore还有一个Terraform Provider来简化这个过程。
以下是展示云平台仪表板的视频:
https://github.com/encoredev/encore/assets/78424526/8116b387-d4d4-4e54-8768-3686ba0245f5
为什么使用Encore?
- 更快的开发: Encore通过其后端框架、清晰的抽象和内置开发工具简化了开发过程,使您能够更快地构建和部署应用。
- 降低成本: Encore的自动基础设施管理最小化了不必要的云开支,减少了DevOps工作量,让您的工作更加高效。
- 可扩展性和性能: Encore简化了构建大规模微服务应用的过程,可以应对不断增长的用户群和需求,而无需通常的样板代码和复杂性。
- 控制和标准化: 内置工具如自动生成的架构图、基础设施跟踪和审批工作流,使团队和领导者能轻松获得整个应用的概览。
- 安全性和合规性: Encore通过强制执行安全标准并根据每个云提供商的最佳实践配置基础设施,帮助确保您的应用安全且合规。
常见用例
Encore旨在为团队在解决大多数后端用例时提供高效且简单的体验。许多团队使用Encore构建以下内容:
- 高性能B2B平台
- 金融科技和消费者应用
- 全球电子商务市场
- SaaS应用和移动应用的微服务后端
- 等等...
入门
- 1. 使用快速入门指南安装Encore
- 2. 跟随教程构建更大的应用
- 3. 在GitHub上关注并标星项目以保持更新
- 4. 探索文档以了解更多Encore的功能
- 5. 预约1对1咨询或加入Discord讨论您的用例或如何开始采用Encore
开源
开发和部署Encore应用所需的一切都是开源的,包括后端框架、解析器、编译器、运行时和CLI。 这包括本地开发所需的所有代码以及在您的云中运行的所有内容。
开源CLI还提供了为您的应用生成独立Docker镜像的机制,因此您可以轻松自托管您的应用。在文档中了解更多。
加入最具开创性的开发者社区
使用Encore构建的开发者是想要专注于创意编程并构建优秀软件以解决有意义问题的前瞻性思考者。这是一个友好的地方,非常适合交流想法和学习新事物!加入Discord上的对话。
我们依靠您的贡献和反馈来为所有使用Encore的人改进它。 以下是您可以贡献的方式:
- ⭐ 给这个仓库点星并关注,以帮助传播信息并保持更新。
- 在Discord上与其他Encore开发者见面并聊天。
- 在Twitter上关注Encore。
- 通过电子邮件分享反馈或提问。
- 在公共路线图上留下反馈。
- 在GitHub上发送包含您贡献的拉取请求。
视频
视觉效果
代码示例(Go)
https://github.com/encoredev/encore/assets/78424526/f511b3fe-751f-4bb8-a1da-6c9e0765ac08
本地开发仪表板
https://github.com/encoredev/encore/assets/78424526/4c659fb8-e9ec-4f14-820b-c2b8d35e5359
生成的架构图和服务目录
https://github.com/encoredev/encore/assets/78424526/a880ed2d-e9a6-4add-b5a8-a4b44b97587b
自动配置基础设施和多云部署
https://github.com/encoredev/encore/assets/78424526/8116b387-d4d4-4e54-8768-3686ba0245f5
分布式追踪和指标
https://github.com/encoredev/encore/assets/78424526/35189335-e3d7-4046-bab0-1af0f00d2504
常见问题(FAQ)
Encore背后是谁?
Encore由来自Spotify、Google和Monzo的长期后端工程师创立,他们拥有超过50年的集体经验。我们经历过构建具有数千个服务的复杂分布式系统,并扩展到数亿用户的挑战。
Encore源于这些经验,是解决随之而来的挫折的解决方案:不必要的令人瘫痪的复杂性和不断重复的无差别工作扼杀了开发者的创造力。通过Encore,我们希望让开发者释放他们的创造潜力。
Encore适合谁?
对于构建云服务的个人开发者来说,Encore提供了一种彻底改善的体验。使用Encore,您能够保持在心流状态,体验构建的快乐和创造力。
对于需要构建可扩展后端以支持产品增长的创业团队来说,Encore让他们能够在几分钟内在云中启动并运行。它让他们能够专注于解决用户的需求,而不是花费大部分时间重新解决在云中构建分布式系统的日常挑战。
对于大型组织中想要专注于创新和构建新功能的个别团队来说,Encore让他们停止花费时间在运营和新团队成员入职上。使用Encore进行新功能开发很容易,只需几分钟就可以启动一个新的后端服务。
Encore有何不同?
Encore是唯一理解您正在构建内容的工具。Encore使用静态分析深入理解您正在构建的应用程序。这实现了一种独特的开发者体验,帮助您在构建过程中保持心流。例如,您不需要费心配置和管理基础设施、设置环境并保持同步,或编写文档和起草架构图。Encore默认自动完成所有这些工作。
与许多旨在仅使云部署更容易的工具不同,Encore不是云托管提供商。使用Encore,您可以使用AWS和GCP的云账户。这意味着您可以控制您的数据,并可以维护与云提供商的信任关系。您还可以免费使用Encore的开发云,并享有相当慷慨的"公平使用"限制。
为什么Encore提供与云平台的集成?
我们发现,要显著改善开发者体验,您必须在整个堆栈中操作。除非您了解应用程序的部署方式,否则开发过程中有很多事情无法简化。这就是为什么许多其他开发者工具影响有限的原因。通过Encore更集成的方法,我们能够为开发者实现根本性的更好体验。
如果我想从Encore迁移出去怎么办?
Encore的设计允许您在需要时超出后端框架的范围,并在需要时轻松降低抽象级别,因此您永远不会遇到任何死胡同。
如果您想迁移出去,这是直接的,不需要大规模重写。99%的代码是普通的Go或TypeScript,特定于Encore的代码仅限于使用后端框架。
Encore支持自托管您的应用程序,通过使用开源CLI生成可以部署在任何地方的独立Docker镜像。
我们认为采用Encore是一个低风险的决定,因为它不需要对基础工作进行初始投资。我们的目标只是从第一天起就为您的日常开发过程增加大量价值。
为Encore贡献和从源代码构建
请参阅CONTRIBUTING.md。