Global HTTP Load Balancer Terraform Module {%- if serverless %} for Serverless NEGs{% elif backend_bucket %} for static websites using a Cloud Storage Bucket{% endif %}
{% if not serverless and not backend_bucket %} Modular Global HTTP Load Balancer for GCE using forwarding rules. {% endif %}
{% if root %}
- If you would like to allow for backend groups to be managed outside Terraform, such as via GKE services, see the dynamic backends submodule.
- If you would like to use load balancing with serverless backends (Cloud Run, Cloud Functions or App Engine), see the serverless_negs submodule and cloudrun example.
{% elif dynamic_backends %}
This submodule allows for configuring dynamic backend outside Terraform.
As such, any changes to the backends.groups
variable after creation will be ignored.
{% elif serverless %}
This submodule allows you to create Cloud HTTP(S) Load Balancer with
Serverless Network Endpoint Groups (NEGs)
and place serverless services from Cloud Run, Cloud Functions and App Engine
behind a Cloud Load Balancer.
{% elif backend_bucket %}
This submodule allows you to create a Cloud HTTP(S) Load Balancer for static website content hosted in one or more Cloud Storage Buckets with a CDN for content caching and distribution.
Note: The use of multiple backend storage buckets with discrete CDN configurations is supported, but this requires a url map to be provided. {% endif %}
{% if not serverless and not backend_bucket %} {# TCP LB and ILB don't work for Serverless NEGs or backend buckets yet. #}
- TCP load balancer
- HTTP/S load balancer
- Internal load balancer {% endif %}
This module is meant for use with Terraform 0.13+ and tested using Terraform 1.0+. If you find incompatibilities using Terraform >=0.13, please open an issue. If you haven't upgraded and need a Terraform 0.12.x-compatible version of this module, the last released version intended for Terraform 0.12.x is v4.5.0.
{% if not serverless %}
module "gce-lb-http" {
{% else %}
module "lb-http" {
{% endif %}
source = "GoogleCloudPlatform/lb-http/google{{ module_path }}"
version = "~> 4.4"
project = "my-project-id"
{% if serverless or backend_bucket %}
name = "my-lb"
ssl = true
managed_ssl_certificate_domains = ["your-domain.com"]
https_redirect = true
{% else %}
name = "group-http-lb"
target_tags = [module.mig1.target_tags, module.mig2.target_tags]
{% endif %}
{% if not backend_bucket %}
backends = {
default = {
description = null
{% if not serverless %}{# not necessary for serverless as default port_name=http, protocol=HTTP #}
protocol = "HTTP"
port = var.service_port
port_name = var.service_port_name
{% endif %}
{% if not serverless %}
timeout_sec = 10
{% endif %}
enable_cdn = false
custom_request_headers = null
custom_response_headers = null
security_policy = null
{% if not serverless %}
connection_draining_timeout_sec = null
session_affinity = null
affinity_cookie_ttl_sec = null
health_check = {
check_interval_sec = null
timeout_sec = null
healthy_threshold = null
unhealthy_threshold = null
request_path = "/"
port = var.service_port
host = null
logging = null
}
{% endif %}
log_config = {
enable = true
sample_rate = 1.0
}
{% if serverless %}
groups = [
{
# Your serverless service should have a NEG created that's referenced here.
group = google_compute_region_network_endpoint_group.default.id
}
]
{% else %}
groups = [
{
# Each node pool instance group should be added to the backend.
group = var.backend
balancing_mode = null
capacity_scaler = null
description = null
max_connections = null
max_connections_per_instance = null
max_connections_per_endpoint = null
max_rate = null
max_rate_per_instance = null
max_rate_per_endpoint = null
max_utilization = null
},
]
{% endif %}
iap_config = {
enable = false
oauth2_client_id = null
oauth2_client_secret = null
}
}
}
{% else %}
backends = {
default = {
description = null
bucket_name = "your-bucket-name"
enable_cdn = true
cdn_policy = {
cache_mode = "CACHE_ALL_STATIC"
client_ttl = 3600
default_ttl = 3600
max_ttl = 86400
negative_caching = false
signed_url_cache_max_age_sec = 7200
}
}
}
{% endif %}
}
{% if not serverless and not backend_bucket %}
Figure 1. diagram of terraform resources
{% if not backend_bucket %}
Current version is 3.0. Upgrade guides:
- 1.X -> 2.X
- 2.X -> 3.0 {% endif %}
Name | Description | Type | Default | Required |
---|---|---|---|---|
address | IPv4 address (actual IP address value) | string | "null" |
no |
ipv6_address | IPv6 address (actual IP address value) | string | "null" |
no |
backends | Map backend indices to list of backend maps. | object | n/a | yes |
cdn | Set to true to enable cdn on backend. |
bool | "false" |
no |
certificate | Content of the SSL certificate. Required if ssl is true and ssl_certificates is empty. |
string | "null" |
no |
create_address | Create a new global IPv4 address | bool | "true" |
no |
create_ipv6_address | Create a new global IPv6 address | bool | "true" |
no |
create_url_map | Set to false if url_map variable is provided. |
bool | "true" |
no |
firewall_networks | Names of the networks to create firewall rules in | list(string) | <list> |
no |
firewall_projects | Names of the projects to create firewall rules in | list(string) | <list> |
no |
http_forward | Set to false to disable HTTP port 80 forward |
bool | "true" |
no |
https_redirect | Set to true to enable https redirect on the lb. |
bool | "false" |
no |
name | Name for the forwarding rule and prefix for supporting resources | string | n/a | yes |
private_key | Content of the private SSL key. Required if ssl is true and ssl_certificates is empty. |
string | "null" |
no |
project | The project to deploy to, if not set the default provider project is used. | string | n/a | yes |
quic | Set to true to enable QUIC support |
bool | "false" |
no |
security_policy | The resource URL for the security policy to associate with the backend service | string | "null" |
no |
ssl | Set to true to enable SSL support, requires variable ssl_certificates - a list of self_link certs |
bool | "false" |
no |
ssl_certificates | SSL cert self_link list. Required if ssl is true and no private_key and certificate is provided. |
list(string) | <list> |
no |
ssl_policy | Selfink to SSL Policy | string | "null" |
no |
target_service_accounts | List of target service accounts for health check firewall rule. Exactly one of target_tags or target_service_accounts should be specified. | list(string) | <list> |
no |
target_tags | List of target tags for health check firewall rule. Exactly one of target_tags or target_service_accounts should be specified. | list(string) | <list> |
no |
url_map | The url_map resource to use. Default is to send all traffic to first backend. | string | "null" |
no |
use_ssl_certificates | If true, use the certificates provided by ssl_certificates , otherwise, create cert from private_key and certificate |
bool | "false" |
no |
Name | Description |
---|---|
backend_services | The backend service resources. |
external_ip | The external IPv4 address assigned to the global fowarding rule. |
external_ipv6_address | The external IPv6 address assigned to the global fowarding rule. |
http_proxy | The HTTP proxy used by this module. |
https_proxy | The HTTPS proxyused by this module. |
google_compute_global_forwarding_rule.http
: The global HTTP forwarding rule.google_compute_global_forwarding_rule.https
: The global HTTPS forwarding rule created whenssl
istrue
.google_compute_target_http_proxy.default
: The HTTP proxy resource that binds the url map. Created when inputssl
isfalse
.google_compute_target_https_proxy.default
: The HTTPS proxy resource that binds the url map. Created when inputssl
istrue
.google_compute_ssl_certificate.default
: The certificate resource created when inputssl
istrue
andmanaged_ssl_certificate_domains
not specified.google_compute_managed_ssl_certificate.default
: The Google-managed certificate resource created when inputssl
istrue
andmanaged_ssl_certificate_domains
is specified.google_compute_url_map.default
: The default URL map resource when inputurl_map
is not provided. {% if not backend_bucket %}google_compute_backend_service.default.*
: The backend services created for each of thebackend_params
elements. {% endif %} {% if not serverless and not backend_bucket %}google_compute_health_check.default.*
: Health check resources created for each of the (non global NEG) backend services.google_compute_firewall.default-hc
: Firewall rule created for each of the backed services to allow health checks to the instance group. {% endif %} {% if backend_bucket %}google_compute_backend_bucket.default.*
: The Backend cloud storage bucket used with HTTP(S) load balancing to serve static content, and its related CDN settings. {% endif %}