Workspaces | Terraform Tutorial | #16

Поділитися
Вставка
  • Опубліковано 29 лис 2024

КОМЕНТАРІ • 90

  • @RamKumar-tk2cb
    @RamKumar-tk2cb 4 роки тому

    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  4 роки тому +1

      Awesome! I'm glad they were helpful

  • @dilgamr.sharifov6652
    @dilgamr.sharifov6652 3 роки тому

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

    • @WillBrock
      @WillBrock  3 роки тому

      Thanks! Glad it was helpful

  • @Emmakungaba
    @Emmakungaba Рік тому

    Great content Will. You cleared my confusion. Thanks

  • @kaypakaipa8559
    @kaypakaipa8559 3 роки тому +1

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

  • @thelemminguk
    @thelemminguk 2 роки тому

    Excellent video, very well explained

  • @bajajrahul001
    @bajajrahul001 3 роки тому +2

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

  • @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

  • @keithsexton8962
    @keithsexton8962 2 роки тому

    very clearly explained - thanks for the information.

  • @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.

  • @ramthirumalai6870
    @ramthirumalai6870 3 роки тому

    Thanks Will very useful just learned about workspaces.

  • @virabadrasana
    @virabadrasana Рік тому

    Very good quality. Thank you.👍👍👍

  • @vijeeshvijayan9966
    @vijeeshvijayan9966 2 роки тому

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

  • @dvirpashut3023
    @dvirpashut3023 Рік тому

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

  • @felipeozoski
    @felipeozoski 3 роки тому +1

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

  • @HasanUckun
    @HasanUckun Рік тому

    it was so helpful Will, thank you very much!

  • @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?

  • @adamkeinan1535
    @adamkeinan1535 2 роки тому

    Great Channel Will. Subscribed!

  • @himanshuupadhyay3129
    @himanshuupadhyay3129 3 роки тому +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?

  • @80amnesia
    @80amnesia 2 роки тому

    nice thanks, clean example

  • @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 ?

  • @temiwale88
    @temiwale88 3 роки тому

    This is very good. Thank you Will!

  • @rakeshjha11
    @rakeshjha11 4 роки тому +1

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

  • @ujwaldhakal6004
    @ujwaldhakal6004 4 роки тому

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

  • @shyamcheekoti7216
    @shyamcheekoti7216 2 роки тому

    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 ?

  • @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.

  • @DevOps-AWS55
    @DevOps-AWS55 Рік тому

    Awesome Training

  • @mayureshpatilvlogs
    @mayureshpatilvlogs 4 роки тому +1

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

  • @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

  • @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 😀 )

  • @swalkers8008
    @swalkers8008 4 роки тому

    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  4 роки тому +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 4 роки тому

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

    • @WillBrock
      @WillBrock  4 роки тому +2

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

  • @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.

  • @production-aws6644
    @production-aws6644 3 роки тому

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

  • @wysefavor
    @wysefavor 2 роки тому

    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 ?

  • @ramithraghunath1073
    @ramithraghunath1073 3 роки тому

    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  3 роки тому +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.

  • @chandrashekhar2461
    @chandrashekhar2461 2 роки тому

    appreciate it! so easy to understand

  • @000djw000
    @000djw000 2 роки тому +1

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

  • @karenzhu6100
    @karenzhu6100 3 роки тому

    Thanks sooo much!!! Need this!

  • @fxy2933
    @fxy2933 2 роки тому

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

    • @WillBrock
      @WillBrock  2 роки тому

      Lol thanks for the kind words

  • @hamidapremani6151
    @hamidapremani6151 4 роки тому

    Very well-explained.

  • @DigitalDave65
    @DigitalDave65 4 роки тому

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

    • @WillBrock
      @WillBrock  4 роки тому +1

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

  • @thrilochanpakkapoti99
    @thrilochanpakkapoti99 Рік тому +1

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

  • @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.

  • @saeedsherani7275
    @saeedsherani7275 2 роки тому

    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>

  • @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

  • @Techtalkswithrahul
    @Techtalkswithrahul 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

  • @TheAlexdoka
    @TheAlexdoka 3 роки тому

    Good work!

  • @sahdevchauhan
    @sahdevchauhan 3 роки тому

    Will (B)Rock!

  • @desiboyz4695
    @desiboyz4695 4 роки тому

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

  • @mamun001
    @mamun001 2 роки тому

    Thank you

  • @vinodchunchuwar3660
    @vinodchunchuwar3660 4 роки тому

    Please add video on usage of data "terraform_remote_state"

    • @WillBrock
      @WillBrock  4 роки тому

      Is this what you're looking for? ua-cam.com/video/RBW253A4SvY/v-deo.html

  • @abraund
    @abraund 2 місяці тому

    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.

  • @mediatwinkleTV
    @mediatwinkleTV 3 роки тому

    This is some good sh*t !

  • @Oswee
    @Oswee 4 роки тому

    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.

  • @billtoner1960
    @billtoner1960 3 роки тому

    That was great, thanks.

  • @aravindaninfo
    @aravindaninfo 4 роки тому

    Awsome

  • @ProWannabe88
    @ProWannabe88 3 роки тому

    Please learn to type!