@pulumi/gcp
Version:
A Pulumi package for creating and managing Google Cloud Platform resources.
376 lines (375 loc) • 16.6 kB
TypeScript
import * as pulumi from "@pulumi/pulumi";
import * as inputs from "../types/input";
import * as outputs from "../types/output";
/**
* An Anthos node pool running on Azure.
*
* For more information, see:
* * [Multicloud overview](https://cloud.google.com/kubernetes-engine/multi-cloud/docs)
* ## Example Usage
*
* ### Basic_azure_node_pool
* A basic example of a containerazure azure node pool
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as gcp from "@pulumi/gcp";
*
* const versions = gcp.container.getAzureVersions({
* project: "my-project-name",
* location: "us-west1",
* });
* const basic = new gcp.container.AzureClient("basic", {
* applicationId: "12345678-1234-1234-1234-123456789111",
* location: "us-west1",
* name: "client-name",
* tenantId: "12345678-1234-1234-1234-123456789111",
* project: "my-project-name",
* });
* const primary = new gcp.container.AzureCluster("primary", {
* authorization: {
* adminUsers: [{
* username: "mmv2@google.com",
* }],
* },
* azureRegion: "westus2",
* client: pulumi.interpolate`projects/my-project-number/locations/us-west1/azureClients/${basic.name}`,
* controlPlane: {
* sshConfig: {
* authorizedKey: "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQC8yaayO6lnb2v+SedxUMa2c8vtIEzCzBjM3EJJsv8Vm9zUDWR7dXWKoNGARUb2mNGXASvI6mFIDXTIlkQ0poDEPpMaXR0g2cb5xT8jAAJq7fqXL3+0rcJhY/uigQ+MrT6s+ub0BFVbsmGHNrMQttXX9gtmwkeAEvj3mra9e5pkNf90qlKnZz6U0SVArxVsLx07vHPHDIYrl0OPG4zUREF52igbBPiNrHJFDQJT/4YlDMJmo/QT/A1D6n9ocemvZSzhRx15/Arjowhr+VVKSbaxzPtEfY0oIg2SrqJnnr/l3Du5qIefwh5VmCZe4xopPUaDDoOIEFriZ88sB+3zz8ib8sk8zJJQCgeP78tQvXCgS+4e5W3TUg9mxjB6KjXTyHIVhDZqhqde0OI3Fy1UuVzRUwnBaLjBnAwP5EoFQGRmDYk/rEYe7HTmovLeEBUDQocBQKT4Ripm/xJkkWY7B07K/tfo56dGUCkvyIVXKBInCh+dLK7gZapnd4UWkY0xBYcwo1geMLRq58iFTLA2j/JmpmHXp7m0l7jJii7d44uD3tTIFYThn7NlOnvhLim/YcBK07GMGIN7XwrrKZKmxXaspw6KBWVhzuw1UPxctxshYEaMLfFg/bwOw8HvMPr9VtrElpSB7oiOh91PDIPdPBgHCi7N2QgQ5l/ZDBHieSpNrQ== thomasrodgers",
* },
* subnetId: "/subscriptions/12345678-1234-1234-1234-123456789111/resourceGroups/my--dev-byo/providers/Microsoft.Network/virtualNetworks/my--dev-vnet/subnets/default",
* version: versions.then(versions => versions.validVersions?.[0]),
* },
* fleet: {
* project: "my-project-number",
* },
* location: "us-west1",
* name: "name",
* networking: {
* podAddressCidrBlocks: ["10.200.0.0/16"],
* serviceAddressCidrBlocks: ["10.32.0.0/24"],
* virtualNetworkId: "/subscriptions/12345678-1234-1234-1234-123456789111/resourceGroups/my--dev-byo/providers/Microsoft.Network/virtualNetworks/my--dev-vnet",
* },
* resourceGroupId: "/subscriptions/12345678-1234-1234-1234-123456789111/resourceGroups/my--dev-cluster",
* project: "my-project-name",
* });
* const primaryAzureNodePool = new gcp.container.AzureNodePool("primary", {
* autoscaling: {
* maxNodeCount: 3,
* minNodeCount: 2,
* },
* cluster: primary.name,
* config: {
* sshConfig: {
* authorizedKey: "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQC8yaayO6lnb2v+SedxUMa2c8vtIEzCzBjM3EJJsv8Vm9zUDWR7dXWKoNGARUb2mNGXASvI6mFIDXTIlkQ0poDEPpMaXR0g2cb5xT8jAAJq7fqXL3+0rcJhY/uigQ+MrT6s+ub0BFVbsmGHNrMQttXX9gtmwkeAEvj3mra9e5pkNf90qlKnZz6U0SVArxVsLx07vHPHDIYrl0OPG4zUREF52igbBPiNrHJFDQJT/4YlDMJmo/QT/A1D6n9ocemvZSzhRx15/Arjowhr+VVKSbaxzPtEfY0oIg2SrqJnnr/l3Du5qIefwh5VmCZe4xopPUaDDoOIEFriZ88sB+3zz8ib8sk8zJJQCgeP78tQvXCgS+4e5W3TUg9mxjB6KjXTyHIVhDZqhqde0OI3Fy1UuVzRUwnBaLjBnAwP5EoFQGRmDYk/rEYe7HTmovLeEBUDQocBQKT4Ripm/xJkkWY7B07K/tfo56dGUCkvyIVXKBInCh+dLK7gZapnd4UWkY0xBYcwo1geMLRq58iFTLA2j/JmpmHXp7m0l7jJii7d44uD3tTIFYThn7NlOnvhLim/YcBK07GMGIN7XwrrKZKmxXaspw6KBWVhzuw1UPxctxshYEaMLfFg/bwOw8HvMPr9VtrElpSB7oiOh91PDIPdPBgHCi7N2QgQ5l/ZDBHieSpNrQ== thomasrodgers",
* },
* proxyConfig: {
* resourceGroupId: "/subscriptions/12345678-1234-1234-1234-123456789111/resourceGroups/my--dev-cluster",
* secretId: "https://my--dev-keyvault.vault.azure.net/secrets/my--dev-secret/0000000000000000000000000000000000",
* },
* rootVolume: {
* sizeGib: 32,
* },
* tags: {
* owner: "mmv2",
* },
* labels: {
* key_one: "label_one",
* },
* vmSize: "Standard_DS2_v2",
* },
* location: "us-west1",
* maxPodsConstraint: {
* maxPodsPerNode: 110,
* },
* name: "node-pool-name",
* subnetId: "/subscriptions/12345678-1234-1234-1234-123456789111/resourceGroups/my--dev-byo/providers/Microsoft.Network/virtualNetworks/my--dev-vnet/subnets/default",
* version: versions.then(versions => versions.validVersions?.[0]),
* annotations: {
* "annotation-one": "value-one",
* },
* management: {
* autoRepair: true,
* },
* project: "my-project-name",
* });
* ```
*
* ## Import
*
* NodePool can be imported using any of these accepted formats:
*
* * `projects/{{project}}/locations/{{location}}/azureClusters/{{cluster}}/azureNodePools/{{name}}`
*
* * `{{project}}/{{location}}/{{cluster}}/{{name}}`
*
* * `{{location}}/{{cluster}}/{{name}}`
*
* When using the `pulumi import` command, NodePool can be imported using one of the formats above. For example:
*
* ```sh
* $ pulumi import gcp:container/azureNodePool:AzureNodePool default projects/{{project}}/locations/{{location}}/azureClusters/{{cluster}}/azureNodePools/{{name}}
* ```
*
* ```sh
* $ pulumi import gcp:container/azureNodePool:AzureNodePool default {{project}}/{{location}}/{{cluster}}/{{name}}
* ```
*
* ```sh
* $ pulumi import gcp:container/azureNodePool:AzureNodePool default {{location}}/{{cluster}}/{{name}}
* ```
*/
export declare class AzureNodePool extends pulumi.CustomResource {
/**
* Get an existing AzureNodePool resource's state with the given name, ID, and optional extra
* properties used to qualify the lookup.
*
* @param name The _unique_ name of the resulting resource.
* @param id The _unique_ provider ID of the resource to lookup.
* @param state Any extra arguments used during the lookup.
* @param opts Optional settings to control the behavior of the CustomResource.
*/
static get(name: string, id: pulumi.Input<pulumi.ID>, state?: AzureNodePoolState, opts?: pulumi.CustomResourceOptions): AzureNodePool;
/**
* Returns true if the given object is an instance of AzureNodePool. This is designed to work even
* when multiple copies of the Pulumi SDK have been loaded into the same process.
*/
static isInstance(obj: any): obj is AzureNodePool;
/**
* Optional. Annotations on the node pool. This field has the same restrictions as Kubernetes annotations. The total size
* of all keys and values combined is limited to 256k. Keys can have 2 segments: prefix (optional) and name (required),
* separated by a slash (/). Prefix must be a DNS subdomain. Name must be 63 characters or less, begin and end with
* alphanumerics, with dashes (-), underscores (_), dots (.), and alphanumerics between. **Note**: This field is
* non-authoritative, and will only manage the annotations present in your configuration. Please refer to the field
* `effectiveAnnotations` for all of the annotations present on the resource.
*/
readonly annotations: pulumi.Output<{
[key: string]: string;
} | undefined>;
/**
* Autoscaler configuration for this node pool.
*/
readonly autoscaling: pulumi.Output<outputs.container.AzureNodePoolAutoscaling>;
/**
* Optional. The Azure availability zone of the nodes in this nodepool. When unspecified, it defaults to `1`.
*/
readonly azureAvailabilityZone: pulumi.Output<string>;
/**
* The azureCluster for the resource
*/
readonly cluster: pulumi.Output<string>;
/**
* The node configuration of the node pool.
*/
readonly config: pulumi.Output<outputs.container.AzureNodePoolConfig>;
/**
* Output only. The time at which this node pool was created.
*/
readonly createTime: pulumi.Output<string>;
readonly effectiveAnnotations: pulumi.Output<{
[key: string]: string;
}>;
/**
* Allows clients to perform consistent read-modify-writes through optimistic concurrency control. May be sent on update and delete requests to ensure the client has an up-to-date value before proceeding.
*/
readonly etag: pulumi.Output<string>;
/**
* The location for the resource
*/
readonly location: pulumi.Output<string>;
/**
* The Management configuration for this node pool.
*/
readonly management: pulumi.Output<outputs.container.AzureNodePoolManagement>;
/**
* The constraint on the maximum number of pods that can be run simultaneously on a node in the node pool.
*/
readonly maxPodsConstraint: pulumi.Output<outputs.container.AzureNodePoolMaxPodsConstraint>;
/**
* The name of this resource.
*/
readonly name: pulumi.Output<string>;
/**
* The project for the resource
*/
readonly project: pulumi.Output<string>;
/**
* Output only. If set, there are currently pending changes to the node pool.
*/
readonly reconciling: pulumi.Output<boolean>;
/**
* Output only. The current state of the node pool. Possible values: STATE_UNSPECIFIED, PROVISIONING, RUNNING, RECONCILING, STOPPING, ERROR, DEGRADED
*/
readonly state: pulumi.Output<string>;
/**
* The ARM ID of the subnet where the node pool VMs run. Make sure it's a subnet under the virtual network in the cluster configuration.
*/
readonly subnetId: pulumi.Output<string>;
/**
* Output only. A globally unique identifier for the node pool.
*/
readonly uid: pulumi.Output<string>;
/**
* Output only. The time at which this node pool was last updated.
*/
readonly updateTime: pulumi.Output<string>;
/**
* The Kubernetes version (e.g. `1.19.10-gke.1000`) running on this node pool.
*/
readonly version: pulumi.Output<string>;
/**
* Create a AzureNodePool resource with the given unique name, arguments, and options.
*
* @param name The _unique_ name of the resource.
* @param args The arguments to use to populate this resource's properties.
* @param opts A bag of options that control this resource's behavior.
*/
constructor(name: string, args: AzureNodePoolArgs, opts?: pulumi.CustomResourceOptions);
}
/**
* Input properties used for looking up and filtering AzureNodePool resources.
*/
export interface AzureNodePoolState {
/**
* Optional. Annotations on the node pool. This field has the same restrictions as Kubernetes annotations. The total size
* of all keys and values combined is limited to 256k. Keys can have 2 segments: prefix (optional) and name (required),
* separated by a slash (/). Prefix must be a DNS subdomain. Name must be 63 characters or less, begin and end with
* alphanumerics, with dashes (-), underscores (_), dots (.), and alphanumerics between. **Note**: This field is
* non-authoritative, and will only manage the annotations present in your configuration. Please refer to the field
* `effectiveAnnotations` for all of the annotations present on the resource.
*/
annotations?: pulumi.Input<{
[key: string]: pulumi.Input<string>;
}>;
/**
* Autoscaler configuration for this node pool.
*/
autoscaling?: pulumi.Input<inputs.container.AzureNodePoolAutoscaling>;
/**
* Optional. The Azure availability zone of the nodes in this nodepool. When unspecified, it defaults to `1`.
*/
azureAvailabilityZone?: pulumi.Input<string>;
/**
* The azureCluster for the resource
*/
cluster?: pulumi.Input<string>;
/**
* The node configuration of the node pool.
*/
config?: pulumi.Input<inputs.container.AzureNodePoolConfig>;
/**
* Output only. The time at which this node pool was created.
*/
createTime?: pulumi.Input<string>;
effectiveAnnotations?: pulumi.Input<{
[key: string]: pulumi.Input<string>;
}>;
/**
* Allows clients to perform consistent read-modify-writes through optimistic concurrency control. May be sent on update and delete requests to ensure the client has an up-to-date value before proceeding.
*/
etag?: pulumi.Input<string>;
/**
* The location for the resource
*/
location?: pulumi.Input<string>;
/**
* The Management configuration for this node pool.
*/
management?: pulumi.Input<inputs.container.AzureNodePoolManagement>;
/**
* The constraint on the maximum number of pods that can be run simultaneously on a node in the node pool.
*/
maxPodsConstraint?: pulumi.Input<inputs.container.AzureNodePoolMaxPodsConstraint>;
/**
* The name of this resource.
*/
name?: pulumi.Input<string>;
/**
* The project for the resource
*/
project?: pulumi.Input<string>;
/**
* Output only. If set, there are currently pending changes to the node pool.
*/
reconciling?: pulumi.Input<boolean>;
/**
* Output only. The current state of the node pool. Possible values: STATE_UNSPECIFIED, PROVISIONING, RUNNING, RECONCILING, STOPPING, ERROR, DEGRADED
*/
state?: pulumi.Input<string>;
/**
* The ARM ID of the subnet where the node pool VMs run. Make sure it's a subnet under the virtual network in the cluster configuration.
*/
subnetId?: pulumi.Input<string>;
/**
* Output only. A globally unique identifier for the node pool.
*/
uid?: pulumi.Input<string>;
/**
* Output only. The time at which this node pool was last updated.
*/
updateTime?: pulumi.Input<string>;
/**
* The Kubernetes version (e.g. `1.19.10-gke.1000`) running on this node pool.
*/
version?: pulumi.Input<string>;
}
/**
* The set of arguments for constructing a AzureNodePool resource.
*/
export interface AzureNodePoolArgs {
/**
* Optional. Annotations on the node pool. This field has the same restrictions as Kubernetes annotations. The total size
* of all keys and values combined is limited to 256k. Keys can have 2 segments: prefix (optional) and name (required),
* separated by a slash (/). Prefix must be a DNS subdomain. Name must be 63 characters or less, begin and end with
* alphanumerics, with dashes (-), underscores (_), dots (.), and alphanumerics between. **Note**: This field is
* non-authoritative, and will only manage the annotations present in your configuration. Please refer to the field
* `effectiveAnnotations` for all of the annotations present on the resource.
*/
annotations?: pulumi.Input<{
[key: string]: pulumi.Input<string>;
}>;
/**
* Autoscaler configuration for this node pool.
*/
autoscaling: pulumi.Input<inputs.container.AzureNodePoolAutoscaling>;
/**
* Optional. The Azure availability zone of the nodes in this nodepool. When unspecified, it defaults to `1`.
*/
azureAvailabilityZone?: pulumi.Input<string>;
/**
* The azureCluster for the resource
*/
cluster: pulumi.Input<string>;
/**
* The node configuration of the node pool.
*/
config: pulumi.Input<inputs.container.AzureNodePoolConfig>;
/**
* The location for the resource
*/
location: pulumi.Input<string>;
/**
* The Management configuration for this node pool.
*/
management?: pulumi.Input<inputs.container.AzureNodePoolManagement>;
/**
* The constraint on the maximum number of pods that can be run simultaneously on a node in the node pool.
*/
maxPodsConstraint: pulumi.Input<inputs.container.AzureNodePoolMaxPodsConstraint>;
/**
* The name of this resource.
*/
name?: pulumi.Input<string>;
/**
* The project for the resource
*/
project?: pulumi.Input<string>;
/**
* The ARM ID of the subnet where the node pool VMs run. Make sure it's a subnet under the virtual network in the cluster configuration.
*/
subnetId: pulumi.Input<string>;
/**
* The Kubernetes version (e.g. `1.19.10-gke.1000`) running on this node pool.
*/
version: pulumi.Input<string>;
}