Workspaces | Terraform Tutorial | #16

แชร์
ฝัง
  • เผยแพร่เมื่อ 4 ส.ค. 2024
  • Workspaces allow the use of the same configuration but having separate state backends for each workspace. One use case is having production and dev workspaces. This allows the same setup for both environments but each with their own state. When working in the dev workspace you can ensure that you are only modifying that infrastructure and not production. This is great for testing changes without affecting other environments.
    In this video tutorial I'll create a couple examples of working with dev and production workspaces in Terraform.
    - Use the CLI to create, update, switch, list, show and delete workspaces
    - Use dev.tfvars and prod.tfvars files to set different variables depending on the workspace
    - Examine the different state between workspaces
    - Access the current workspace in config files with terraform.workspace
    Course Examples:
    github.com/WillBrock/terrafor...
    Documentation:
    www.terraform.io/docs/state/w...
  • วิทยาศาสตร์และเทคโนโลยี

ความคิดเห็น • 89

  • @bajajrahul001
    @bajajrahul001 3 ปีที่แล้ว +2

    Thanks Will for these videos ! I finally got my head around the concept of Workspaces. Appreciate it !

  • @felipeozoski
    @felipeozoski 3 ปีที่แล้ว +1

    Thank you so much for this playlist!!! we all really appreciate it!

  • @kaypakaipa8559
    @kaypakaipa8559 3 ปีที่แล้ว +1

    Thanks for this course bro. Its perfect for mere mortals like myself. I fully get it now.

  • @ujwaldhakal6004
    @ujwaldhakal6004 3 ปีที่แล้ว

    One of the good tuts out there... Keep up the good work

  • @RamKumar-tk2cb
    @RamKumar-tk2cb 3 ปีที่แล้ว

    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.

    • @WillBrock
      @WillBrock  3 ปีที่แล้ว +1

      Awesome! I'm glad they were helpful

  • @temiwale88
    @temiwale88 3 ปีที่แล้ว

    This is very good. Thank you Will!

  • @vijeeshvijayan9966
    @vijeeshvijayan9966 2 ปีที่แล้ว

    Very well simply explained and much appreciated you for this wonderful video

  • @keithsexton8962
    @keithsexton8962 2 ปีที่แล้ว

    very clearly explained - thanks for the information.

  • @hamidapremani6151
    @hamidapremani6151 3 ปีที่แล้ว

    Very well-explained.

  • @gihanmahmoud5651
    @gihanmahmoud5651 3 ปีที่แล้ว +1

    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.

  • @virabadrasana
    @virabadrasana 10 หลายเดือนก่อน

    Very good quality. Thank you.👍👍👍

  • @user-tw9me4hl4v
    @user-tw9me4hl4v ปีที่แล้ว

    Great content Will. You cleared my confusion. Thanks

  • @rakeshjha11
    @rakeshjha11 4 ปีที่แล้ว +1

    This was really good explanation of Workspaces, request you to add a video on Workspace, directory, module comparison.

  • @80amnesia
    @80amnesia 2 ปีที่แล้ว

    nice thanks, clean example

  • @thumpanekolla2661
    @thumpanekolla2661 2 ปีที่แล้ว

    You are amazing mate. Thanks for the explanation in the best possible way with the demo. Keep Up the good work. ( Just subscribed 😀 )

  • @HasanUckun
    @HasanUckun ปีที่แล้ว

    it was so helpful Will, thank you very much!

  • @dilgamr.sharifov6652
    @dilgamr.sharifov6652 2 ปีที่แล้ว

    Very useful video, finally with this video i cleared my confusion about Terraform workspaces.

    • @WillBrock
      @WillBrock  2 ปีที่แล้ว

      Thanks! Glad it was helpful

  • @karenzhu6100
    @karenzhu6100 3 ปีที่แล้ว

    Thanks sooo much!!! Need this!

  • @TheAlexdoka
    @TheAlexdoka 3 ปีที่แล้ว

    Good work!

  • @thelemminguk
    @thelemminguk ปีที่แล้ว

    Excellent video, very well explained

  • @production-aws6644
    @production-aws6644 3 ปีที่แล้ว

    exactly what i was looking for. Nice intro in to terraform ive always used CF instead

  • @himanshuupadhyay3129
    @himanshuupadhyay3129 2 ปีที่แล้ว +2

    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?

  • @adamkeinan1535
    @adamkeinan1535 2 ปีที่แล้ว

    Great Channel Will. Subscribed!

  • @ramthirumalai6870
    @ramthirumalai6870 2 ปีที่แล้ว

    Thanks Will very useful just learned about workspaces.

  • @chandrashekhar2461
    @chandrashekhar2461 2 ปีที่แล้ว

    appreciate it! so easy to understand

    • @WillBrock
      @WillBrock  2 ปีที่แล้ว

      Glad to hear

  • @DevOps-AWS55
    @DevOps-AWS55 ปีที่แล้ว

    Awesome Training

  • @dvirpashut3023
    @dvirpashut3023 ปีที่แล้ว

    thks will.... the best explenation i found... your great!!!!!!!!!!!!11

    • @WillBrock
      @WillBrock  ปีที่แล้ว

      Glad it helped!

  • @sahdevchauhan
    @sahdevchauhan 3 ปีที่แล้ว

    Will (B)Rock!

  • @saeedsherani7275
    @saeedsherani7275 ปีที่แล้ว

    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>

  • @mamun001
    @mamun001 ปีที่แล้ว

    Thank you

  • @azy22222
    @azy22222 4 ปีที่แล้ว +1

    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

    • @WillBrock
      @WillBrock  4 ปีที่แล้ว

      Hi, yes you need to call the -var-file otherwise it won't know what variables to use. You could also set environment variables.

    • @azy22222
      @azy22222 4 ปีที่แล้ว

      @@WillBrock hmmm interesting

    • @erikwhitesides
      @erikwhitesides 3 ปีที่แล้ว +1

      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

  • @aravindaninfo
    @aravindaninfo 4 ปีที่แล้ว

    Awsome

  • @AvinashReddy21
    @AvinashReddy21 4 ปีที่แล้ว +1

    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 ?

    • @WillBrock
      @WillBrock  4 ปีที่แล้ว

      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.

  • @rajivnayanverma6822
    @rajivnayanverma6822 ปีที่แล้ว

    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 ?

  • @abettertomorrow4311
    @abettertomorrow4311 ปีที่แล้ว

    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?

  • @mayureshpatilvlogs
    @mayureshpatilvlogs 3 ปีที่แล้ว +1

    Awesome video Dude. Can we use workspace concept if we are using modules in main. tf file.

  • @shyamcheekoti7216
    @shyamcheekoti7216 ปีที่แล้ว

    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 ?

  • @DigitalDave65
    @DigitalDave65 3 ปีที่แล้ว

    How many keyboards do you go through? You hit them keys hard! However, great video. You made it very simple to understand.

    • @WillBrock
      @WillBrock  3 ปีที่แล้ว +1

      Haha, I was using the built in computer mic so it makes it sound loud.

  • @swalkers8008
    @swalkers8008 3 ปีที่แล้ว

    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?

    • @WillBrock
      @WillBrock  3 ปีที่แล้ว +1

      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.

    • @swalkers8008
      @swalkers8008 3 ปีที่แล้ว

      @@WillBrock thank you for the reply. Let me put the state file to gitignore. I will also research more on remote state

    • @WillBrock
      @WillBrock  3 ปีที่แล้ว +2

      @@swalkers8008 no problem. There is a video in my terraform playlist on backends if you wanted to learn more

  • @fxy2933
    @fxy2933 2 ปีที่แล้ว

    Why do such amazing videos come to me so late ??? 😃

    • @WillBrock
      @WillBrock  2 ปีที่แล้ว

      Lol thanks for the kind words

  • @nitishgavankar9666
    @nitishgavankar9666 3 ปีที่แล้ว +1

    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.

    • @WillBrock
      @WillBrock  3 ปีที่แล้ว +1

      If you're in the dev workspace it won't affect anything in the prod workspace since each workspace has their own state files.

  • @greattobehere
    @greattobehere 3 ปีที่แล้ว

    Still waiting for workspace vs directory structure video which you mentioned in the video that you will create

  • @matthewwarner1633
    @matthewwarner1633 3 ปีที่แล้ว

    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.

    • @WillBrock
      @WillBrock  3 ปีที่แล้ว

      Not that I know of. I have the same problem and forget to specify the var file sometimes.

    • @njabulongwenyama
      @njabulongwenyama 3 ปีที่แล้ว

      ​@@WillBrock Enterim solution on this could be coloring your terminal to display different colors on different environments.

    • @stockrt
      @stockrt 2 ปีที่แล้ว

      you could automate the commands using a Makefile to create shortcuts.
      $ make apply dev
      $ make apply prod

  • @desiboyz4695
    @desiboyz4695 3 ปีที่แล้ว

    Sir pls make a video on dockers using terraform from installation to pushing image to ecr . Thanks

  • @mediatwinkleTV
    @mediatwinkleTV 3 ปีที่แล้ว

    This is some good sh*t !

  • @billtoner1960
    @billtoner1960 3 ปีที่แล้ว

    That was great, thanks.

  • @000djw000
    @000djw000 2 ปีที่แล้ว +1

    Ok so, to summarise, workspaces is a state thing and nothing else!

  • @thrilochanpakkapoti99
    @thrilochanpakkapoti99 ปีที่แล้ว +1

    your videos are good. i would suggest you create the course in udemy with some practice exams.

  • @ramithraghunath1073
    @ramithraghunath1073 2 ปีที่แล้ว

    when you changed instance to t2xlarge, why it didn't provision a new instance and instead changed the instance type of existing instance?

    • @WillBrock
      @WillBrock  2 ปีที่แล้ว +1

      Thats how it works when you change it in the aws interface. It modifies the existing resource in place and does not destroy it.

  • @wysefavor
    @wysefavor ปีที่แล้ว

    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 ?

  • @ThiagoTorresFaioli
    @ThiagoTorresFaioli 3 ปีที่แล้ว

    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" ...

    • @WillBrock
      @WillBrock  3 ปีที่แล้ว

      No it won't. They are isolated from each other.

  • @vinodchunchuwar3660
    @vinodchunchuwar3660 3 ปีที่แล้ว

    Please add video on usage of data "terraform_remote_state"

    • @WillBrock
      @WillBrock  3 ปีที่แล้ว

      Is this what you're looking for? th-cam.com/video/RBW253A4SvY/w-d-xo.html

  • @Ronnie9P
    @Ronnie9P 2 ปีที่แล้ว +1

    how do you destroy the resources created under each workspace ? you forgot to mention that

    • @WillBrock
      @WillBrock  2 ปีที่แล้ว

      terraform destroy just like you would do without using a workspace

    • @Ronnie9P
      @Ronnie9P 2 ปีที่แล้ว +1

      @@WillBrockyou also have to add the variables when you use terraform destroy

  • @Oswee
    @Oswee 3 ปีที่แล้ว

    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.

  • @ProWannabe88
    @ProWannabe88 3 ปีที่แล้ว

    Please learn to type!

  • @welingtonws
    @welingtonws 2 ปีที่แล้ว

    Will, thanks a lot for this Terraform course. It's been very useful as I'm dealing with TF currently in my job

    • @WillBrock
      @WillBrock  2 ปีที่แล้ว

      No problem, I'm glad it's helping out