Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add CDN load balancer with Cloud Storage buckets as backend #5575

Merged
merged 2 commits into from
Jan 25, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 17 additions & 0 deletions mmv1/products/compute/terraform.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -936,6 +936,23 @@ overrides: !ruby/object:Overrides::ResourceOverrides
post_create: templates/terraform/post_create/labels.erb
GlobalForwardingRule: !ruby/object:Overrides::Terraform::ResourceOverride
examples:
- !ruby/object:Provider::Terraform::Examples
name: "external_cnd_lb_with_backend_bucket"
primary_resource_id: "default"
vars:
cdn_network: "cdn-network"
cdn_subnet: "cdn-subnet"
cdn_static_ip: "cdn-static-ip"
cdn_forwarding_rule: "cdn-forwarding-rule"
cdn_target_http_proxy: "cdn-target-http-proxy"
cdn_url_map: "cdn-url-map"
image_backend_bucket: "image-backend-bucket"
cdn_backend_storage_bucket: "cdn-backend-storage-bucket"
min_version: beta
ignore_read_extra:
- "port_range"
- "target"
- "ip_address"
- !ruby/object:Provider::Terraform::Examples
name: "external_ssl_proxy_lb_mig_backend"
primary_resource_id: "default"
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,137 @@
# CDN load balancer with Cloud bucket as backend

# [START cloudloadbalancing_cdn_with_backend_bucket]
# VPC
resource "google_compute_network" "default" {
name = "<%= ctx[:vars]['cdn_network'] %>"
provider = google-beta
auto_create_subnetworks = false
}

# backend subnet
resource "google_compute_subnetwork" "default" {
name = "<%= ctx[:vars]['cdn_subnet'] %>"
provider = google-beta
ip_cidr_range = "10.0.1.0/24"
region = "us-central1"
network = google_compute_network.default.id
}

# reserve IP address
resource "google_compute_global_address" "default" {
provider = google-beta
name = "<%= ctx[:vars]['cdn_static_ip'] %>"
}

# forwarding rule
resource "google_compute_global_forwarding_rule" "<%= ctx[:primary_resource_id] %>" {
name = "<%= ctx[:vars]['cdn_forwarding_rule'] %>"
provider = google-beta
ip_protocol = "TCP"
load_balancing_scheme = "EXTERNAL"
port_range = "80"
target = google_compute_target_http_proxy.default.id
ip_address = google_compute_global_address.default.id
}

# http proxy
resource "google_compute_target_http_proxy" "default" {
name = "<%= ctx[:vars]['cdn_target_http_proxy'] %>"
provider = google-beta
url_map = google_compute_url_map.default.id
}

# url map
resource "google_compute_url_map" "default" {
name = "<%= ctx[:vars]['cdn_url_map'] %>"
provider = google-beta
default_service = google_compute_backend_bucket.default.id
}

# backend bucket with CDN policy with default ttl settings
resource "google_compute_backend_bucket" "default" {
name = "<%= ctx[:vars]['image_backend_bucket'] %>"
description = "Contains beautiful images"
bucket_name = google_storage_bucket.default.name
enable_cdn = true
cdn_policy {
cache_mode = "CACHE_ALL_STATIC"
client_ttl = 3600
default_ttl = 3600
max_ttl = 86400
negative_caching = true
serve_while_stale = 86400
}
}

# cdn backend bucket
resource "google_storage_bucket" "default" {
name = "<%= ctx[:vars]['cdn_backend_storage_bucket'] %>"
location = "US"
uniform_bucket_level_access = true
// delete bucket and contents on destroy.
force_destroy = true
// Assign specialty files
website {
main_page_suffix = "index.html"
not_found_page = "404.html"
}
}

# make bucket public
resource "google_storage_bucket_iam_member" "default" {
bucket = google_storage_bucket.default.name
role = "roles/storage.objectViewer"
member = "allUsers"
}

resource "google_storage_bucket_object" "index_page" {
name = "index.html"
source = "index.html"
bucket = google_storage_bucket.default.name
depends_on = [local_file.index_page]
}

resource "google_storage_bucket_object" "error_page" {
name = "404.html"
source = "404.html"
bucket = google_storage_bucket.default.name
depends_on = [local_file.error_page]
}

# image object for testing, try to access http://<your_lb_ip_address>/test.jpg
resource "google_storage_bucket_object" "test_image" {
name = "test.jpg"
source = "test.jpg"
content_type = "image/jpeg"
bucket = google_storage_bucket.default.name
depends_on = [null_resource.test_image]
}

# cdn sample index page
resource "local_file" "index_page" {
filename = "index.html"
content = <<-EOT
<html><body>
<h1>Congratulations on setting up Google Cloud CDN with Storage backend!</h1>
</body></html>
EOT
}

# cdn default error page
resource "local_file" "error_page" {
filename = "404.html"
content = <<-EOT
<html><body>
<h1>404 Error: Object you are looking for is no longer available!</h1>
</body></html>
EOT
}

# cdn sample image
resource "null_resource" "test_image" {
provisioner "local-exec" {
command = "wget -O test.jpg https://upload.wikimedia.org/wikipedia/commons/c/c8/Thank_you_001.jpg"
}
}
# [END cloudloadbalancing_cdn_with_backend_bucket]