From 28a7000a5af114e3e62d0d2dced02c385c73a681 Mon Sep 17 00:00:00 2001 From: Roberto Jung Drebes Date: Sun, 8 Aug 2021 10:47:22 +0200 Subject: [PATCH 1/2] L3 default for Network load balancer --- mmv1/products/compute/api.yaml | 2 ++ mmv1/products/compute/terraform.yaml | 8 ++++++ .../forwarding_rule_l3_default.tf.erb | 26 +++++++++++++++++++ 3 files changed, 36 insertions(+) create mode 100644 mmv1/templates/terraform/examples/forwarding_rule_l3_default.tf.erb diff --git a/mmv1/products/compute/api.yaml b/mmv1/products/compute/api.yaml index 584fef947956..e4fd2ddeb594 100644 --- a/mmv1/products/compute/api.yaml +++ b/mmv1/products/compute/api.yaml @@ -2654,6 +2654,7 @@ objects: - :TCP - :UDP - :GRPC + - :UNSPECIFIED - !ruby/object:Api::Type::Enum name: 'sessionAffinity' description: | @@ -3697,6 +3698,7 @@ objects: - :AH - :SCTP - :ICMP + - :L3_DEFAULT # This is a multi-resource resource reference (BackendService (global), RegionBackendService) # We have custom expands that manage this. - !ruby/object:Api::Type::ResourceRef diff --git a/mmv1/products/compute/terraform.yaml b/mmv1/products/compute/terraform.yaml index a1a68e2bc996..312888162892 100644 --- a/mmv1/products/compute/terraform.yaml +++ b/mmv1/products/compute/terraform.yaml @@ -723,6 +723,14 @@ overrides: !ruby/object:Overrides::ResourceOverrides vars: forwarding_rule_name: "website-forwarding-rule" target_pool_name: "website-target-pool" + - !ruby/object:Provider::Terraform::Examples + name: "forwarding_rule_l3_default" + primary_resource_id: "fwd_rule" + vars: + forwarding_rule_name: "l3-forwarding-rule" + service_name: "service" + health_check_name: "health-check" + min_version: beta - !ruby/object:Provider::Terraform::Examples name: "forwarding_rule_internallb" primary_resource_id: "default" diff --git a/mmv1/templates/terraform/examples/forwarding_rule_l3_default.tf.erb b/mmv1/templates/terraform/examples/forwarding_rule_l3_default.tf.erb new file mode 100644 index 000000000000..98314cce430b --- /dev/null +++ b/mmv1/templates/terraform/examples/forwarding_rule_l3_default.tf.erb @@ -0,0 +1,26 @@ +resource "google_compute_forwarding_rule" "<%= ctx[:primary_resource_id] %>" { + provider = google-beta + name = "<%= ctx[:vars]['forwarding_rule_name'] %>" + backend_service = google_compute_region_backend_service.service.id + ip_protocol = "L3_DEFAULT" + all_ports = true +} + +resource "google_compute_region_backend_service" "service" { + provider = google-beta + region = "us-central1" + name = "<%= ctx[:vars]['service_name'] %>" + health_checks = [google_compute_region_health_check.health_check.id] + protocol = "UNSPECIFIED" + load_balancing_scheme = "EXTERNAL" +} + +resource "google_compute_region_health_check" "health_check" { + provider = google-beta + name = "<%= ctx[:vars]['health_check_name'] %>" + region = "us-central1" + + tcp_health_check { + port = 80 + } +} From 6cae9d65efb09001d54033a21bbc8c623d43dfc5 Mon Sep 17 00:00:00 2001 From: Roberto Jung Drebes Date: Thu, 12 Aug 2021 20:52:33 +0200 Subject: [PATCH 2/2] update docs --- mmv1/products/compute/api.yaml | 29 +++++++++++++++++------------ 1 file changed, 17 insertions(+), 12 deletions(-) diff --git a/mmv1/products/compute/api.yaml b/mmv1/products/compute/api.yaml index e4fd2ddeb594..2f814469262b 100644 --- a/mmv1/products/compute/api.yaml +++ b/mmv1/products/compute/api.yaml @@ -3772,15 +3772,18 @@ objects: name: 'ports' max_size: 5 description: | - This field is used along with the backend_service field for internal - load balancing. + This field is used along with internal load balancing and network + load balancer when the forwarding rule references a backend service + and when protocol is not L3_DEFAULT. - When the load balancing scheme is INTERNAL, a single port or a comma - separated list of ports can be configured. Only packets addressed to - these ports will be forwarded to the backends configured with this - forwarding rule. + A single port or a comma separated list of ports can be configured. + Only packets addressed to these ports will be forwarded to the backends + configured with this forwarding rule. - You may specify a maximum of up to 5 ports. + You can only use one of ports and portRange, or allPorts. + The three are mutually exclusive. + + You may specify a maximum of up to 5 ports, which can be non-contiguous. item_type: Api::Type::String - !ruby/object:Api::Type::ResourceRef name: 'subnetwork' @@ -3834,11 +3837,13 @@ objects: - !ruby/object:Api::Type::Boolean name: 'allPorts' description: | - For internal TCP/UDP load balancing (i.e. load balancing scheme is - INTERNAL and protocol is TCP/UDP), set this to true to allow packets - addressed to any ports to be forwarded to the backends configured - with this forwarding rule. Used with backend service. Cannot be set - if port or portRange are set. + This field can be used with internal load balancer or network load balancer + when the forwarding rule references a backend service, or with the target + field when it references a TargetInstance. Set this to true to + allow packets addressed to any ports to be forwarded to the backends configured + with this forwarding rule. This can be used when the protocol is TCP/UDP, and it + must be set to true when the protocol is set to L3_DEFAULT. + Cannot be set if port or portRange are set. - !ruby/object:Api::Type::Enum name: 'networkTier' description: |