Terraformを使って1円クラウド、DigitalOceanにドロップレットをさくっと立ててみます。Vagrantに似たツールではありますが、Vagrantよりシンプルでかつ軽量に動作します。
$ terraform version
Terraform v0.6.14
上記のバージョンの terraform を使っていきます。
terraformファイル、例えばtest.tf
ファイルを下記のように作成します(.tf
という拡張子でファイル名はなんでもよいようです)。
# Configure the DigitalOcean Provider
provider "digitalocean" {
token = "your_digitalocean_token"
}
# Create a web server
resource "digitalocean_droplet" "web" {
image = "ubuntu-14-04-x64"
name = "web-1"
region = "sfo1"
size = "512mb"
ssh_keys = [123456]
}
token
にはDigitalOceanのあなた自身のトークンをセットしてください。
ちなみに上記にある ssh_keys
の id は下記のようにAPI経由で取得できます(jqを使ってます)。
$ curl "https://api.digitalocean.com/v2/account/keys" -H "Authorization: Bearer your_token" | jq ".ssh_keys[0].id"
terraform plan
で実行プランを表示できます。これで何が作成されるかを確認しましょう。
$ terraform plan
Refreshing Terraform state prior to plan...
The Terraform execution plan has been generated and is shown below.
Resources are shown in alphabetical order for quick scanning. Green resources
will be created (or destroyed and then created if an existing resource
exists), yellow resources are being changed in-place, and red resources
will be destroyed.
Note: You didn't specify an "-out" parameter to save this plan, so when
"apply" is called, Terraform can't guarantee this is what will execute.
+ digitalocean_droplet.web
image: "" => "ubuntu-14-04-x64"
ipv4_address: "" => "<computed>"
ipv4_address_private: "" => "<computed>"
ipv6_address: "" => "<computed>"
ipv6_address_private: "" => "<computed>"
locked: "" => "<computed>"
name: "" => "web-1"
region: "" => "sfo1"
size: "" => "512mb"
ssh_keys.#: "" => "1"
ssh_keys.0: "" => "123456"
status: "" => "<computed>"
Plan: 1 to add, 0 to change, 0 to destroy.
確認後はterraform apply
で実際に作成を行えます。
$ terraform apply
digitalocean_droplet.web: Creating...
image: "" => "ubuntu-14-04-x64"
ipv4_address: "" => "<computed>"
ipv4_address_private: "" => "<computed>"
ipv6_address: "" => "<computed>"
ipv6_address_private: "" => "<computed>"
locked: "" => "<computed>"
name: "" => "web-1"
region: "" => "sfo1"
size: "" => "512mb"
ssh_keys.#: "" => "1"
ssh_keys.0: "" => "123456"
status: "" => "<computed>"
digitalocean_droplet.web: Creation complete
Apply complete! Resources: 1 added, 0 changed, 0 destroyed.
The state of your infrastructure has been saved to the path
below. This state is required to modify and destroy your
infrastructure, so keep it safe. To inspect the complete state
use the `terraform show` command.
State path: terraform.tfstate
terraform show
で作成物の情報を表示できます。
$ terraform show
digitalocean_droplet.web:
id = 12808253
image = ubuntu-14-04-x64
ipv4_address = 1.2.3.4
locked = false
name = web-1
region = sfo1
size = 512mb
ssh_keys.# = 1
ssh_keys.0 = 123456
status = active
確かにできあがってます。
ほっとくとどんどん課金されていきますので使い終わったら削除しましょう。
$ terraform destroy
Do you really want to destroy?
Terraform will delete all your managed infrastructure.
There is no undo. Only 'yes' will be accepted to confirm.
Enter a value: yes
digitalocean_droplet.web: Refreshing state... (ID: 12808253)
digitalocean_droplet.web: Destroying...
digitalocean_droplet.web: Destruction complete
Apply complete! Resources: 0 added, 0 changed, 1 destroyed.
この記事を気に入っていただけたなら下記のリファラルリンクよりDigital Oceanにご登録いただけますと筆者が喜びます(*´ω`*)