AWS::AppMesh::VirtualRouter - AWS CloudFormation

AWS::AppMesh::VirtualRouter

Creates a virtual router within a service mesh.

Specify a listener for any inbound traffic that your virtual router receives. Create a virtual router for each protocol and port that you need to route. Virtual routers handle traffic for one or more virtual services within your mesh. After you create your virtual router, create and associate routes for your virtual router that direct incoming requests to different virtual nodes.

For more information about virtual routers, see Virtual routers.

Syntax

To declare this entity in your AWS CloudFormation template, use the following syntax:

JSON

{ "Type" : "AWS::AppMesh::VirtualRouter", "Properties" : { "MeshName" : String, "MeshOwner" : String, "Spec" : VirtualRouterSpec, "Tags" : [ Tag, ... ], "VirtualRouterName" : String } }

YAML

Type: AWS::AppMesh::VirtualRouter Properties: MeshName: String MeshOwner: String Spec: VirtualRouterSpec Tags: - Tag VirtualRouterName: String

Properties

MeshName

The name of the service mesh to create the virtual router in.

Required: Yes

Type: String

Minimum: 1

Maximum: 255

Update requires: Replacement

MeshOwner

The AWS IAM account ID of the service mesh owner. If the account ID is not your own, then the account that you specify must share the mesh with your account before you can create the resource in the service mesh. For more information about mesh sharing, see Working with shared meshes.

Required: No

Type: String

Minimum: 12

Maximum: 12

Update requires: Replacement

Spec

The virtual router specification to apply.

Required: Yes

Type: VirtualRouterSpec

Update requires: No interruption

Tags

Optional metadata that you can apply to the virtual router to assist with categorization and organization. Each tag consists of a key and an optional value, both of which you define. Tag keys can have a maximum character length of 128 characters, and tag values can have a maximum length of 256 characters.

Required: No

Type: Array of Tag

Minimum: 0

Maximum: 50

Update requires: No interruption

VirtualRouterName

The name to use for the virtual router.

Required: No

Type: String

Minimum: 1

Maximum: 255

Update requires: Replacement

Return values

Ref

When you pass the logical ID of this resource to the intrinsic Ref function, Ref returns the resource ARN. For example:

{ "Ref": "myVirtualRouter" }

When you pass the logical ID of an AWS::AppMesh::VirtualRouter resource to the intrinsic Ref function, the function returns the virtual router ARN, such as arn:aws:appmesh:us-east-1:555555555555:virtualRouter/myVirtualRouter .

For more information about using the Ref function, see Ref.

Fn::GetAtt

The Fn::GetAtt intrinsic function returns a value for a specified attribute of this type. The following are the available attributes and sample return values.

For more information about using the Fn::GetAtt intrinsic function, see Fn::GetAtt.

Arn

The full Amazon Resource Name (ARN) for the virtual router.

MeshName

The name of the service mesh that the virtual router resides in.

MeshOwner

The AWS IAM account ID of the service mesh owner. If the account ID is not your own, then it's the ID of the account that shared the mesh with your account. For more information about mesh sharing, see Working with Shared Meshes.

ResourceOwner

The AWS IAM account ID of the resource owner. If the account ID is not your own, then it's the ID of the mesh owner or of another account that the mesh is shared with. For more information about mesh sharing, see Working with Shared Meshes.

Uid

The unique identifier for the virtual router.

VirtualRouterName

The name of the virtual router.

Examples

Create a Virtual Router

This example creates a basic virtual router with an HTTP port mapping and two tags.

JSON

{ "Description": "Basic Test Virtual Router", "Resources": { "BasicVirtualRouter": { "Type": "AWS::AppMesh::VirtualRouter", "Properties": { "VirtualRouterName": "TestVirtualRouter", "MeshName": null, "Spec": { "Listeners": [ { "PortMapping": { "Port": 8080, "Protocol": "http" } } ] }, "Tags": [ { "Key": "Key1", "Value": "Value1" }, { "Key": "Key2", "Value": "Value2" } ] } } }, "Outputs": { "VirtualRouterName": { "Description": "Name of the VirtualRouter", "Value": { "Fn::GetAtt": [ "BasicVirtualRouter", "VirtualRouterName" ] } }, "MeshName": { "Description": "Name of the Mesh", "Value": { "Fn::GetAtt": [ "BasicVirtualRouter", "MeshName" ] } }, "Arn": { "Description": "Arn of the VirtualRouter created", "Value": { "Fn::GetAtt": [ "BasicVirtualRouter", "Arn" ] } }, "Uid": { "Description": "Uid of the VirtualRouter created", "Value": { "Fn::GetAtt": [ "BasicVirtualRouter", "Uid" ] } } } }

YAML

Description: Basic Test Virtual Router Resources: BasicVirtualRouter: Type: AWS::AppMesh::VirtualRouter Properties: VirtualRouterName: TestVirtualRouter MeshName: Spec: Listeners: - PortMapping: Port: 8080 Protocol: http Tags: - Key: Key1 Value: Value1 - Key: Key2 Value: Value2 Outputs: VirtualRouterName: Description: Name of the VirtualRouter Value: Fn::GetAtt: - BasicVirtualRouter - VirtualRouterName MeshName: Description: Name of the Mesh Value: Fn::GetAtt: - BasicVirtualRouter - MeshName Arn: Description: Arn of the VirtualRouter created Value: Fn::GetAtt: - BasicVirtualRouter - Arn Uid: Description: Uid of the VirtualRouter created Value: Fn::GetAtt: - BasicVirtualRouter - Uid

See also