workgroups
Creates, updates, deletes or gets a workgroup resource or lists workgroups in a region
Overview
| Name | workgroups |
| Type | Resource |
| Description | Definition of AWS::RedshiftServerless::Workgroup Resource Type |
| Id | awscc.redshiftserverless.workgroups |
Fields
| Name | Datatype | Description |
|---|---|---|
workgroup_name | string | The name of the workgroup. |
namespace_name | string | The namespace the workgroup is associated with. |
base_capacity | integer | The base compute capacity of the workgroup in Redshift Processing Units (RPUs). |
max_capacity | integer | The max compute capacity of the workgroup in Redshift Processing Units (RPUs). |
enhanced_vpc_routing | boolean | The value that specifies whether to enable enhanced virtual private cloud (VPC) routing, which forces Amazon Redshift Serverless to route traffic through your VPC. |
config_parameters | array | A list of parameters to set for finer control over a database. Available options are datestyle, enable_user_activity_logging, query_group, search_path, max_query_execution_time, and require_ssl. |
security_group_ids | array | A list of security group IDs to associate with the workgroup. |
subnet_ids | array | A list of subnet IDs the workgroup is associated with. |
publicly_accessible | boolean | A value that specifies whether the workgroup can be accessible from a public network. |
port | integer | The custom port to use when connecting to a workgroup. Valid port ranges are 5431-5455 and 8191-8215. The default is 5439. |
price_performance_target | object | A property that represents the price performance target settings for the workgroup. |
snapshot_arn | string | The Amazon Resource Name (ARN) of the snapshot to restore from. |
snapshot_name | string | The snapshot name to restore from. |
snapshot_owner_account | string | The Amazon Web Services account that owns the snapshot. |
recovery_point_id | string | The recovery point id to restore from. |
tags | array | The map of the key-value pairs used to tag the workgroup. |
track_name | string | |
workgroup | object | Definition for workgroup resource |
region | string | AWS region. |
For more information, see AWS::RedshiftServerless::Workgroup.
Methods
| Name | Accessible by | Required Params |
|---|---|---|
create_resource | INSERT | WorkgroupName, region |
delete_resource | DELETE | data__Identifier, region |
update_resource | UPDATE | data__Identifier, data__PatchDocument, region |
list_resources | SELECT | region |
get_resource | SELECT | data__Identifier, region |
SELECT examples
Gets all properties from an individual workgroup.
SELECT
region,
workgroup_name,
namespace_name,
base_capacity,
max_capacity,
enhanced_vpc_routing,
config_parameters,
security_group_ids,
subnet_ids,
publicly_accessible,
port,
price_performance_target,
snapshot_arn,
snapshot_name,
snapshot_owner_account,
recovery_point_id,
tags,
track_name,
workgroup
FROM awscc.redshiftserverless.workgroups
WHERE region = 'us-east-1' AND data__Identifier = '<WorkgroupName>';
INSERT example
Use the following StackQL query and manifest file to create a new workgroup resource, using stack-deploy.
- Required Properties
- All Properties
- Manifest
/*+ create */
INSERT INTO awscc.redshiftserverless.workgroups (
WorkgroupName,
region
)
SELECT
'{{ WorkgroupName }}',
'{{ region }}';
/*+ create */
INSERT INTO awscc.redshiftserverless.workgroups (
WorkgroupName,
NamespaceName,
BaseCapacity,
MaxCapacity,
EnhancedVpcRouting,
ConfigParameters,
SecurityGroupIds,
SubnetIds,
PubliclyAccessible,
Port,
PricePerformanceTarget,
SnapshotArn,
SnapshotName,
SnapshotOwnerAccount,
RecoveryPointId,
Tags,
TrackName,
Workgroup,
region
)
SELECT
'{{ WorkgroupName }}',
'{{ NamespaceName }}',
'{{ BaseCapacity }}',
'{{ MaxCapacity }}',
'{{ EnhancedVpcRouting }}',
'{{ ConfigParameters }}',
'{{ SecurityGroupIds }}',
'{{ SubnetIds }}',
'{{ PubliclyAccessible }}',
'{{ Port }}',
'{{ PricePerformanceTarget }}',
'{{ SnapshotArn }}',
'{{ SnapshotName }}',
'{{ SnapshotOwnerAccount }}',
'{{ RecoveryPointId }}',
'{{ Tags }}',
'{{ TrackName }}',
'{{ Workgroup }}',
'{{ region }}';
version: 1
name: stack name
description: stack description
providers:
- aws
globals:
- name: region
value: '{{ vars.AWS_REGION }}'
resources:
- name: workgroup
props:
- name: WorkgroupName
value: '{{ WorkgroupName }}'
- name: NamespaceName
value: '{{ NamespaceName }}'
- name: BaseCapacity
value: '{{ BaseCapacity }}'
- name: MaxCapacity
value: '{{ MaxCapacity }}'
- name: EnhancedVpcRouting
value: '{{ EnhancedVpcRouting }}'
- name: ConfigParameters
value:
- ParameterKey: '{{ ParameterKey }}'
ParameterValue: '{{ ParameterValue }}'
- name: SecurityGroupIds
value:
- '{{ SecurityGroupIds[0] }}'
- name: SubnetIds
value:
- '{{ SubnetIds[0] }}'
- name: PubliclyAccessible
value: '{{ PubliclyAccessible }}'
- name: Port
value: '{{ Port }}'
- name: PricePerformanceTarget
value:
Status: '{{ Status }}'
Level: '{{ Level }}'
- name: SnapshotArn
value: '{{ SnapshotArn }}'
- name: SnapshotName
value: '{{ SnapshotName }}'
- name: SnapshotOwnerAccount
value: '{{ SnapshotOwnerAccount }}'
- name: RecoveryPointId
value: '{{ RecoveryPointId }}'
- name: Tags
value:
- Key: '{{ Key }}'
Value: '{{ Value }}'
- name: TrackName
value: '{{ TrackName }}'
- name: Workgroup
value:
WorkgroupName: '{{ WorkgroupName }}'
NamespaceName: '{{ NamespaceName }}'
BaseCapacity: '{{ BaseCapacity }}'
MaxCapacity: '{{ MaxCapacity }}'
EnhancedVpcRouting: '{{ EnhancedVpcRouting }}'
ConfigParameters:
- null
SecurityGroupIds:
- '{{ SecurityGroupIds[0] }}'
SubnetIds:
- '{{ SubnetIds[0] }}'
PubliclyAccessible: '{{ PubliclyAccessible }}'
Port: '{{ Port }}'
PricePerformanceTarget: null
SnapshotArn: '{{ SnapshotArn }}'
SnapshotName: '{{ SnapshotName }}'
SnapshotOwnerAccount: '{{ SnapshotOwnerAccount }}'
RecoveryPointId: '{{ RecoveryPointId }}'
Tags:
- null
TrackName: '{{ TrackName }}'
Workgroup: null
DELETE example
/*+ delete */
DELETE FROM awscc.redshiftserverless.workgroups
WHERE data__Identifier = '<WorkgroupName>'
AND region = 'us-east-1';
Permissions
To operate on the workgroups resource, the following permissions are required:
Create
ec2:DescribeVpcAttribute,
ec2:DescribeSecurityGroups,
ec2:DescribeAddresses,
ec2:DescribeInternetGateways,
ec2:DescribeSubnets,
ec2:DescribeAccountAttributes,
ec2:DescribeAvailabilityZones,
redshift-serverless:CreateNamespace,
redshift-serverless:CreateWorkgroup,
redshift-serverless:GetWorkgroup,
redshift-serverless:GetNamespace,
redshift-serverless:ListTagsForResource,
redshift-serverless:TagResource,
redshift-serverless:RestoreFromSnapshot,
redshift-serverless:RestoreFromRecoveryPoint
Read
ec2:DescribeVpcAttribute,
ec2:DescribeSecurityGroups,
ec2:DescribeAddresses,
ec2:DescribeInternetGateways,
ec2:DescribeSubnets,
ec2:DescribeAccountAttributes,
ec2:DescribeAvailabilityZones,
redshift-serverless:GetWorkgroup,
redshift-serverless:ListTagsForResource
Update
ec2:DescribeVpcAttribute,
ec2:DescribeSecurityGroups,
ec2:DescribeAddresses,
ec2:DescribeInternetGateways,
ec2:DescribeSubnets,
ec2:DescribeAccountAttributes,
ec2:DescribeAvailabilityZones,
redshift-serverless:ListTagsForResource,
redshift-serverless:TagResource,
redshift-serverless:UntagResource,
redshift-serverless:GetWorkgroup,
redshift-serverless:UpdateWorkgroup,
redshift-serverless:ListTagsForResource,
redshift-serverless:TagResource,
redshift-serverless:UntagResource,
redshift-serverless:RestoreFromSnapshot,
redshift-serverless:RestoreFromRecoveryPoint
Delete
ec2:DescribeVpcAttribute,
ec2:DescribeSecurityGroups,
ec2:DescribeAddresses,
ec2:DescribeInternetGateways,
ec2:DescribeSubnets,
ec2:DescribeAccountAttributes,
ec2:DescribeAvailabilityZones,
redshift-serverless:GetWorkgroup,
redshift-serverless:GetNamespace,
redshift-serverless:DeleteWorkgroup,
redshift-serverless:ListTagsForResource,
redshift-serverless:UntagResource
List
ec2:DescribeVpcAttribute,
ec2:DescribeSecurityGroups,
ec2:DescribeAddresses,
ec2:DescribeInternetGateways,
ec2:DescribeSubnets,
ec2:DescribeAccountAttributes,
ec2:DescribeAvailabilityZones,
redshift-serverless:ListWorkgroups,
redshift-serverless:ListTagsForResource