You are viewing documentation for version 2 of the AWS SDK for Ruby. Version 3 documentation can be found here.
Class: Aws::AppMesh::Types::CreateVirtualNodeInput
- Inherits:
-
Struct
- Object
- Struct
- Aws::AppMesh::Types::CreateVirtualNodeInput
- Defined in:
- (unknown)
Overview
When passing CreateVirtualNodeInput as input to an Aws::Client method, you can use a vanilla Hash:
{
client_token: "String",
mesh_name: "ResourceName", # required
mesh_owner: "AccountId",
spec: { # required
backend_defaults: {
client_policy: {
tls: {
enforce: false,
ports: [1],
validation: { # required
trust: { # required
acm: {
certificate_authority_arns: ["Arn"], # required
},
file: {
certificate_chain: "FilePath", # required
},
},
},
},
},
},
backends: [
{
virtual_service: {
client_policy: {
tls: {
enforce: false,
ports: [1],
validation: { # required
trust: { # required
acm: {
certificate_authority_arns: ["Arn"], # required
},
file: {
certificate_chain: "FilePath", # required
},
},
},
},
},
virtual_service_name: "ServiceName", # required
},
},
],
listeners: [
{
connection_pool: {
grpc: {
max_requests: 1, # required
},
http: {
max_connections: 1, # required
max_pending_requests: 1,
},
http2: {
max_requests: 1, # required
},
tcp: {
max_connections: 1, # required
},
},
health_check: {
healthy_threshold: 1, # required
interval_millis: 1, # required
path: "String",
port: 1,
protocol: "http", # required, accepts http, tcp, http2, grpc
timeout_millis: 1, # required
unhealthy_threshold: 1, # required
},
outlier_detection: {
base_ejection_duration: { # required
unit: "s", # accepts s, ms
value: 1,
},
interval: { # required
unit: "s", # accepts s, ms
value: 1,
},
max_ejection_percent: 1, # required
max_server_errors: 1, # required
},
port_mapping: { # required
port: 1, # required
protocol: "http", # required, accepts http, tcp, http2, grpc
},
timeout: {
grpc: {
idle: {
unit: "s", # accepts s, ms
value: 1,
},
per_request: {
unit: "s", # accepts s, ms
value: 1,
},
},
http: {
idle: {
unit: "s", # accepts s, ms
value: 1,
},
per_request: {
unit: "s", # accepts s, ms
value: 1,
},
},
http2: {
idle: {
unit: "s", # accepts s, ms
value: 1,
},
per_request: {
unit: "s", # accepts s, ms
value: 1,
},
},
tcp: {
idle: {
unit: "s", # accepts s, ms
value: 1,
},
},
},
tls: {
certificate: { # required
acm: {
certificate_arn: "Arn", # required
},
file: {
certificate_chain: "FilePath", # required
private_key: "FilePath", # required
},
},
mode: "STRICT", # required, accepts STRICT, PERMISSIVE, DISABLED
},
},
],
logging: {
access_log: {
file: {
path: "FilePath", # required
},
},
},
service_discovery: {
aws_cloud_map: {
attributes: [
{
key: "AwsCloudMapInstanceAttributeKey", # required
value: "AwsCloudMapInstanceAttributeValue", # required
},
],
namespace_name: "AwsCloudMapName", # required
service_name: "AwsCloudMapName", # required
},
dns: {
hostname: "Hostname", # required
},
},
},
tags: [
{
key: "TagKey", # required
value: "TagValue", # required
},
],
virtual_node_name: "ResourceName", # required
}
Instance Attribute Summary collapse
-
#client_token ⇒ String
Unique, case-sensitive identifier that you provide to ensure the idempotency of the request.
-
#mesh_name ⇒ String
The name of the service mesh to create the virtual node in.
-
#mesh_owner ⇒ String
The AWS IAM account ID of the service mesh owner.
-
#spec ⇒ Types::VirtualNodeSpec
The virtual node specification to apply.
-
#tags ⇒ Array<Types::TagRef>
Optional metadata that you can apply to the virtual node to assist with categorization and organization.
-
#virtual_node_name ⇒ String
The name to use for the virtual node.
Instance Attribute Details
#client_token ⇒ String
Unique, case-sensitive identifier that you provide to ensure the idempotency of the request. Up to 36 letters, numbers, hyphens, and underscores are allowed.
#mesh_name ⇒ String
The name of the service mesh to create the virtual node in.
#mesh_owner ⇒ String
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.
#spec ⇒ Types::VirtualNodeSpec
The virtual node specification to apply.
#tags ⇒ Array<Types::TagRef>
Optional metadata that you can apply to the virtual node 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.
#virtual_node_name ⇒ String
The name to use for the virtual node.