pulumi/README.md

134 lines
6.4 KiB
Markdown
Raw Permalink Normal View History

2018-03-26 00:14:30 +02:00
# Pulumi
2016-10-09 01:01:25 +02:00
2018-06-10 19:35:51 +02:00
Pulumi is a cloud development platform that makes creating cloud programs easy and productive.
2018-03-26 00:14:30 +02:00
2018-06-18 10:33:10 +02:00
Author cloud programs in your favorite language and Pulumi will automatically keep your
infrastructure up-to-date. Skip the YAML and just write code. Pulumi is multi-language, multi-cloud
and fully extensible in both its engine and ecosystem of packages.
2018-06-10 19:35:51 +02:00
To install the latest Pulumi release, run:
2018-06-10 19:35:51 +02:00
```bash
$ curl -fsSL https://get.pulumi.com/ | sh
```
After installing, you can get started with the `pulumi new` command,
[our examples](https://github.com/pulumi/examples), or our [visit project website](https://pulumi.io/) which
includes several [in-depth tutorials](https://pulumi.io/quickstart) and
[an interactive tour](https://pulumi.io/tour) to walk through the core CLI usage and programming concepts.
Please join [the conversation on Slack](https://slack.pulumi.io/).
2018-06-10 19:35:51 +02:00
This repo contains the CLI, language SDKs, and the core Pulumi engine. Individual libraries are in their own repos.
## Platforms
2017-10-10 22:40:11 +02:00
2017-10-10 22:41:45 +02:00
| Architecture | Build Status |
| ------------ | ------------ |
| Linux/macOS x64 | [![Linux x64 Build Status](https://travis-ci.com/pulumi/pulumi.svg?token=cTUUEgrxaTEGyecqJpDn&branch=master)](https://travis-ci.com/pulumi/pulumi) |
| Windows x64 | [![Windows x64 Build Status](https://ci.appveyor.com/api/projects/status/uqrduw6qnoss7g4i?svg=true&branch=master)](https://ci.appveyor.com/project/pulumi/pulumi) |
2017-10-10 22:40:11 +02:00
2018-06-10 19:35:51 +02:00
## Languages
2017-02-25 19:46:26 +01:00
2018-06-10 19:35:51 +02:00
| Language | Status | Runtime | Readme |
| -------- | ------ | ------- | -------- |
| JavaScript | Stable | Node.js 6.x-10.x | [Readme](./sdk/nodejs) |
| TypeScript | Stable | Node.js 6.x-10.x | [Readme](./sdk/nodejs) |
2018-06-15 22:37:27 +02:00
| Python | Preview | Python 2.7 | [Readme](./sdk/python) |
2018-06-10 19:35:51 +02:00
| Go | Preview | Go 1.x | [Readme](./sdk/go) |
2017-02-25 19:46:26 +01:00
2018-06-10 19:35:51 +02:00
## Clouds
2017-02-25 19:46:26 +01:00
2018-06-10 19:35:51 +02:00
| Cloud | Status | Docs | Repo |
| ----- | ------ | ---- | ---- |
| Amazon Web Services | Stable | [Docs](https://pulumi.io/reference/pkg/nodejs/@pulumi/aws/) | [pulumi/pulumi-aws](https://github.com/pulumi/pulumi-aws) |
2018-06-15 22:37:27 +02:00
| Microsoft Azure | Preview | [Docs](https://pulumi.io/reference/pkg/nodejs/@pulumi/azure/) | [pulumi/pulumi-azure](https://github.com/pulumi/pulumi-azure) |
2018-06-10 19:35:51 +02:00
| Google Cloud Platform | Preview | [Docs](https://pulumi.io/reference/pkg/nodejs/@pulumi/gcp/) | [pulumi/pulumi-gcp](https://github.com/pulumi/pulumi-gcp) |
2018-06-15 22:37:27 +02:00
| Kubernetes | Preview | [Docs](https://pulumi.io/reference/pkg/nodejs/@pulumi/kubernetes/) | [pulumi/pulumi-kubernetes](https://github.com/pulumi/pulumi-kubernetes) |
2017-02-25 19:46:26 +01:00
2018-06-10 19:35:51 +02:00
## Libraries
2017-02-25 19:46:26 +01:00
2018-06-10 19:35:51 +02:00
There are several libraries that encapsulate best practices and common patterns:
| Library | Status | Docs | Repo |
| ------- | ------ | ---- | ---- |
| AWS Serverless | Preview | [Docs](https://pulumi.io/reference/pkg/nodejs/@pulumi/aws-serverless/) | [pulumi/pulumi-aws-serverless](https://github.com/pulumi/pulumi-aws-serverless) |
2018-06-15 22:37:27 +02:00
| AWS Infrastructure | Preview | [Docs](https://pulumi.io/reference/pkg/nodejs/@pulumi/aws-infra/) | [pulumi/pulumi-aws-infra](https://github.com/pulumi/pulumi-aws-infra) |
| Pulumi Multi-Cloud Framework | Preview | [Docs](https://pulumi.io/reference/pkg/nodejs/@pulumi/cloud/) | [pulumi/pulumi-cloud](https://github.com/pulumi/pulumi-cloud) |
2018-06-10 19:35:51 +02:00
## Examples
A collection of examples for different languages, clouds, and scenarios is available in the
[pulumi/examples](https://github.com/pulumi/examples) repo.
2017-02-25 19:52:01 +01:00
2017-02-25 19:46:26 +01:00
## Development
2018-06-10 19:35:51 +02:00
If you'd like to contribute to Pulumi and/or build from source, this section is for you.
2017-02-25 19:46:26 +01:00
### Prerequisites
Pulumi is written in Go, uses Dep for dependency management, and GoMetaLinter for linting:
* [Go](https://golang.org/doc/install): https://golang.org/dl
2017-08-02 03:37:06 +02:00
* [Dep](https://github.com/golang/dep): `$ go get -u github.com/golang/dep/cmd/dep`
* [GoMetaLinter](https://github.com/alecthomas/gometalinter):
2017-08-02 03:37:06 +02:00
- `$ go get -u github.com/alecthomas/gometalinter`
- `$ gometalinter --install`
2018-06-10 19:35:51 +02:00
### Building from Source
To install the pre-built SDK, please run `curl -fsSL https://get.pulumi.com/ | sh`, or see detailed installation
instructions on [the project page](https://pulumi.io/). Read on if you want to install from source.
To build the Pulumi CLI from source, you may simply run:
$ go get -u github.com/pulumi/pulumi
This installs the `pulumi` binary to `$GOPATH/bin`.
To do anything interesting with Pulumi, you will need an SDK for your language of choice. The SDK installation comes
with pre-built language providers, however the `make` flow below will create a complete SDK distribution for you.
2017-02-25 19:46:26 +01:00
### Building and Testing
2018-06-10 19:35:51 +02:00
To build a complete Pulumi SDK, ensure `$GOPATH` is set, and clone into a standard Go workspace:
2016-11-23 21:41:30 +01:00
$ git clone git@github.com:pulumi/pulumi $GOPATH/src/github.com/pulumi/pulumi
$ cd $GOPATH/src/github.com/pulumi/pulumi
2016-11-23 21:41:30 +01:00
The first time you build, you must `make ensure` to install dependencies and perform other machine setup:
$ make ensure
In the future, you can synch dependencies simply by running `dep ensure` explicitly:
2017-05-24 22:25:28 +02:00
2017-08-02 03:37:06 +02:00
$ dep ensure
2017-05-24 22:25:28 +02:00
At this point you can run `make` to build and run tests:
2016-11-23 21:41:30 +01:00
$ make
This installs the `pulumi` binary into `$GOPATH/bin`, which may now be run provided `make` exited successfully.
2016-11-23 21:41:30 +01:00
The Makefile also supports just running tests (`make test_all` or `make test_fast`), just running the linter
(`make lint`), just running Govet (`make vet`), and so on. Please just refer to the Makefile for the full list of targets.
2017-05-24 22:25:28 +02:00
2017-02-25 19:52:01 +01:00
### Debugging
2017-01-26 22:50:27 +01:00
The Pulumi tools have extensive logging built in. In fact, we encourage liberal logging in new code, and adding new
2017-01-26 22:50:27 +01:00
logging when debugging problems. This helps to ensure future debugging endeavors benefit from your sleuthing.
All logging is done using Google's [Glog library](https://github.com/golang/glog). It is relatively bare-bones, and
adds basic leveled logging, stack dumping, and other capabilities beyond what Go's built-in logging routines offer.
2017-01-26 22:50:27 +01:00
The `pulumi` command line has two flags that control this logging and that can come in handy when debugging problems.
The `--logtostderr` flag spews directly to stderr, rather than the default of logging to files in your temp directory.
And the `--verbose=n` flag (`-v=n` for short) sets the logging level to `n`. Anything greater than 3 is reserved for
2017-01-26 22:50:27 +01:00
debug-level logging, greater than 5 is going to be quite verbose, and anything beyond 7 is extremely noisy.
For example, the command
$ pulumi preview --logtostderr -v=5
2017-01-26 22:50:27 +01:00
is a pretty standard starting point during debugging that will show a fairly comprehensive trace log of a compilation.