instance_group#

Exec module for managing Instance Groups.

async idem_gcp.exec.gcp.compute.instance_group.list_(hub, ctx, project: str = None, zone: str = None, filter_: (<class 'str'>, 'alias=filter') = None, order_by: str = None)[source]#

Retrieves the list of zonal instance group resources contained within the specified zone. For managed instance groups, use the instanceGroupManagers or regionInstanceGroupManagers methods instead.

Parameters:
  • project (str, Optional) – Project ID for this request.

  • zone (str, Optional) – The name of the zone where the instance group is located.

  • filter (str, Optional) – A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either =, !=, >, <, <=, >= or :. For example, if you are filtering Compute Engine instances, you can exclude instances named example-instance by specifying name != example-instance. The : operator can be used with string fields to match substrings. For non-string fields it is equivalent to the = operator. The :* comparison can be used to test whether a key has been defined. For example, to find all objects with owner label use: ` labels.owner:* ` You can also filter nested fields. For example, you could specify scheduling.automaticRestart = false to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ` By default, each expression is an AND expression. However, you can include AND and OR expressions explicitly. For example: ` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ` If you want to use a regular expression, use the eq (equal) or ne (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: fieldname eq unquoted literal fieldname eq ‘single quoted literal’ fieldname eq "double quoted literal" (fieldname1 eq literal) (fieldname2 ne "literal") The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name “instance”, you would use name ne .*instance.

  • order_by (str, Optional) – Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using orderBy="creationTimestamp desc". This sorts results based on the creationTimestamp field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by name or creationTimestamp desc is supported.

Examples

random-name:
  exec.run:
  - path: gcp.compute.instance_group.list
  - kwargs:
      project: project-name
      zone: zone-name
async idem_gcp.exec.gcp.compute.instance_group.get(hub, ctx, resource_id: str = None, project: str = None, zone: str = None, name: str = None)[source]#

Returns the specified zonal instance group. acceleratorTypes.get a list of available zonal instance groups by making a list() request. For managed instance groups, use the instanceGroupManagers or regionInstanceGroupManagers methods instead.

Parameters:
  • resource_id (str, Optional) – An identifier of the resource in the provider.

  • project (str, Optional) – Project ID for this request.

  • zone (str, Optional) – Name of the zone for this request.

  • name (str, Optional) – The name of the instance group. Authorization requires the following IAM permission on the specified resource instanceGroup: compute.instance_group.get.

Examples

random-name:
  exec.run:
  - path: gcp.compute.instance_group.get
  - kwargs:
      project: project-name
      zone: zone-name
      name: instance-name
async idem_gcp.exec.gcp.compute.instance_group.list_instances(hub, ctx, instance_group_resource_id: str, filter_: (<class 'str'>, 'alias=filter') = None, order_by: str = None)[source]#

Retrieves the list of instances in an instance groups.

Parameters:
  • instance_group_resource_id (str) – Resource ID for the container instance group.

  • filter (str, Optional) – A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either =, !=, >, <, <=, >= or :. For example, if you are filtering Compute Engine instances, you can exclude instances named example-instance by specifying name != example-instance. The : operator can be used with string fields to match substrings. For non-string fields it is equivalent to the = operator. The :* comparison can be used to test whether a key has been defined. For example, to find all objects with owner label use: ` labels.owner:* ` You can also filter nested fields. For example, you could specify scheduling.automaticRestart = false to include instances only if they are not scheduled for automatic restarts. You can use filtering on nested fields to filter based on resource labels. To filter on multiple expressions, provide each separate expression within parentheses. For example: ` (scheduling.automaticRestart = true) (cpuPlatform = \"Intel Skylake\") ` By default, each expression is an AND expression. However, you can include AND and OR expressions explicitly. For example: ` (cpuPlatform = \"Intel Skylake\") OR (cpuPlatform = \"Intel Broadwell\") AND (scheduling.automaticRestart = true) ` If you want to use a regular expression, use the eq (equal) or ne (not equal) operator against a single un-parenthesized expression with or without quotes or against multiple parenthesized expressions. Examples: fieldname eq unquoted literal fieldname eq ‘single quoted literal’ fieldname eq "double quoted literal" (fieldname1 eq literal) (fieldname2 ne "literal") The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name “instance”, you would use name ne .*instance.

  • order_by (str, Optional) – Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using orderBy="creationTimestamp desc". This sorts results based on the creationTimestamp field in reverse chronological order (newest result first). Use this to sort resources like operations so that the newest operation is returned first. Currently, only sorting by name or creationTimestamp desc is supported.

Examples

random-name:
  exec.run:
  - path: gcp.compute.instance_group.list_instances
  - kwargs:
        instance_group_resource_id: projects/project-name/zones/us-central1-a/instanceGroups/instance-group
async idem_gcp.exec.gcp.compute.instance_group.remove_instances(hub, ctx, instance_group_resource_id: str, instances: List[str])[source]#

Removes instances from an instance group.

Parameters:
  • instance_group_resource_id (str) – Resource ID for the container instance group.

  • instances (List[str]) – Instance IDs of the instances to be removed.

Examples

random-name:
  exec.run:
  - path: gcp.compute.instance_group.remove_instances
  - kwargs:
        instance_group_resource_id: projects/project-name/zones/us-central1-a/instanceGroups/instance-group
        instances:
            - projects/project-name/zones/us-central1-a/instances/instance-1
async idem_gcp.exec.gcp.compute.instance_group.add_instances(hub, ctx, instance_group_resource_id: str, instances: List[str])[source]#

Adds instances to an instance group.

Parameters:
  • instance_group_resource_id (str) – Resource ID for the container instance group.

  • instances (List[str]) – Instance IDs of the instances to be added.

Examples

random-name:
  exec.run:
  - path: gcp.compute.instance_group.add_instances
  - kwargs:
        instance_group_resource_id: projects/project-name/zones/us-central1-a/instanceGroups/instance-group
        instances:
            - projects/project-name/zones/us-central1-a/instances/instance-1
async idem_gcp.exec.gcp.compute.instance_group.set_named_ports(hub, ctx, instance_group_resource_id: str, named_ports: List[NamedPort] = None, fingerprint: str = None)[source]#

Sets the named ports for the specified instance group.

Parameters:
  • instance_group_resource_id (str) – Resource ID for the container instance group.

  • named_ports (List[Dict[str, Any]]) –

    The list of named ports to set for this instance group. Assigns a name to a port number. For example: {name: “http”, port: 80} This allows the system to reference ports by the assigned name instead of a port number. Named ports can also contain multiple ports. For example: [{name: “app1”, port: 8080}, {name: “app1”, port: 8081}, {name: “app2”, port: 8082}] Named ports apply to all instances in this instance group. . Defaults to None.

    • name (str, Optional): The name for this named port. The name must be 1-63 characters long, and comply with RFC1035.

    • port (int, Optional): The port number, which can be a value between 1 and 65535.

  • fingerprint (str) – The fingerprint of the named ports information for this instance group. Use this optional property to prevent conflicts when multiple users change the named ports settings concurrently. Obtain the fingerprint with the instanceGroups.get method. Then, include the fingerprint in your request to ensure that you do not overwrite changes that were applied from another concurrent request. A request with an incorrect fingerprint will fail with error 412 conditionNotMet. A base64-encoded string.

Examples

random-name:
  exec.run:
  - path: gcp.compute.instance_group.set_named_ports
  - kwargs:
        instance_group_resource_id: projects/project-name/zones/us-central1-a/instanceGroups/instance-group
        fingerprint: ABCD
        named_ports:
            - name: http
              port: 8080