Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/onlydole/a-tale-of-two-clouds
An infrastructure as code example of spinning up resources in multiple clouds.
https://github.com/onlydole/a-tale-of-two-clouds
aks aws azure clouds eks hashicorp hashicorp-terraform hcl terraform
Last synced: 3 months ago
JSON representation
An infrastructure as code example of spinning up resources in multiple clouds.
- Host: GitHub
- URL: https://github.com/onlydole/a-tale-of-two-clouds
- Owner: onlydole
- License: apache-2.0
- Created: 2020-09-08T21:57:05.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2020-09-22T17:29:33.000Z (over 4 years ago)
- Last Synced: 2024-10-29T23:15:11.761Z (3 months ago)
- Topics: aks, aws, azure, clouds, eks, hashicorp, hashicorp-terraform, hcl, terraform
- Language: HCL
- Homepage:
- Size: 27.3 KB
- Stars: 11
- Watchers: 7
- Forks: 16
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# A Tale Of Two Clouds
> Reading material and code examples
A webinar with A Cloud Guru that showcases how to use Terraform to manage two separate clouds, side by side.
_Note:_ You will need to ensure `wget` is installed locally for the EKS module to validate your EKS cluster's endpoint.
## Table of Contents
- [A Tale Of Two Clouds](#code-all-the-things-terraform-x-aws)
- [Table of Contents](#table-of-contents)
- [Prerequisites](#prerequisites)
- [Reading material](#reading-material)
- [HashiCorp Configuration Language](#hashicorp-configuration-language)
- [First Steps](#first-steps)
- [Next Steps](#next-steps)
- [Code Quality](#code-quality)
- [Modules](#modules)
- [Author Information](#author-information)
- [License](#license)## Prerequisites
As part of this workshop, you will be using [HashiCorp Terraform](https://www.terraform.io) and [Amazon Web Services](https://aws.amazon.com).
For instructions on how to install Terraform. please see our [Learn Guide](https://learn.hashicorp.com/terraform/getting-started/install.html).
On that page, you will find instructions for macOS (using `brew`), Windows (using `choco`) as well as a manual installation path.
## Reading material
This section is a collection of links that will help you make the most of today's session.
### HashiCorp Configuration Language
- repository: [hashicorp/hcl](https://github.com/hashicorp/hcl/tree/hcl2)
- intermediate HCL: [Configuration Languages in HCL2](https://www.hashicorp.com/resources/intermediate-hcl-configuration-languages-in-hcl2/)## First Steps
- CLI commands [terraform.io/docs/commands/index.html](https://www.terraform.io/docs/commands/index.html)
- variables and type constraints: [terraform.io/docs/configuration/variables.html](https://www.terraform.io/docs/configuration/variables.html#type-constraints)
- variable definition files: [terraform.io/docs/configuration/variables.html](https://www.terraform.io/docs/configuration/variables.html#variable-definitions-tfvars-files)
- information about Terraform State: [terraform.io/docs/state/index.html](https://www.terraform.io/docs/state/index.html)## Next Steps
- Learn Guide: Build infrastructure [learn.hashicorp.com/terraform/getting-started/build](https://learn.hashicorp.com/terraform/getting-started/build)
- Build your own AMIs with Packer: [packer.io/docs/builders/amazon/](https://www.packer.io/docs/builders/amazon/)### Code Quality
Before `plan` and `apply`, always clean up your code:
- use [terraform fmt](https://www.terraform.io/docs/commands/fmt.html) to rewrite Terraform configuration files to a canonical format and style.
- use [terraform validate](https://www.terraform.io/docs/commands/validate.html) to validate the configuration syntax and internal consistency
- use [pre-commit](https://pre-commit.com) to run more checks
- community member [@antonbabenko](https://github.com/antonbabenko/) built and maintains [pre-commit-terraform](https://github.com/antonbabenko/pre-commit-terraform)### Modules
- use modules as building blocks
- module documentation: [terraform.io/docs/configuration/modules.html](https://www.terraform.io/docs/configuration/modules.html)
- module registry: [registry.terraform.io](https://registry.terraform.io)
- Learn Guide: Modules on [learn.hashicorp.com/terraform/modules/modules-overview](https://learn.hashicorp.com/terraform/modules/modules-overview)## Author Information
This repository is maintained by [Taylor Dolezal](https://github.com/onlydole) .
## License
Licensed under the Apache License, Version 2.0 (the "License").
You may obtain a copy of the License at [apache.org/licenses/LICENSE-2.0](http://www.apache.org/licenses/LICENSE-2.0).
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an _"AS IS"_ basis, without WARRANTIES or conditions of any kind, either express or implied.
See the License for the specific language governing permissions and limitations under the License.