1
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Pulumiの気になること調べてみた

Last updated at Posted at 2024-01-01

これは何?

インフラ構成管理ツールといえば、Terraformや、AWSならCloudFormation, CDKなどが現在一般的かと思います。
その他では、Pulumiも一時期話題になっていました。最近では2023年8月、Terraformの開発元であるHashicorp社からライセンス変更のアナウンスがあり、その影響でPulumiにも関心が集まりました。

ex: https://zenn.dev/the_exile/articles/b90fe8c5c41694

ご多分に漏れず、自分もPulumiが気になったため、個人的に気になったことをいくつか調査検証してみました。
本記事はそれを書いたものです。

要約

  • ドリフト検出(コードと実体の差分検出)は可能。ただterraformより少し面倒。
  • 無料枠はterraformより少し狭い。ただ小さいプロジェクトなら無料範囲内で十分導入できそう。
  • Pulumi AIは賢くなれば結構便利そうだけど、今のところ使用感は微妙。

Pulumiについて

Pulumiの概要については、他に優れた記事がたくさんあるため、この記事ではすごくさらっと説明します。

Pulumiは、TerraformCloudFormationのような独自言語を使用せずとも、TypescriptやGo, Cなど幅広い言語で書くことができ、開発者フレンドリーな構成管理ツールという特徴があります。

また、AWS CDKはAWS限定ですが、Pulumiはそれに限らず様々なプロバイダ(GCP, Azure, K8s, その他クラウドに限らず色々)をサポートしていることも特徴的です。

それでは早速、以下本題です。

気になること1: ドリフト検出

ドリフト検出とは、CloudFormationでよく使われている表現な気がしますが、
構成管理コードから作成したインフラに対し、マネジメントコンソールやCLIなど、コード以外から手動変更した際に、コード側が実リソースとの差分を検出してくれるかどうか
という認識です。

自分が現在terraformユーザなこともあり、個人的にここは検出してほしいと強く感じるところです。
terraformでは、$ terraform planapply実行時にドリフトを自動検出してくれるため、apply時に意図しない変更を上書きする危険がないです。

ドリフト検出はPulumiでも可能なのでしょうか?

検証

実際に試してみます。
今回は、ライフサイクルルールを設定したS3バケットを作成して検証しました。

Pulumi.yaml
name: quickstart
runtime: yaml
description: Test

resources:
  my-bucket:
    type: aws:s3:Bucket
    properties:
      lifecycleRules:
        - enabled: true
          expiration:
            days: 90
          id: test-rule
          prefix: log/
          tags:
            autoclean: 'true'
            rule: log
          transitions:
            - days: 30
              storageClass: STANDARD_IA
            - days: 60
              storageClass: GLACIER

まずこちらを$ pulumi upします。

その後、デプロイされたバケットのライフサイクルルールを、AWSマネジメントコンソール上から修正してみます。
今回は、ライフサイクルルールの中身を変更しました(STANDARD_IAへの移行を30日から50日に、Glacierへの移行を60日から80日に変更)

image.png

その後 $ pulumi preview(terraformでいうplan的な)をしてみましたが、unchangedと出て、実体との差分は検出されませんでした。(pulumi upでも同様でした)
image.png

それでは、Pulumiではドリフト検出は不可能なのでしょうか?
調べてみたところ、検出方法は用意されているようでした。

pulumi refreshによる検出

$ pulumi refreshというコマンドによりドリフト検出ができました、
refreshとは、PlumiのStateと実リソースの同期を行うコマンドのようです。

実行したところ、terrformのように詳細には表示されませんが、どこに差分があるかが出力されました。
image.png

このあと、Do you want to perform this refresh?と聞かれるのでyesと入力すると、Stateが更新されました。

この状態で再度、$ pulumi previewしたところ、実体との差分が表示されるようになりました。
※ 正確には、コードとStateの差分という認識が正しいです。
image.png

また、$ pulumi up --diffで詳細な差分を表示してくれました。
実運用ではこちらのコマンドのほうが役立ちそうです。
(ちなみに$ pulumi updetailsオプション選択でも、同じように詳細表示されます)
image.png

結論、ドリフト検知方法はあるが、$ pulumi refresh$ pulumi up --diffの2段が必要なため、terraformより少し面倒という所感でした。

気になること2: 無料枠の範囲

Pulumi, terraformいずれもオープンソースであるため、個人でのツール利用自体は無料です。
ただし、チーム規模が大きくなってきて、権限管理・承認ステップつきのデプロイ・変更履歴管理など、最適な制御を行いたくなるケースが多いと思います。そんな時は、それぞれの専用Cloudを利用します。

Pricingの公式ページ

各クラウドの機能にも少しずつ違いがあるため単純な比較はできませんが、2023年12月現在で無料利用できる範囲だと、下記の通りでした。

リソース数 ユーザ数
terraform cloud 500以下 制限なし
pulumi cloud 約210以下 10人以下

※ pulumi cloudのリソース数は、Teamプランの150k無料クレジットで計算しました。

image.png

もともとterraform cloudはFreeプランの制限が、ユーザ数5人上限でした。しかし2023年5月にリソース数500に変更となり、ユーザ数制限は撤廃されました。

そのため、リソース数・ユーザ数だけの視点でみるとpulumiの方が上限は厳しく、terraform cloudの方が気軽に導入できる印象です。

気になること3: Pulumi AI

構成管理ツールの中でも、Pulumiで特徴的なのは「Pulumi AI」の存在だと思います。
これは、自然言語からインフラのコードを自動生成するサービスです。

Pulumi AIは2023年4月に、AIを活用した新サービス群「Pulumi Insights」のひとつとしてPulumi社より発表されました。

すでに色々な記事でも述べられていますが、どのような使用感なのか体感したいと思い、実際に試してみました。

↑のページにアクセスし、画面下側の四角の枠に、言語と作りたいインフラ構成を入力します。
注意点なのが、日本語での入力できず、英語に翻訳する必要があります。自分は今回はGoogle翻訳で英語に訳して入力しました。

image.png

Lambdaなど簡単なサーバーレス構成でも全然良かったのですが、ちょっと味気なかったのでEKSクラスタとそれを配置するVPC, サブネットを書いてもらいました。

言語はyamlを指定し、インフラ構成を英文入力すると、コードを自動生成されました。

Pasted Graphic.png

これをそのままコピペして、$ pulumi upしたところ、エラーが出てデプロイできませんでした。

Pasted Graphic 2.png

出てきたエラー文を、Pulumi AIにコピペして入力すると、修正したコードを提示してくれました。
ここでは、他リソースやoutputsで参照するプロパティ名が、Pulumiでサポートされていないものだったようです。
Pasted Graphic 3.png

以後省略しますが、これを再度pulumi upしてもエラーとなり、そのエラーメッセージからPulumi AIに修正を提示してもらい、、ということが3回ほど続きようやくデプロイできました。

リージョン指定やネットワークの要件など全くしていなかったのでこちらのプロンプトも雑すぎたと反省しつつ、
AI側も存在しないプロパティを提示してきたりした(pulumiのコード仕様も最近で大きく変わっているため?)ので、現時点では使用感は微妙でした
複雑な構成であれば、最初からドキュメント見ながら書いたほうが早いかもしれません。

これから徐々にサービスが安定版に入っていき、ユーザ数も増えていけば、より正確なコードを返してくれるようになると期待しています。

最後に

最近個人的に気になっていたPulumiについて、調べてみました。今回手を動かして検証したので、他ツールとの使用感の違いを体感できてよかったです。

ツールごとに設計思想が違うので単純比較できませんが、だからこそPulumiが今後成長していき、プロジェクトの特性に応じてterraform等との使い分けができるようになったりすると面白いなと思います。

参考

1
3
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?