-
Notifications
You must be signed in to change notification settings - Fork 22
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* 1.9.0-alpha blog post Signed-off-by: AbstractionFactory <179820029+abstractionfactory@users.noreply.github.com> * Note about static Signed-off-by: AbstractionFactory <179820029+abstractionfactory@users.noreply.github.com> * Header banner Signed-off-by: AbstractionFactory <179820029+abstractionfactory@users.noreply.github.com> * Preview picture Signed-off-by: AbstractionFactory <179820029+abstractionfactory@users.noreply.github.com> * Code coloring Signed-off-by: AbstractionFactory <179820029+abstractionfactory@users.noreply.github.com> * Better example Signed-off-by: AbstractionFactory <179820029+abstractionfactory@users.noreply.github.com> * Even better example Signed-off-by: AbstractionFactory <179820029+abstractionfactory@users.noreply.github.com> Co-authored-by: Oleksandr Levchenkov <ollevche@gmail.com> * Update blog/2024-11-11-help-us-test-opentofu-1-9-0-alpha2.md Co-authored-by: Oleksandr Levchenkov <ollevche@gmail.com> Signed-off-by: AbstractionFactory <179820029+abstractionfactory@users.noreply.github.com> * Code coloring Signed-off-by: AbstractionFactory <179820029+abstractionfactory@users.noreply.github.com> * Minor typo fix Signed-off-by: AbstractionFactory <179820029+abstractionfactory@users.noreply.github.com> --------- Signed-off-by: AbstractionFactory <179820029+abstractionfactory@users.noreply.github.com> Co-authored-by: Oleksandr Levchenkov <ollevche@gmail.com>
- Loading branch information
1 parent
c89d995
commit 1170ef7
Showing
3 changed files
with
133 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,132 @@ | ||
--- | ||
title: Help us test OpenTofu 1.9.0-alpha2 | ||
slug: help-us-test-opentofu-1-9-0-alpha2 | ||
image: /img/blog/help-us-test-opentofu-1-9-0-alpha2.png | ||
--- | ||
|
||
Hello everyone! As we have taken on one of the most difficult tasks since the inception of OpenTofu and it's been a while since we last released a feature version. Today, we are very proud to ask for your help in testing OpenTofu 1.9.0-alpha2, coming with a much-requested feature: provider iteration using `for_each`. Additionally, this release includes the new `-exclude` flag for plan and apply. | ||
|
||
We have done everything we could to make sure that the new alpha release doesn't break anything, and we need your help to get this release tested. If you have a **non-production** setup that you would be willing to test any of the new features on, please give it a try and give us [feedback using a GitHub issue](https://github.com/opentofu/opentofu/issues/new/choose), even if it's just telling us that everything went well. | ||
|
||
This blog post will go over how to download the new preview release and detail how each of the new features works. | ||
|
||
:::warning | ||
|
||
Do not test this release on a production project! It is not a stable release! | ||
|
||
::: | ||
|
||
## Downloading the alpha release | ||
|
||
The alpha release is available exclusively from the [GitHub Releases page](https://github.com/opentofu/opentofu/releases/tag/v1.9.0-alpha2). Please select the appropriate file for your platform. Here are some quick links: | ||
|
||
| Platform/Device | Download link | | ||
|---------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | ||
| **Desktop Windows computer**<br />(64-bit) | [tofu_1.9.0-alpha2_windows_amd64.zip](https://github.com/opentofu/opentofu/releases/download/v1.9.0-alpha2/tofu_1.9.0-alpha2_windows_amd64.zip) | | ||
| **MacOS**<br />(Macbook M1 or higher; ARM64) | [tofu_1.9.0-alpha2_darwin_arm64.tar.gz](https://github.com/opentofu/opentofu/releases/download/v1.9.0-alpha2/tofu_1.9.0-alpha2_darwin_arm64.tar.gz) | | ||
| **MacOS**<br />(Macbook pre-M1; AMD64) | [tofu_1.9.0-alpha2_darwin_amd64.tar.gz](https://github.com/opentofu/opentofu/releases/download/v1.9.0-alpha2/tofu_1.9.0-alpha2_darwin_amd64.tar.gz) | | ||
| **Intel/AMD Linux computer or server**<br />(AMD64) | [tofu_1.9.0-alpha2_linux_amd64.tar.gz](https://github.com/opentofu/opentofu/releases/download/v1.9.0-alpha2/tofu_1.9.0-alpha2_linux_amd64.tar.gz) | | ||
| **ARM-based Linux computer<br />or<br />Raspberry Pi 3 or higher**<br />(ARM64) | [tofu_1.9.0-alpha2_linux_arm64.tar.gz](https://github.com/opentofu/opentofu/releases/download/v1.9.0-alpha2/tofu_1.9.0-alpha2_linux_arm64.tar.gz) | | ||
|
||
For the releases above, please unpack the archive and you should find the `tofu` binary inside. You can also use the [standalone installer](https://opentofu.org/docs/intro/install/standalone/) to download the release with signature verification. | ||
|
||
## Provider `for_each` | ||
|
||
Imagine you have to deploy an infrastructure that involves multiple regions using your cloud provider. In order to minimize code duplication, you created a module that you can use for each region. However, your main module still looks like this: | ||
|
||
```hcl | ||
provider "aws" { | ||
alias = "useast" | ||
region = "us-east-1" | ||
} | ||
provider "aws" { | ||
alias = "uswest" | ||
region = "us-west-1" | ||
} | ||
provider "aws" { | ||
alias = "eucentral" | ||
region = "eu-central-1" | ||
} | ||
module "deploy-useast" { | ||
source = "./deploy" | ||
providers = { | ||
aws = aws.useast | ||
} | ||
} | ||
module "deploy-uswest" { | ||
source = "./deploy" | ||
providers = { | ||
aws = aws.uswest | ||
} | ||
} | ||
module "deploy-eucentral" { | ||
source = "./deploy" | ||
providers = { | ||
aws = aws.eucentral | ||
} | ||
} | ||
``` | ||
|
||
Starting OpenTofu 1.9, you can now use a `for_each` instead: | ||
|
||
```hcl | ||
variable "regions" { | ||
description = "A list of regions that should have a deployment." | ||
type = set(string) | ||
} | ||
variable "disabled_regions" { | ||
description = "A list of regions that should be disabled and all resources removed." | ||
type = set(string) | ||
default = [] | ||
} | ||
provider "aws" { | ||
alias = "by_region" | ||
region = each.value | ||
for_each = var.regions | ||
} | ||
module "deploy" { | ||
source = "./deploy" | ||
providers = { | ||
aws = aws.by_region[each.key] | ||
} | ||
// Here we make sure that all resources from a region are removed | ||
// if the region is disabled. This must be done before removing | ||
// a region entirely. | ||
for_each = setsubtract(var.regions, var.disabled_regions) | ||
} | ||
``` | ||
|
||
As you can see, you can pass in the set of regions using a variable and then call the module as many times as you need it. | ||
|
||
However, there are some important considerations to remember when using `for_each` in this manner: | ||
|
||
1. You can only use `for_each` on variables and locals that can be obtained statically. Expressions that rely on data sources or resources are currently not usable. | ||
2. If you have an already-deployed infrastructure, don't simply remove a provider from the list as this will make it impossible for OpenTofu to destroy the infrastructure in this region. Instead, you will need to implement removing that infrastructure first and then remove the provider from the list. See the `disabled_regions` variable for an example above. | ||
3. Currently, each provider used in a `for_each` **must** have an alias. Providers without aliases are not supported for now due to internal technical reasons. | ||
4. There is currently no way to pass a set of providers to a module, you can only pass individual providers. | ||
|
||
We are actively working on resolving these limitations and future OpenTofu versions will see this capability improved. | ||
|
||
## Exclude on plan and apply | ||
|
||
This flag is small but powerful: similar to `-target`, you can now tell OpenTofu to ignore a certain resource when applying your configuration. | ||
|
||
For example: | ||
|
||
```hcl2 | ||
tofu plan -exclude=kubernetes_manifest.crds | ||
``` | ||
|
||
In this case, OpenTofu will ignore `kubernetes_manifest.crds` during planning. | ||
|
||
## Providing feedback | ||
|
||
Thank you for taking the time to test this preview release. If you have any feedback, please use [a GitHub issue](https://github.com/opentofu/opentofu/issues/new/choose) or chat with us on the [OpenTofu Slack](https://opentofu.org/slack/). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.