[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-4718":3},{"id":4,"name":5,"fullName":6,"owner":5,"repo":5,"description":7,"homepage":8,"htmlUrl":9,"language":10,"languages":9,"totalLinesOfCode":9,"stars":11,"forks":12,"watchers":13,"openIssues":14,"contributorsCount":15,"subscribersCount":15,"size":15,"stars1d":16,"stars7d":17,"stars30d":18,"stars90d":15,"forks30d":15,"starsTrendScore":19,"compositeScore":20,"rankGlobal":9,"rankLanguage":9,"license":21,"archived":22,"fork":22,"defaultBranch":23,"hasWiki":22,"hasPages":22,"topics":24,"createdAt":9,"pushedAt":9,"updatedAt":43,"readmeContent":44,"aiSummary":45,"trendingCount":15,"starSnapshotCount":15,"syncStatus":46,"lastSyncTime":47,"discoverSource":48},4718,"pulumi","pulumi\u002Fpulumi","Pulumi - Infrastructure as Code in any programming language 🚀","https:\u002F\u002Fwww.pulumi.com",null,"Go",25294,1384,191,2248,0,4,34,136,22,104.42,"Apache License 2.0",false,"master",[25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42],"aws","azure","cloud","cloud-computing","containers","csharp","dotnet","fsharp","gcp","go","golang","iac","infrastructure-as-code","javascript","kubernetes","python","serverless","typescript","2026-06-12 04:00:22","\u003Cp align=\"center\">\n    \u003Ca href=\"https:\u002F\u002Fwww.pulumi.com\u002F?utm_source=github.com&utm_medium=referral&utm_campaign=pulumi-pulumi-github-repo&utm_content=top+logo\" title=\"Pulumi - Modern Infrastructure as Code - AWS Azure Kubernetes Containers Serverless\">\n        \u003Cimg src=\"https:\u002F\u002Fwww.pulumi.com\u002Fimages\u002Flogo\u002Flogo-on-white-box.svg?\" width=\"350\">\n    \u003C\u002Fa>\n\u003C\u002Fp>\n\n[![Slack](http:\u002F\u002Fwww.pulumi.com\u002Fimages\u002Fdocs\u002Fbadges\u002Fslack.svg)](https:\u002F\u002Fslack.pulumi.com\u002F)\n[![GitHub Discussions](https:\u002F\u002Fimg.shields.io\u002Fgithub\u002Fdiscussions\u002Fpulumi\u002Fpulumi)](https:\u002F\u002Fgithub.com\u002Fpulumi\u002Fpulumi\u002Fdiscussions)\n[![NPM version](https:\u002F\u002Fbadge.fury.io\u002Fjs\u002F%40pulumi%2Fpulumi.svg)](https:\u002F\u002Fnpmjs.com\u002Fpackage\u002F@pulumi\u002Fpulumi)\n[![Python version](https:\u002F\u002Fbadge.fury.io\u002Fpy\u002Fpulumi.svg)](https:\u002F\u002Fpypi.org\u002Fproject\u002Fpulumi)\n[![NuGet version](https:\u002F\u002Fbadge.fury.io\u002Fnu\u002Fpulumi.svg)](https:\u002F\u002Fbadge.fury.io\u002Fnu\u002Fpulumi)\n[![GoDoc](https:\u002F\u002Fgodoc.org\u002Fgithub.com\u002Fpulumi\u002Fpulumi?status.svg)](https:\u002F\u002Fgodoc.org\u002Fgithub.com\u002Fpulumi\u002Fpulumi)\n[![License](https:\u002F\u002Fimg.shields.io\u002Fgithub\u002Flicense\u002Fpulumi\u002Fpulumi)](LICENSE)\n\n# Infrastructure as Code in any Programming Language\n\n\u003Ca href=\"https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Fget-started\u002F\">\n    \u003Cimg src=\"https:\u002F\u002Fwww.pulumi.com\u002Fimages\u002Fget-started.svg?\" align=\"right\" width=\"120\">\n\u003C\u002Fa>\n\n**Pulumi Infrastructure as Code** is the easiest way to build and deploy infrastructure, of any architecture and on any cloud, using programming languages that you already know and love. Code and ship infrastructure faster with your favorite languages and tools, and embed IaC anywhere with [Automation API](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Fusing-pulumi\u002Fautomation-api\u002F).\n\nSimply write code in your favorite language and Pulumi automatically provisions and manages your resources on\n[AWS](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Fclouds\u002Faws\u002F),\n[Azure](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Fclouds\u002Fazure\u002F),\n[Google Cloud Platform](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Fclouds\u002Fgcp\u002F), \n[Kubernetes](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Fclouds\u002Fkubernetes\u002F), and [120+ providers](https:\u002F\u002Fwww.pulumi.com\u002Fregistry\u002F) using an\n[infrastructure-as-code](https:\u002F\u002Fwww.pulumi.com\u002Fwhat-is\u002Fwhat-is-infrastructure-as-code\u002F) approach.\nSkip the YAML, and use standard language features like loops, functions, classes,\nand package management that you already know and love.\n\nFor example, create three web servers:\n\n```typescript\nconst aws = require(\"@pulumi\u002Faws\");\nconst sg = new aws.ec2.SecurityGroup(\"web-sg\", {\n    ingress: [{ protocol: \"tcp\", fromPort: 80, toPort: 80, cidrBlocks: [\"0.0.0.0\u002F0\"] }],\n});\nfor (let i = 0; i \u003C 3; i++) {\n    new aws.ec2.Instance(`web-${i}`, {\n        ami: \"ami-7172b611\",\n        instanceType: \"t2.micro\",\n        vpcSecurityGroupIds: [sg.id],\n        userData: `#!\u002Fbin\u002Fbash\n            echo \"Hello, World!\" > index.html\n            nohup python -m SimpleHTTPServer 80 &`,\n    });\n}\n```\n\nOr a simple serverless timer that archives Hacker News every day at 8:30AM:\n\n```typescript\nconst aws = require(\"@pulumi\u002Faws\");\n\nconst snapshots = new aws.dynamodb.Table(\"snapshots\", {\n    attributes: [{ name: \"id\", type: \"S\", }],\n    hashKey: \"id\", billingMode: \"PAY_PER_REQUEST\",\n});\n\naws.cloudwatch.onSchedule(\"daily-yc-snapshot\", \"cron(30 8 * * ? *)\", () => {\n    require(\"https\").get(\"https:\u002F\u002Fnews.ycombinator.com\", res => {\n        let content = \"\";\n        res.setEncoding(\"utf8\");\n        res.on(\"data\", chunk => content += chunk);\n        res.on(\"end\", () => new aws.sdk.DynamoDB.DocumentClient().put({\n            TableName: snapshots.name.get(),\n            Item: { date: Date.now(), content },\n        }).promise());\n    }).end();\n});\n```\n\nMany examples are available spanning containers, serverless, and infrastructure in\n[pulumi\u002Fexamples](https:\u002F\u002Fgithub.com\u002Fpulumi\u002Fexamples).\n\nPulumi is open source under the [Apache 2.0 license](https:\u002F\u002Fgithub.com\u002Fpulumi\u002Fpulumi\u002Fblob\u002Fmaster\u002FLICENSE), supports many languages and clouds, and is easy to extend.  This\nrepo contains the `pulumi` CLI, language SDKs, and core Pulumi engine, and individual libraries are in their own repos.\n\n## Welcome\n\n\u003Cimg align=\"right\" width=\"400\" src=\"https:\u002F\u002Fwww.pulumi.com\u002Fimages\u002Fdocs\u002Fquickstart\u002Fconsole.png\" \u002F>\n\n* **[Get Started with Pulumi](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Fget-started\u002F)**: Deploy a simple application in AWS, Azure, Google Cloud, or Kubernetes using Pulumi.\n\n* **[Learn](https:\u002F\u002Fwww.pulumi.com\u002Ftutorials\u002F)**: Follow Pulumi learning pathways to learn best practices and architectural patterns through authentic examples.\n\n* **[Examples](https:\u002F\u002Fgithub.com\u002Fpulumi\u002Fexamples)**: Browse several examples across many languages,\n  clouds, and scenarios including containers, serverless, and infrastructure.\n\n* **[Docs](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002F)**: Learn about Pulumi concepts, follow user-guides, and consult the reference documentation.\n\n* **[Registry](https:\u002F\u002Fwww.pulumi.com\u002Fregistry\u002F)**: Find the Pulumi Package with the resources you need. Install the package directly into your project, browse the API documentation, and start building.\n\n* **[Secrets Management](https:\u002F\u002Fwww.pulumi.com\u002Fproduct\u002Fsecrets-management\u002F)**: Tame secrets sprawl and configuration complexity securely across all your cloud infrastructure and applications with Pulumi ESC.\n\n* **[Pulumi Roadmap](https:\u002F\u002Fgithub.com\u002Forgs\u002Fpulumi\u002Fprojects\u002F44)**: Review the planned work for the upcoming quarter and a selected backlog of issues that are on our mind but not yet scheduled.\n\n* **[Community Slack](https:\u002F\u002Fslack.pulumi.com\u002F)**: Join us in Pulumi Community Slack. All conversations and questions are welcome.\n\n* **[GitHub Discussions](https:\u002F\u002Fgithub.com\u002Fpulumi\u002Fpulumi\u002Fdiscussions)**: Ask questions or share what you're building with Pulumi.\n\n## \u003Ca name=\"getting-started\">\u003C\u002Fa>Getting Started\n\n[![Watch the video](\u002Fyoutube_preview_image.png)](https:\u002F\u002Fwww.youtube.com\u002Fwatch?v=6f8KF6UGN7g)\n\nSee the [Get Started](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Fget-started\u002F) guide to quickly get started with\nPulumi on your platform and cloud of choice.\n\nOtherwise, the following steps demonstrate how to deploy your first Pulumi program, using AWS\nServerless Lambdas, in minutes:\n\n1. **Install**:\n\n    To install the latest Pulumi release, run the following (see full\n    [installation instructions](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Fdownload-install\u002F) for additional installation options):\n\n    ```bash\n    curl -fsSL https:\u002F\u002Fget.pulumi.com\u002F | sh\n    ```\n\n2. **Create a Project**:\n\n    After installing, you can get started with the `pulumi new` command:\n\n    ```bash\n    mkdir pulumi-demo && cd pulumi-demo\n    pulumi new serverless-aws-typescript\n    ```\n\n    The `new` command offers [templates](https:\u002F\u002Fgithub.com\u002Fpulumi\u002Ftemplates\u002F) for all languages and clouds.  Run it without an argument and it'll prompt\n    you with available projects.  This command creates an AWS Serverless Lambda project written in TypeScript.\n\n3. **Deploy to the Cloud**:\n\n    Run `pulumi up` to get your code to the cloud:\n\n    ```bash\n    pulumi up\n    ```\n\n    This makes all cloud resources needed to run your code.  Simply make edits to your project, and subsequent\n    `pulumi up`s will compute the minimal diff to deploy your changes.\n\n4. **Use Your Program**:\n\n    Now that your code is deployed, you can interact with it.  In the above example, we can curl the endpoint:\n\n    ```bash\n    curl $(pulumi stack output url)\n    ```\n\n5. **Access the Logs**:\n\n    If you're using containers or functions, Pulumi's unified logging command will show all of your logs:\n\n    ```bash\n    pulumi logs -f\n    ```\n\n6. **Destroy your Resources**:\n\n    After you're done, you can remove all resources created by your program:\n\n    ```bash\n    pulumi destroy -y\n    ```\n\nTo learn more, head over to [pulumi.com](https:\u002F\u002Fpulumi.com\u002F) for much more information, including\n[tutorials](https:\u002F\u002Fwww.pulumi.com\u002Ftutorials\u002F), [examples](https:\u002F\u002Fgithub.com\u002Fpulumi\u002Fexamples), and\ndetails of the core Pulumi CLI and [programming model concepts](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Fconcepts\u002F).\n\n## \u003Ca name=\"platform\">\u003C\u002Fa>Platform\n\n### Languages\n\n|    | Language | Status | Runtime | Versions |\n| -- | -------- | ------ | ------- | -------- |\n| \u003Cimg src=\"https:\u002F\u002Fwww.pulumi.com\u002Flogos\u002Ftech\u002Flogo-js.png\" height=38 \u002F>     | [JavaScript](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Flanguages-sdks\u002Fjavascript\u002F) | Stable  | Node.js | [Current, Active and Maintenance LTS versions](https:\u002F\u002Fnodejs.org\u002Fen\u002Fabout\u002Fprevious-releases)  |\n| \u003Cimg src=\"https:\u002F\u002Fwww.pulumi.com\u002Flogos\u002Ftech\u002Flogo-ts.png\" height=38 \u002F>     | [TypeScript](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Flanguages-sdks\u002Fjavascript\u002F) | Stable  | Node.js | [Current, Active and Maintenance LTS versions](https:\u002F\u002Fnodejs.org\u002Fen\u002Fabout\u002Fprevious-releases)  |\n| \u003Cimg src=\"https:\u002F\u002Fwww.pulumi.com\u002Flogos\u002Ftech\u002Flogo-python.svg\" height=38 \u002F> | [Python](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Flanguages-sdks\u002Fpython\u002F)     | Stable  | Python | [Supported versions](https:\u002F\u002Fdevguide.python.org\u002Fversions\u002F#versions) |\n| \u003Cimg src=\"https:\u002F\u002Fwww.pulumi.com\u002Flogos\u002Ftech\u002Flogo-golang.png\" height=38 \u002F> | [Go](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Flanguages-sdks\u002Fgo\u002F)             | Stable  | Go | [Supported versions](https:\u002F\u002Fgo.dev\u002Fdoc\u002Fdevel\u002Frelease#policy) |\n| \u003Cimg src=\"https:\u002F\u002Fwww.pulumi.com\u002Flogos\u002Ftech\u002Fdotnet.svg\" height=38 \u002F>      | [.NET (C#\u002FF#\u002FVB.NET)](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Flanguages-sdks\u002Fdotnet\u002F)     | Stable  | .NET | [Supported versions](https:\u002F\u002Fdotnet.microsoft.com\u002Fen-us\u002Fplatform\u002Fsupport\u002Fpolicy\u002Fdotnet-core#lifecycle)  |\n| \u003Cimg src=\"https:\u002F\u002Fwww.pulumi.com\u002Flogos\u002Ftech\u002Fjava.svg\" height=38 \u002F>      | [Java](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Flanguages-sdks\u002Fjava\u002F)     | Stable  | JDK | 11+  |\n| \u003Cimg src=\"https:\u002F\u002Fwww.pulumi.com\u002Flogos\u002Ftech\u002Fyaml.svg\" height=38 \u002F>      | [YAML](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Flanguages-sdks\u002Fyaml\u002F)     | Stable  | n\u002Fa  | n\u002Fa  |\n\n### EOL Releases\n\nThe Pulumi CLI v1 and v2 are no longer supported. If you are not yet running v3, please consider migrating to v3 to continue getting the latest and greatest Pulumi has to offer! :muscle:\n\n* To migrate from v2 to v3, please see our [v3 Migration Guide](https:\u002F\u002Fwww.pulumi.com\u002Fdocs\u002Fiac\u002Fdownload-install\u002Fmigrating-3.0\u002F).\n\n### Clouds\n\nVisit the [Registry](https:\u002F\u002Fwww.pulumi.com\u002Fregistry\u002F) for the full list of supported cloud and infrastructure providers.\n\n## Contributing\n\nVisit [CONTRIBUTING.md](https:\u002F\u002Fgithub.com\u002Fpulumi\u002Fpulumi\u002Fblob\u002Fmaster\u002FCONTRIBUTING.md) for information on building Pulumi from source or contributing improvements.\n","Pulumi 是一个支持使用任意编程语言进行基础设施即代码（IaC）开发的平台。它允许开发者通过熟悉的编程语言如TypeScript、Python、Go等来定义和部署云资源，从而实现对AWS、Azure、GCP、Kubernetes等超过120种云服务提供商的支持。Pulumi的核心优势在于其能够充分利用现代编程语言的特性，比如循环、函数、类以及包管理机制，使得基础设施配置更加灵活且易于维护。此外，Pulumi还提供了自动化API，方便将IaC集成到CI\u002FCD流程或其他自动化任务中。此工具非常适合需要快速迭代并希望保持代码一致性的云原生应用开发团队或个人开发者，在构建微服务架构、容器化应用或是无服务器计算环境时尤为有用。",2,"2026-06-11 03:00:12","top_language"]