-
Notifications
You must be signed in to change notification settings - Fork 9.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
What is the dependency cycle in this? #1475
Comments
Sorry for the frustrating experience. We'll look into this. Terraform right now is fairly conservative with graph cycles. It is better to incorrectly error when there is no cycle then to execute and fail to work with a real cycle. We'll continue to iron out any false cycles over time. I've tagged this issue and will take a look for the next release. |
terraform: prune tainted destroys if no tainted in state [GH-1475]
Fixed in master! |
Sweet, I'll try it out |
* master: (511 commits) Update CHANGELOG.md core: avoid diff mismatch on NewRemoved fields during -/+ Update CHANGELOG.md update CHANGELOG Fix minor error in index/count docs terraform: remove debug terraform: when pruning destroy, only match exact nodes, or exact counts up version for dev update CHANGELOG terraform: prune tainted destroys if no tainted in state [GH-1475] update CHANGELOG config/lang: support math on variables through implicits update CHANGELOG update cHANGELOG update cHANGELOG providers/aws: set id outside if/esle providers/aws: set ID after creation core: remove dead code from pre-deposed refactor website: update LC docs to note name is optional security_groups field expects a list of Security Group Group Names, not IDs ...
@mitchellh, is it possible for me to determine if this fix will work for a cycle / destroy / tainted error I am getting? My code is a bit more to analyze, but I can post it if that helps. I can also test master, but that will take me time to do (first attempts have been failing me). |
@ketzacoatl Testing master is the easiest way, what issues have you ran into? |
@mitchellh, I am unable to get past running
I'm on debian, and this is my first attempt building a project in go, so I expect the problem is with me, but the README and http://golang.org/doc/code.html#GOPATH make it seem pretty simple. |
Hm, I've never seen that, what version of Go? You need 1.4+. Otherwise, I'm unsure. |
bingo, I will get the latest. |
@mitchellh, I got further, but
I attempted to drop back to the revision from this issue, and build from there (with |
That is a harmless error. I'll fix it here shortly but you should be able to compile otherwise: |
Wonderful.. I will build, test, and report back shortly |
Did the behavior of Terraform I built from with: I imagine the rabbit hole will circle back around to where I started with the dependency cycle error.. |
Put the whole thing in |
Yes, that's nearly obvious.. sorry. Ok, so back to the dependency cycle error.. I believe using the latest git has addressed that, though I have a couple of small issues to address with my plan before I'll know for sure. @mitchellh thank you for your help this evening! |
Bah, I spoke too soon. With v0.4.2, I would get the cycle error with
...but errors out when applying the plan:
@mitchellh, Is there a way to inspect the cycle or details of the problem? Would it be easier to review the code behind this error? |
I think I may be having a similar problem as @ketzacoatl, here's my error (note this is on the first attempt at terraform apply... if that matters)
|
@mitchellh, I too can confirm the detail @gposton added: I'm applying these resources for the first time, there is no existing state.. Any thoughts on how to proceed? Apologies if this should be a new/separate issue..? |
@ketzacoatl and @gposton if you could each file separate issues with config snippets that would be helpful. I think it's easiest for us to treat each cycle issue as separate until we determine possible relationships. That should allow us to easily work with you 1:1 to determine the issue. Off the bat - there are some legitimate cycles that can be introduced into the graph by using create_before_destroy. So when you're in the weeds, the first thing to start playing with is commenting out |
@phinze, thanks for the guidance here. I'll create a new issue with relevant information. |
FTR, I am not using |
I am also having this issue with a similar configuration, tested with: Terraform v0.5.0-dev (3d36779) |
@wazoo, I removed all modules within modules, so I only have a top-level plan that calls other modules, and all of those modules define AWS/etc resources directly, and I have been able to proceed with TF as it is right now. |
Mine was due to cyclic security group dependency I think. |
I just ran into this again, I have this (basically):
The parent module has two child module definitions (child_module0 and child_module1), the outputs of one child module are used in the second child module definition (security groups). This results in this (made up example):
I can create a real set of example TF files if this doesn't really make sense, let me know. I submitted #1742 that would also help solve this by reducing when I need to pass around variables. It's also possible there is a better way to accomplish what I am doing, feel free to let me know. |
We are running into the same cycle issue with Terraform from master. |
We were getting some cycle dependencies error when applying the config without existing .tfstate. We double checked and we have no cycles at all. For reference, see: * [What is the dependency cycle in this? #1475](hashicorp/terraform#1475) * [Dependency cycle errors with modules #1637](hashicorp/terraform#1637)
@wazoo, @mikkoc, what worked best for me, though slightly less than ideal, flatten the module graph a little. In my case, instead of having a module call another module, I ensure modules all have resources and no modules, and then I feed inputs/outputs to each of the modules that need it, at the root level. This has worked nicely with how TF is as of today, YMMV. |
@ketzacoatl I get graph cycles even with a flattened topology like you described, my actual situation is that instances are only allowed to receive ssh from a bastion SG and the bastion host can only connect to the security groups instances for all of the applications so TF doesn't know which to create first. What it really needs to know to do is create the groups first then modify them with the rules later, this would also be solved if #1620 became a reality I think. |
@wazoo, ah, ok, a little more complicated. If it were me, I would change things around, possibly with duplication of SG if needed. As a fallback, if you really can't change that now, you could create the SG, then use a noop-type resource (I forget the name, you'll have to look up in TF docs) with a local provisioner to issue some shell locally.. then use that to call out to the AWS APIs to make the changes you want.. and use Another thought is to have TF run from within a network at AWS, where you can access those private instances, and completely avoid the need of sending TF provisioning through the bastion. |
Interesting, I hadn't thought about using a local provisioner like that. The bastion host is actually just for SSH, this setup I am not using in-guest provisioners, just using TF to do the AWS layout. |
We were getting some cycle dependencies error when applying the config without existing .tfstate. We double checked and we have no cycles at all. For reference, see: * [What is the dependency cycle in this? #1475](hashicorp/terraform#1475) * [Dependency cycle errors with modules #1637](hashicorp/terraform#1637)
We were getting some cycle dependencies error when applying the config without existing .tfstate. We double checked and we have no cycles at all. For reference, see: * [What is the dependency cycle in this? #1475](hashicorp/terraform#1475) * [Dependency cycle errors with modules #1637](hashicorp/terraform#1637)
I'm going to lock this issue because it has been closed for 30 days ⏳. This helps our maintainers find and focus on the active issues. If you have found a problem that seems similar to this, please open a new issue and complete the issue template so we can capture all the details necessary to investigate further. |
I have a very simple module (lives at
module/main.tf
):And a very simple config that includes the module above (
main.tf
):I would expect this to produce a dependency graph where:
which has no cycles.
Instead, I get this error:
Since
terraform graph
refuses to produce a graph when there's a cycle (which is very frustrating), I can't really figure out what's going on.Where is my cycle?
The text was updated successfully, but these errors were encountered: