I spent a lot of hours to understand how things are segregating bet' workspace and folder based structure flow in terraform. After i pumped into here, got to know how simple it is. Heads up to you Will Brock. Simple and Sweet explanation. Awesome Job. Thanks a lot.
So glad someone addressed the initial confusion I had when I first was introduced to Workspace. Because I thought initially that by defining a workspace, it automatically deploys resources to different "profile" automatically on the cloud server I am working on. But that's not the case. It is more of a logical grouping with its own state file that helps manages different prod/non-prod environments GIVEN the right config.
This was a good explanation, thanks Curious, what if you define instance name in the dev.tfvars with a dev prefix. Same for PRD. Would you still need workspace? I guess to manage different .tfstate files?
Thanks Will for this wornderful video. But I have a question here apart from instance name which was picked based on workspace I couldn't understand what else could be the use case . If being in dev workspace you will pass prod.tfvars as argument the script will create the infra with prod configuration I beleive then what is new here ? can you pls clarify ?
Thank you, what is locals resource? I am not clear on that part. And one more doubt when run terraform apply with different variable files at that time only environments Got segregated and accordingly apply ?
Hi Will, What if, In Dev Workspace, I use -var-file prod.tfvars. this will apply the prod vars in Dev workspace. !! if that's the case, It all depends on varfiles, rather than Workspace. Then what is the use of differnt workspaces. - "is it maintaining different tfstate files for same config ? " please correct me if I am wrong.
Hey @Will Brock thanks for this video. Question for you - must you call the -var-file for each environment? Is there a way to add this elsewhere so it's not in the CLI. I'm trying to find use cases to use Terraform workspace over Terragrunt
i think the way Will Brock presented this is bound to fail.... someone will accidentally apply prod variables to dev environment. unless you set up a pipeline and no one actually runs terraform plan/apply on their terminal. in variables.tf you could do a map like variable "testing" { default = { dev = "abc" prod = "def"}} , then you call it like var.testing[terraform.workspace]. if you want values to come from tfvars you could probably use some other technique like an if statement
Excellent demo and explanation. Thanks so much. I have a few questions: 1) After setting up the two separate workspaces, is there still a point for the terraform.tfvars 2) how would git keep track of the workspace?
For number 1 you can still have a terraform.tfvars depending on your needs. You would use git to keep track of the code only and not the state files. You could use git to track the state files but it's not recommend. Instead you should use a remote backend like S3 to keep track of the state.
Awesome video ! Question- How can I further break down the project into infrastructure types ? Lets say under dev --> App(a folder), database(a folder). How can I maintain separate state for apps and database under dev ?
If you want separate state for databases and app you need to create two separate configurations not in the same workspace. Depending on your needs it might make sense to keep them both in the same state files.
So workspace allows you to have different state files for different environment . Each environment can have its own workspace hence its own state file.. right ?
but there is a problem! When you change workspace and run "terraform plan" the existing resource that was created previously will be marked as ... "1 to change" ...
Hi Will. Such an amazing teaching for terraform. Can you please make a video on how to use workspace for different account. Like sandbox and dev accounts in AWS>
Thanks for the awesome tutorials! Is it possible to have a workspace default to a .tfvars file? I find it easy to forget which workspace I'm in and apply the wrong .tfvars file. I have a dev, qa and prod.tfvars files and want to use them in my dev, qa and prod workspace respectively.
Workspaces do not seem to add a great deal of value? When you run terraform apply you select the right tfvars file yourself, and so the main use-case for a workspace, env differentiation, is handled via a different mechanism. A most likely naive first glance suggests one should be able to associate tfvars files with workspaces.
I am looking more like for multicloud setup where some things are spin up on own bare metal VM's, some dev envirionment on GCP and some prod env are provisioned on AWS. Or... demo env is set up on local VM's, but later transfered to the AWS. From the code organization perspective.
I spent a lot of hours to understand how things are segregating bet' workspace and folder based structure flow in terraform. After i pumped into here, got to know how simple it is. Heads up to you Will Brock. Simple and Sweet explanation. Awesome Job. Thanks a lot.
Awesome! I'm glad they were helpful
Very useful video, finally with this video i cleared my confusion about Terraform workspaces.
Thanks! Glad it was helpful
Great content Will. You cleared my confusion. Thanks
Thanks for this course bro. Its perfect for mere mortals like myself. I fully get it now.
Excellent video, very well explained
Thanks!
Thanks Will for these videos ! I finally got my head around the concept of Workspaces. Appreciate it !
Will, thanks a lot for this Terraform course. It's been very useful as I'm dealing with TF currently in my job
No problem, I'm glad it's helping out
very clearly explained - thanks for the information.
So glad someone addressed the initial confusion I had when I first was introduced to Workspace. Because I thought initially that by defining a workspace, it automatically deploys resources to different "profile" automatically on the cloud server I am working on. But that's not the case. It is more of a logical grouping with its own state file that helps manages different prod/non-prod environments GIVEN the right config.
Thanks Will very useful just learned about workspaces.
Awesome
Very good quality. Thank you.👍👍👍
Very well simply explained and much appreciated you for this wonderful video
thks will.... the best explenation i found... your great!!!!!!!!!!!!11
Glad it helped!
Thank you so much for this playlist!!! we all really appreciate it!
it was so helpful Will, thank you very much!
This was a good explanation, thanks
Curious, what if you define instance name in the dev.tfvars with a dev prefix. Same for PRD. Would you still need workspace? I guess to manage different .tfstate files?
Great Channel Will. Subscribed!
Thanks!
Excellent video will. Thankyou for this playlist. Are you planning to make a video on workspaces vs directory structure as you mentioned in the video?
nice thanks, clean example
Thanks Will for this wornderful video. But I have a question here apart from instance name which was picked based on workspace I couldn't understand what else could be the use case . If being in dev workspace you will pass prod.tfvars as argument the script will create the infra with prod configuration I beleive then what is new here ? can you pls clarify ?
This is very good. Thank you Will!
This was really good explanation of Workspaces, request you to add a video on Workspace, directory, module comparison.
One of the good tuts out there... Keep up the good work
Thank you, what is locals resource? I am not clear on that part. And one more doubt when run terraform apply with different variable files at that time only environments Got segregated and accordingly apply ?
Hi Will,
What if, In Dev Workspace, I use -var-file prod.tfvars.
this will apply the prod vars in Dev workspace. !!
if that's the case, It all depends on varfiles, rather than Workspace.
Then what is the use of differnt workspaces. - "is it maintaining different tfstate files for same config ? "
please correct me if I am wrong.
If you're in the dev workspace it won't affect anything in the prod workspace since each workspace has their own state files.
Awesome Training
Thanks
Awesome video Dude. Can we use workspace concept if we are using modules in main. tf file.
You can
Hey @Will Brock thanks for this video. Question for you - must you call the -var-file for each environment? Is there a way to add this elsewhere so it's not in the CLI. I'm trying to find use cases to use Terraform workspace over Terragrunt
Hi, yes you need to call the -var-file otherwise it won't know what variables to use. You could also set environment variables.
@@WillBrock hmmm interesting
i think the way Will Brock presented this is bound to fail.... someone will accidentally apply prod variables to dev environment. unless you set up a pipeline and no one actually runs terraform plan/apply on their terminal.
in variables.tf you could do a map like variable "testing" { default = { dev = "abc" prod = "def"}} , then you call it like var.testing[terraform.workspace].
if you want values to come from tfvars you could probably use some other technique like an if statement
You are amazing mate. Thanks for the explanation in the best possible way with the demo. Keep Up the good work. ( Just subscribed 😀 )
Thanks!
Excellent demo and explanation. Thanks so much. I have a few questions:
1) After setting up the two separate workspaces, is there still a point for the terraform.tfvars
2) how would git keep track of the workspace?
For number 1 you can still have a terraform.tfvars depending on your needs.
You would use git to keep track of the code only and not the state files. You could use git to track the state files but it's not recommend. Instead you should use a remote backend like S3 to keep track of the state.
@@WillBrock thank you for the reply. Let me put the state file to gitignore. I will also research more on remote state
@@swalkers8008 no problem. There is a video in my terraform playlist on backends if you wanted to learn more
Awesome video ! Question- How can I further break down the project into infrastructure types ? Lets say under dev --> App(a folder), database(a folder). How can I maintain separate state for apps and database under dev ?
If you want separate state for databases and app you need to create two separate configurations not in the same workspace. Depending on your needs it might make sense to keep them both in the same state files.
exactly what i was looking for. Nice intro in to terraform ive always used CF instead
So workspace allows you to have different state files for different environment . Each environment can have its own workspace hence its own state file.. right ?
when you changed instance to t2xlarge, why it didn't provision a new instance and instead changed the instance type of existing instance?
Thats how it works when you change it in the aws interface. It modifies the existing resource in place and does not destroy it.
appreciate it! so easy to understand
Glad to hear
Ok so, to summarise, workspaces is a state thing and nothing else!
Thanks sooo much!!! Need this!
Why do such amazing videos come to me so late ??? 😃
Lol thanks for the kind words
Very well-explained.
How many keyboards do you go through? You hit them keys hard! However, great video. You made it very simple to understand.
Haha, I was using the built in computer mic so it makes it sound loud.
your videos are good. i would suggest you create the course in udemy with some practice exams.
but there is a problem! When you change workspace and run "terraform plan" the existing resource that was created previously will be marked as ... "1 to change" ...
No it won't. They are isolated from each other.
Hi Will. Such an amazing teaching for terraform. Can you please make a video on how to use workspace for different account. Like sandbox and dev accounts in AWS>
how do you destroy the resources created under each workspace ? you forgot to mention that
terraform destroy just like you would do without using a workspace
@@WillBrockyou also have to add the variables when you use terraform destroy
Still waiting for workspace vs directory structure video which you mentioned in the video that you will create
Thanks for the awesome tutorials! Is it possible to have a workspace default to a .tfvars file? I find it easy to forget which workspace I'm in and apply the wrong .tfvars file. I have a dev, qa and prod.tfvars files and want to use them in my dev, qa and prod workspace respectively.
Not that I know of. I have the same problem and forget to specify the var file sometimes.
@@WillBrock Enterim solution on this could be coloring your terminal to display different colors on different environments.
you could automate the commands using a Makefile to create shortcuts.
$ make apply dev
$ make apply prod
Good work!
Will (B)Rock!
Sir pls make a video on dockers using terraform from installation to pushing image to ecr . Thanks
Thank you
Please add video on usage of data "terraform_remote_state"
Is this what you're looking for? ua-cam.com/video/RBW253A4SvY/v-deo.html
Workspaces do not seem to add a great deal of value? When you run terraform apply you select the right tfvars file yourself, and so the main use-case for a workspace, env differentiation, is handled via a different mechanism. A most likely naive first glance suggests one should be able to associate tfvars files with workspaces.
This is some good sh*t !
Thanks!
I am looking more like for multicloud setup where some things are spin up on own bare metal VM's, some dev envirionment on GCP and some prod env are provisioned on AWS. Or... demo env is set up on local VM's, but later transfered to the AWS. From the code organization perspective.
That was great, thanks.
Awsome
Please learn to type!