The network stack manages the management plane networking configuration, including all the routing to customer VCNs.
Management plane network administrators.
This stack is executed in different stages with a PROGRESSIVELY UPDATED single input configuration file.
- Mgmt Plane Foundational - IAM, Logging, Governance
- Mgmt Plane Networking 1st stage - Mgmt Plane VCNs (this stack)
- Mgmt Plane Networking - Firewall
- Mgmt Plane Networking 2nd stage - Network routing post firewall deployment (this stack)
- Customer Onboarding
- Mgmt Plane Networking 3rd stage - Network routing post customer onboarding (this stack)
Stacks #5 and #6 must be repeated for each NEW customer onboarding.
Input Configuration Files | Input Dependency Files | Generated Output |
---|---|---|
network_initial_config.json, flow_logs_config.json | iam/output/compartments_output.json | network/output/network_output.json |
Click the button to create the stack with all variables pre-filled.
The resources in red color are added.
THE 2ND STAGE IS NOT A NEW STACK, BUT AN UPDATE TO NETWORK STACK INITIAL DEPLOYMENT, NOW INCLUDING THE CONFIGURATIONS DEPLOYED BY THE NETWORK FIREWALL STACK.
AFTER THIS STAGE THE MANAGEMENT PLANE IS CONSIDERED READY TO ONBOARD CUSTOMERS.
This stage updates the initial network configuration with route rules to the Network Load Balancer and the DRG.
Specifically:
THESE CONFIGURATION SNIPPETS ARE SHOWN HERE FOR CLARITY PURPOSES. THEY ARE ALL ALREADY ADDED IN network_post_firewall_config.json.
- A new route table IS ADDED for routing any traffic to the Network Load Balancer.
"HUB-INGRESS-ROUTE" : {
"display_name" : "central-hub-vcn-ingress-route",
"route_rules" : {
"TO-ANYWHERE-RULE" : {
"description" : "All traffic goes to NLB.",
"destination" : "0.0.0.0/0",
"destination_type" : "CIDR_BLOCK",
"network_entity_key" : "INDOOR-NLB"
}
}
}
- All DRG attachments ARE ADDED, with the attachment to the Firewall VCN (Central Hu VCN) referring to the route table above.
"drg_attachments" : {
"CENTRAL-HUB-VCN-ATTACH" : {
"display_name" : "central-hub-vcn-attachment",
"drg_route_table_key" : "HUB-VCN-DRG-ROUTE",
"network_details" : {
"attached_resource_key" : "CENTRAL-HUB-VCN",
"type" : "VCN",
"route_table_key" : "HUB-INGRESS-ROUTE"
}
},
"SECURITY-VCN-ATTACH" : {
"display_name" : "security-vcn-attachment",
"drg_route_table_key" : "SECURITY-VCN-DRG-ROUTE",
"network_details" : {
"attached_resource_key" : "SECURITY-VCN",
"type" : "VCN"
}
},
"SHARED-SERVICES-VCN-ATTACH" : {
"display_name" : "shared-services-vcn-attachment",
"drg_route_table_key" : "SHARED-SERVICES-VCN-DRG-ROUTE",
"network_details" : {
"attached_resource_key" : "SHARED-SERVICES-VCN",
"type" : "VCN"
}
}
}
- DRG route tables associated with Import route distributions ARE ADDED:
"drg_route_tables" : {
"HUB-VCN-DRG-ROUTE" : {
"display_name" : "central-hub-drg-route",
"import_drg_route_distribution_key" : "HUB-IMPORT-ROUTE-DISTRIBUTION"
},
"SECURITY-VCN-DRG-ROUTE" : {
"display_name" : "security-vcn-drg-route",
"import_drg_route_distribution_key" : "SECURITY-VCN-IMPORT-ROUTE-DISTRIBUTION"
},
"SHARED-SERVICES-VCN-DRG-ROUTE" : {
"display_name" : "shared-services-vcn-drg-route",
"import_drg_route_distribution_key" : "SHARED-SERVICES-VCN-IMPORT-ROUTE-DISTRIBUTION"
}
}
- DRG Import route distributions ARE ADDED, for the dynamic learning of route rules:
"drg_route_distributions" : {
"HUB-IMPORT-ROUTE-DISTRIBUTION" : {
"display_name" : "central-hub-vcn-route-distribution",
"distribution_type" : "IMPORT",
"statements" : {
"SECURITY-VCN-STMT" : {
"action" : "ACCEPT",
"priority" : 1,
"match_criteria" : {
"match_type" : "DRG_ATTACHMENT_ID",
"attachment_type" : "VCN",
"drg_attachment_key" : "SECURITY-VCN-ATTACH"
}
},
"SHARED-SERVICES-VCN-STMT" : {
"action" : "ACCEPT",
"priority" : 2,
"match_criteria" : {
"match_type" : "DRG_ATTACHMENT_ID",
"attachment_type" : "VCN",
"drg_attachment_key" : "SHARED-SERVICES-VCN-ATTACH"
}
}
}
},
"SECURITY-VCN-IMPORT-ROUTE-DISTRIBUTION" : {
"display_name" : "security-vcn-route-distribution",
"distribution_type" : "IMPORT",
"statements" : {
"CENTRAL-HUB-VCN-STMT" : {
"action" : "ACCEPT",
"priority" : 1,
"match_criteria" : {
"match_type" : "DRG_ATTACHMENT_ID",
"attachment_type" : "VCN",
"drg_attachment_key" : "CENTRAL-HUB-VCN-ATTACH"
}
}
}
},
"SHARED-SERVICES-VCN-IMPORT-ROUTE-DISTRIBUTION" : {
"display_name" : "shared-services-vcn-route-distribution",
"distribution_type" : "IMPORT",
"statements" : {
"CENTRAL-HUB-VCN-STMT-2" : {
"action" : "ACCEPT",
"priority" : 1,
"match_criteria" : {
"match_type" : "DRG_ATTACHMENT_ID",
"attachment_type" : "VCN",
"drg_attachment_key" : "CENTRAL-HUB-VCN-ATTACH"
}
}
}
}
}
In order to update the initial network configuration, edit the existing network stack, replacing the existing Input Configuration File and Input Dependency Files with the files in the table below:
Input Configuration Files | Input Dependency Files | Generated Output |
---|---|---|
network_post_firewall_config.json, flow_logs_config.json | iam/output/compartments_output.json, firewall/output/nlbs_output.json | network/output/network_output.json |
The resources in red color are added.
THE 3RD STAGE IS NOT A NEW STACK, BUT AN UPDATE TO THE NETWORK STACK AFTER EACH CUSTOMER ONBOARDING INITIATION.
At this stage, the Central Hub VCN is updated for routing traffic to the newly added customer VCN.
Specifically:
THESE CONFIGURATION SNIPPETS ARE SHOWN HERE FOR CLARITY PURPOSES. THEY ARE ALL ALREADY ADDED IN network_post_each_customer_config.json
- A new route rule IS ADDED to the Indoor subnet route table. This enforces routing through the DRG for any traffic that leaves the subnet destined to the newly added customer VCN.
"TO-CUSTOMER-1-VCN-RULE" : {
"description" : "To DRG.",
"destination" : "10.0.0.0/25", ## ======>>> newly added customer VCN CIDR range <<=======
"destination_type" : "CIDR_BLOCK",
"network_entity_key" : "CENTRAL-HUB-DRG"
}
- A new import route distribution statement IS ADDED to Central Hub VCN Import Route Distribution.
"CUSTOMER-1-VCN-STMT" : {
"action" : "ACCEPT",
"priority" : 3, ## ======>>> INCREMENT THIS FOR EACH NEWLY ADDED CUSTOMER. <<=======
"match_criteria" : {
"match_type" : "DRG_ATTACHMENT_ID",
"attachment_type" : "VCN",
"drg_attachment_key" : "CUSTOMER-1-VCN-ATTACH"
}
}
MAKE SURE TO REPEAT STEPS 1 and 2 ABOVE FOR ANY NEWLY ADDED CUSTOMERS. UTILIZE AVAILABLE CUSTOMER 1 SAMPLE AS GUIDANCE.
In order to update the current network configuration, edit the existing network stack, replacing the existing Input Configuration File and Input Dependency Files with the files in the table below:
Input Configuration Files | Input Dependency Files | Generated Output |
---|---|---|
network_post_each_customer_config.json, flow_logs_config.json | iam/output/compartments_output.json, firewall/output/nlbs_output.json, customer1/output/network_output.json | network/output/network_output.json |
Routing is updated, so that the customer VCN can route to the DRG and the DRG can route to the customer VCN.