0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

aliyun CLI チートシート(jmespath)

Posted at

はじめに

CLIで取得した情報を整理して表示したいということは運用をしていればたまーに必要になることがあると思います。目的はいろいろあると思いますが、個人的に業務で使って便利だったものを備忘録として載せておきます。ここに記載せれているもの以上に他にもさまざまなオプションや活用方法があるので気が向いた時に加筆していこうと思います。

前提

執筆時のクライアントバージョンは3.0.127

 $ aliyun version
3.0.127

出力の制御

基本

普通にコマンドを入力するとJson形式で全ての情報が出力されます。

$ aliyun ecs DescribeInstances
{
	"Instances": {
		"Instance": [
			{
				"AutoReleaseTime": "",
				"ClusterId": "",
				"Cpu": 8,
				"CpuOptions": {
					"CoreCount": 4,
					"Numa": "",
					"ThreadsPerCore": 2
				},
				"CreationTime": "2022-11-30T08:19Z",
				"CreditSpecification": "",
				"DedicatedHostAttribute": {
					"DedicatedHostClusterId": "",
					"DedicatedHostId": "",
					"DedicatedHostName": ""
				},
				"DedicatedInstanceAttribute": {
					"Affinity": "",
					"Tenancy": ""
				},
				"DeletionProtection": false,
				"DeploymentSetId": "",
				"Description": "ESS",
				"DeviceAvailable": true,
				"EcsCapacityReservationAttr": {
					"CapacityReservationId": "",
					"CapacityReservationPreference": ""
				},
				以下略

--outputオプション + cols

---outionもしくは-oをコマンドにつけると、必要な出力のみを表示させることが可能。
-o指定時に同時に必須となるcolsで制御する。
出力例は以下の通り

$ aliyun ecs DescribeInstances -o cols=Instances.Instance[0].InstanceName
Instances.Instance[0].InstanceName
----------------------------------
instance01

コマンドの出力にたいして表示したい値にcolsでアクセスができる。結果はcolsが列名となる表形式で表示される。

複数取得することも可能。

$ aliyun ecs DescribeInstances -o cols=Instances.Instance[0].InstanceName,Instances.Instance[0].Status
Instances.Instance[0].InstanceName | Instances.Instance[0].Status
---------------------------------- | ----------------------------
instance01                         | Running

でもこれでは記述は冗長な割に、表示量はすくなり。なんならインスタンス全ての情報が欲しい。みたいなことはよくあること。そこで使うのがrows(jmespath)

--option + cols + rows

さまざまなCLIでも利用されるjmespathですが、aliyunでも利用可能です。これによって、より自由な出力取得が可能。例えば上記と同じ結果を取得する場合はこう書きます。

落とし穴
rowsの条件は全体をダブルコーテーションで囲み、中で使われる文字列をシングルコーテーションで囲みます。どちらか一つしか使わない場合はこの限りではありません。

$ aliyun ecs DescribeInstances -o cols=InstanceName,Status rows='Instances.Instance[]'
InstanceName  | Status
------------  | ------
instance01    | Running
instance02    | Running
instance03    | Stopped
(以下略)

簡単に解説すると、rowsで出力を絞り込みます。その中で表示したい要素をcolsで指定して出力します。条件を追加することもできます。

条件付き出力

  • 条件と等しいものを出力
$ aliyun ecs DescribeInstances -o cols=InstanceName,Status rows="Instances.Instance[?Status == 'Running']"
InstanceName  | Status
------------  | ------
instance01    | Running
instance02    | Running
(以下略)
  • ある文字列を含むものを出力
$ aliyun ecs DescribeInstances -o cols=InstanceName,Status 
rows="Instances.Instance[?contains(Status, 'Run')]"
InstanceName  | Status
------------  | ------
instance01    | Running
instance02    | Running
(以下略)

ネストの深さが違う値をまとめて表示したい

欲しい情報を集めたオブジェクトを作り、それをcolsで指定して表示する。

$ aliyun ecs DescribeInstances --output cols=InstanceName,Status,IpAddress rows="Instances.Instance[].{InstanceName: InstanceName, Status: Status, IpAddress: VpcAtIpAddress.IpAddress[0]}"
InstanceName  | Status  | IpAddress
------------  | ------  | ---------
instance01    | Running | 10.2.15.116
instance02    | Running | 10.2.0.6
instance03    | Stopped | 10.2.7.252

今回はここまで。

0
0
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
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?