Contrail security was introduced in 4.1 release, Contrail security uses tags, application policy sets, firewall policies and other objects to configure security policies. Check the following blueprint for details.
Contrail natively doesn't support Next-generation Firewall (NGFW) functions. This feature addresses the gap by integrating third-party firewalls. Contrail does support service chaining functions with any third-party firewalls. However, Service Chaining constructs are limited, support only chaining between virtual networks(Inter), don't support intra-network. Moreover, Service Chaining constructs don't understand tags and they are tied with virtual network constructs.
###NGFW
NGFW integration will support tag based firewall configuration. NGFW integration got three types of firewall models. Host based firewall (HBF), service chain and physical FW. This design addresses only HBF.
NGFW integration needs, license management, and automatic provisioning of supported firewall models, registration of NGFW controller and lifecycle management of NGFW instances.
Single management interface for both Contrail and NGFW management is desired, but 5.1.x release will have two management interfaces. Contrail management interface to configure intent based policies up to L4 and NGFW management (SD) to configure NGFW functions with contrail defined security objects (mainly tags and tenants).
Later releases will support a single management interface by Contrail Command and also Contrail security FWP language enhanced with NGFW features configuration. Tag based security policy to redirect traffic towards to NGFW. NGFW includes features like IPS, IDS, AV, Malware detection and many more.
Focus of this document is to go over HBF functions and use cases supported for contrail side of development.
HBF gives an ability to support NGFW functions close to workloads. NGFW can be vSRX/cSRX or any third party firewall. Architecture should support customer choice NGFW vendor. But, this effort will be mainly focus on releasing it with cSRX and its corresponding management plane (Security Director).
NGFW (HBF) instance may support multi-tenancy, in those cases one instance of NGFW per compute node would be sufficient. Other cases, would require multiple instances of NGFW per compute node minimum an instance per tenant. There could be another extreme that, a cSRX instance per port (It is not in scope for this effort). cSRX doesn't support multi tenancy, hence we choose support one cSRX instance per tenant in a compute node. Multiple instances per tenant in a compute node will be addressed in later releases.
Multi tenancy feature needs an identifier for tenants for configuration at NGFW controller and also at data path to distinguish tenants. We will be using vlan id as identifier and communicated to NGFW controller. Since we are using vlan id, there is a limit of 4k tenants/projects for given cluster from Contrail.
Physical NGFW (SRX) supports multi-tenancy. Firewall domains are created for tenant in SRX and supports overlapping addresses across tenants. Virtual SRXes doesn't support multi tenancy. vSRX got a feature to support it in later releases, but not for cSRX. NGFW doesn't support overlapping addresses for a tenant. This feature introduces restriction to support overlapping ipaddress ranges in a given tenant. Where as, across tenants overlapping addresses will be supported.
Firewalls typically support three modes of operation, routing, transparent and secure wire (a.k.a bump in the wire).
- Routing - Acts as router
- Transparent - it is l2 mode or bridging mode
- Secure wire - It ties two interfaces in secure wire mode, there is no change in the packet including mac-address, when packet is sent out on connected interfaces.
This feature uses cSRX in secure wire mode.
NGFW controller learns about tenants and tags from Contrail Controller. Both Contrail and NGFW management interfaces use contrail defined tags.
Interfaces can be tagged at Contrail, tags and virtual network objects doesn't have any binding.
NGFW controller should understand, whether tags are tenant scoped or global. NGFW controller also gets information about projects and tags to port mapping. NGFW controllers uses tenant and tag to port mapping to configure cSRX policies.
HBF feature is bump in wire, based on policy configuration
All these use cases are with respect to tag based Contrail Security framework.
- HBF action configuration option for Contrail Security firewall rule configuration (Part of an action).
- HBF to support virtual to virtual workload policies. BMS to BMS and BMS to Virtual tag based policies are not supported for this release.
- Tag based policies doesn't support mirror action, hence supporting HBF action along with mirror action will not be supported.
- Knob to do HBF at source or source/destination traffic endpoints. (optional)
- Fabric network supporting HBF (vhost traffic requiring HBF feature) will be supported.
- Current floating IP and all other features like LB/SNAT/DNAT should work.
- Existing Networking polcies should work.
- This feature should work in contrail supported orchestrators (openstack, vmware compute VM, container based orchestrators and BMS combinations)
- It is important use case test with VMware/Cloud with cSRX containers
- Packet mode interfaces doesn't participate in flow creation, hence it is not subjected to HBF. HBF traffic streeting happens via policy, which is used to create flows.
- HBF is currently not supported with DPDK variant of vRouter
- HBF is currently not supported for cross-tenant traffic
Contrail cluster supports openstack, k8s and vmware orchestrators for virtual workloads. Contrail cluster can support all at the same time, but there are limitations via Contrail Command UI to provistion all in orchestrators.
HBF feature design should support all orchestrators in a given cluster, but it will be supported in phased manner. First phase supports kubernetes orchestrated projects and subsequent phases will support other orchestrator projects.
Tier=Web -> Tier=App all traffic to HBF
Tier=Web -> Tier=App service SQL traffic to HBF
Tier=Web -> Tier=App service HTTP to malware detection
Tier=Web -> Tier=App service HTTPs to IPS
Tier=Web -> Tier=App service SQL traffic to AV
Contrail FWP framework supports action as HBF. HBF action will send traffic to NGFW instance assigned for that project/tenant.
Above diagram explains about each process involved in setting HBS object and its associated objects like Right-VN/Right-VMI, Left-VN/Left-VMI and Mgmt-VN/Mgmt-VMI and finally Host based services VM/Docker.
A new object named HBS (Host Based Services) would be added to our data model. This object will have references to Left-VN, Right-VN and Mgmt-VN which inturn will have one VMI per each VNs, Left-VMI, Right-VMI and Mgmt-VMI respectively. These VMIs would be three VMIs of the Docker or VM running the Host Based Services software, for instance, Host based services of type Firewall, cSRX. HBS object is a generic object with type. Current implementation is for HBS object with type = firewall.
HBS object would be created in the Config DB by API server when user enables HBS option in the user project. HBS object and these VNs, VMI and Docker container will all be hosted in the same project or dedicated project
Step 1: User creates a Project in the orchestrator, say Project-1. This project is automatically synced to Config DB
Step 2: User creates HBS object at Contrail via API-server. This object would be created and maintained in Config DB.
Step 3: HBS object is created in Config DB. HBS-Manager (Kube-Manager or Operator framework) is expected to automatically start a series of events to create
Step 4: Right VN, Left VN and Mgmt VN
Step 5: Right VMI, Left VMI and Mgmt VMI
Step 6: Ref update on HBS object, to create refs from HBS object to above three VNs. This ref will have a property name called type = Left-VN/Right-VN/Mgmt-VN and this property can be used to identify VN type. There is no special property in the VN to identify its direction.
Step 7: Start the Host Based services image based on the HBS object type. Current implementation is for HBS type = firewall.
This completes the setup required for using HBS in the Contrail Security Policies.
Contrail security policies should be able to create HBS action independent of the above process, as two steps are orthogonal steps.
Step 8: At this point of time, user should be able to use a new action named - HBS in their contrail security policies.
HBS object will be created by API server in Config DB on project with HBS option enabled. This triggers a series of automation by HBS-Manager (or operator framework) to create VNs/VMIs and spawns security docker image as well as refs from HBS object to both VNs in the project where HBS is enabled or in a dedicated project
Likewise, when HBS object is disabled in the project, API server deletes the HBS object from Config DB which inturn triggers HBS-Manager (or operator framework) to remove Security Docker/VM, VMIs and VNs and refs.
HBS object, VNs, VMIs and Security Docker/VM can live in the same user project or in its dedicated project. Security Docker/VM is created per project per compute.
HBS object is created per project per Compute node. This may resulted in several number of security images running in the cluster depending upon the number of Projects and Compute nodes. For instance, for 10 project on a 10 compute node can result in 100 instances running in a cluster.To limit this number of instances, Config will provide an option at global system config to specify number of HBS enabled projects in a given cluster.
Cluster level quota is required to limit the number of projects to enable HBF feature.
Project level knob to enable/disable or quota for HBF
Contrail security policy action enhancements to support HBF, add enable/disable HBF or action as HBF.
HBF_Left and HBF_Right are treated like any other networks, and not seeing any code changes.
One HBF instance is created for each tenant with HBF enabled. Two data interfaces, called HBF left and right interfaces, are created for each HBF instance. Two VNs named "HBF-LEFT" and "HBF-RIGHT" are created under the tenant's project. The left and right interfaces are assigned respectively to "HBF-LEFT" and "HBF-RIGHT" VNs. The vif objects corresponding to HBF left and right interfaces are marked with a flag to indicate that they are HBF interfaces. One management interface also created with specified management VN.
This approach embeds the flow id in L2 header of the packet sent to HBF instance. HBF instance is expected to send back the packet without modifying the l2 header.
-
HBF instance does not modify the L2 header of the packets
-
vRouter's VMIs work in promiscuous mode (Is this assumption for HBF VMIs ?)
-
Packets generated by HBF are sent back to vRouter by just interchanging source and destination MACs
Defined as all flows that have HBF flag set.
vRouter's vif object is enhanced to store all vif and AAP (IP, MAC) pairs. Agent programs vRouter with this information.
When adding a vif to vRouter, Agent additionally sends the HBF left and right interface indices to vRouter. From this information, vRouter maintains a map of VRF to HBF left and right interfaces. Agent obtains a VMI's project via VMI à VN à Project config path. From the project it obtains HBF interfaces via Project à "HBF-LEFT"/"HBF-RIGHT" à HBF-interface config path.
At the time of flow creation, Agent marks a flow as an HBF flow if a matching ACL has HBF action set. Agent also marks HBF flows with an "HBF-interface" flag that indicates if packets matching the flows are to be sent to HBF left (L) or HBF right (R) interface. The flag is set according to the table below.
Destination: VMI | Destination: Fabric | |
---|---|---|
Source: VMI | L if source vif index < dest vif indexElse R | L |
Source: Fabric | R | - |
When a packet enters the Vrouter via a VMI and matches a flow marked with HBF flag, vRouter redirects the packet to the left interface of the tenant's HBF interface if the flow's HBF-interface flag is set to L. Otherwise, it sends the packet to HBF's right interface.
If the packet is being sent to HBF left interface, it encodes flow id as the source MAC address in packet's L2 header. In case of L3 VPN, it uses the HBF mac as the destination MAC. In L2 VPN case, it leaves the destination MAC as it is.
In addition to encoding the flow id in source or destination MAC field, a FROM_VMI bit is also encoded in the MAC field (flow Id requires 32 bits of 48-bit MAC field) to indicate the packet source.
When a packet enters the vRouter via the fabric interface and matches a flow marked with HBF flag, Vrouter redirects the packet to the right interface of the tenant's HBF interface. The matching flow is expected to have its HBF-interface flag set to R. It uses flow id as the destination MAC address in packet's L2 header. If the incoming packet matches an AF_INET NH, VRRP MAC is used as source MAC. If the matching NH is an AF_BRIDGE NH, original source MAC is retained. In addition to encoding the flow id in destination MAC field, a FROM_FABRIC bit is also encoded in the MAC field to indicate the packet source.
When a packet enters vRouter via an HBF right interface, vRouter uses the source MAC as flow index to get back the original flow. In case of l2 VPNs, it will restore the original source MAC from IP-to-MAC map of flow key-NH's vif using the flow's source IP. Vrouter skips HBF processing this time to avoid looping the packet back to HBF instance and continues with NAT, mirroring, service chaining etc.
When a packet enters the Vrouter via an HBF left interface, vRouter uses the destination MAC as flow index to get back the original flow. If FROM_FABRIC bit is set, in case of l2 VPNs, it will restore the original destination MAC from IP-to-MAC map of flow key-NH's vif using the flow's destination IP. If FROM_VMI bit is set and the flow's HBF-interface flag is R, the destination MAC is restored from IP-to-MAC map of reverse-flow's key-NH's vif using the flow's destination IP.
vRouter skips HBF processing this time to avoid looping the packet back to HBF instance and continues with NAT, mirroring, service chaining etc.
In cases were a composite NH is being used a flow's key-NH, the flow's ECMP index indicates the leg of the composite NH to be used for routing the packet. The same data is used in case of HBF flows to obtain the correct vif (vif of the leg indicated by flow's ECMP index) from which the original source/destination MAC is restored.
VMI1:<IP1, MAC1, AAP-IP, AAP-MAC1> VMI2:<IP2, MAC2, AAP-IP, AAP-MAC2> Packets use <AAP-IP, MAC1> and <AAP-IP, MAC2>
Flows from the two VMIs use the corresponding vif NH as flow key-NH. When a packet enters vRouter from HBF right/left interface, the flow id embedded in the source/destination MAC allows us to get back the original MAC address from IP-to-MAC map of flow key NH's vif.
9.4.2 VMIs are configured to have the same AAP IP and packets use the corresponding AAP MACs as source
VMI1:<IP1, MAC1, AAP-IP, AAP-MAC1> VMI2:<IP2, MAC2, AAP-IP, AAP-MAC2> Packets use <AAP-IP, AAP-MAC1> and <AAP-IP, AAP-MAC2>
Flows from the two VMIs use the corresponding vif NH as flow key-NH. When a packet enters vRouter from HBF right/left interface, the flow id embedded in the source/destination MAC allows us to get back the original source/destination MAC address from IP-to-MAC map of flow key NH's vif.
VMI:<IP, MAC, AAP-IP, AAP-MAC> Packets use <IP, MAC> and <AAP-IP, AAP-MAC>
Two flows are created. Flows from the two IP addresses use the same vif NH as flow key-NH. When a packet enters vRouter from HBF right/left interface, the flow id embedded in the source/destination MAC allows us to get back the original flow. Original source/destination MAC address is got back from IP-to-MAC map of flow key NH's vif.
VMI:<IP, MAC, AAP-IP, AAP-MAC> Packets use <IP, MAC> and <IP, AAP-MAC>
Only one flow is created with vif NH as flow key-NH. MAC index in the flow would the index of the MAC that triggered flow creation. When a packet enters vRouter from HBF right/left interface, the flow id embedded in the source/destination MAC allows us to get back the original flow. However, we cannot deterministically get back the original source/destination MAC from IP-to-MAC map of vif. This configuration is not expected.
VMI:<IP, MAC, AAP-IP, AAP-MAC> Packets use <IP, MAC> and <AAP-IP, MAC>
Two flows are created. Flows from the two IP addresses use the same vif NH as flow key-NH. When a packet enters vRouter from HBF right/left interface, the flow id embedded in the source/destination MAC allows us to get back the original flow. Original source/destinationMAC address is got back from IP-to-MAC map of flow key NH's vif.
It is possible that while a flow Id is being carried in a packet to HBF instance, if the flow id gets released and gets allocated to a new flow. In this case, when the packet enters vRouter from HBF interfaces, the flow id would be not be pointing the flow the packet had matched when it was sent to HBF instance. This is a transient condition that would affect all packets that are in fight to HBF when the flow change occurs. To avoid this mismatch, the gen-id of the flow is embedded in the source/destination MAC along with the flow id. When a packet enters vRouter after its HBF instance visit, gen-id of the flow obtained from the flow-id is compared with the flow's gen-id. If they don't match, the packet is discarded.
Sometimes HBF instances generate and send back packets to the source of the packet they drop. For example, if HBF blocks a TCP connection by dropping a SYN packet, it sends back RST to the source originating the SYN. HBF uses the source/destination IP/MAC addresses from the dropped packet as destination/source IP/MAC addresses in the packet it generates and sends the generated packet out on the interface on which the dropped packet had been received.
When HBF-generated packets reach vRouter, they must be treated as if coming from the destination of the dropped packet and be processed using the reverse flow of the flow that had redirected the dropped packet to HBF instance.
When vRouter redirects packets to HBF instances, it encodes into source/destination MAC fields a bit indicating the source of the packet in addition to flow id and gen id. vRouter sets the direction bit to "From VMI" or "From Fabric" depending on the origin of the packet.
When a packet is received by vRouter on HBF left interface with direction bit value of FROM_VMI and the matching flow has HBF-interface flag set to L, or on HBF right interface with direction bit value of FROM_FABRIC/FROM_VMI and HBF-interface flag set to R, it indicates that the packet is an HBF-generated packet and hence uses the reverse flow in its further processing.
This triggers flow re-evaluation of all flows that depend on the policy. HBF flows will get reprogrammed on non-HBF flows.
This triggers flow re-evaluation of all flows that depend on the policy. Non-HBF flows will get reprogrammed on HBF flows.
We don't trigger flow re-evaluations. HBF interfaces would be withdrawn from vRouter as a result of disabling HBF. Entries for all the VRFs under the tenant in VRF-to-HBF interfaces map would also be removed. Packets matching HBF flows would get dropped in vRouter as destination no matching entry would be found in VRF-to-HBF interfaces map. "No matching HBF instance" drop stat is incremented.
We don't trigger flow re-evaluations. HBF interfaces would be added into vRouter as a result of enabling HBF. Entries for all the VRFs under the tenant in VRF-to-HBF interfaces map would also be added. Packets matching HBF flows would start getting redirected to HBF instance.
Following items that are helpful for debugging would be implemented –
-
HBF flows display would have "H" flag set
-
"No matching HBF instance" drop stat to indicate non-existence of HBF interfaces
-
Packet counters on HBF interfaces
-
Ways to dump VRF-to-HBF interfaces map and IP-to-MAC map of VMIs in both Agent/vRouter
-
HBF is currently not supported with DPDK variant of vRouter
-
HBF is currently not supported in vRouter packet mode. HBF support for VMIs in packet mode can be taken up in later releases
-
HBF is currently not supported for cross-tenant traffic
Because intra-vn is to be supported and LR always relies on inet table to do routing. Other major reason is that LR leaks all IP routes but it should not leak bridge routes. Intra-VN or BMS-VM in intra-VN is always bridged and therefore it will a bigger challenge to use LR for same.
Agent will use current flow based system to redirect traffic from source/destination to HBF and vice versa. The list of information needed by agent to do same are listed below:
- --Policy specifying HBF action.
- --HBF instance left and right interface information (especially VRF).
- --VLAN id per project/tenant to support multiple project/tenant on same HBF. Scope of this vlan-id will be HBF left and right interface and not beyond them. Vlan is used to determine NH for left/right interface of HBF which in turn is key to flow.
One HBF instance per tenant, then we can avoid VLANs with the assumption that, there are no overlapping IP addresses in a given tenant to connect via policies.
- --Knob to specify HBF at source/destination or preference (e.g. source HBF preferred, but if not possible then do destination HBF or do a combination of both).
- --Non overlapping IP in a project/tenant.Flow aging will need to flush all relevant flows, otherwise it will create discrepancies for flows.
- --Support HBF along with current network policy based service chaining.
This approach has been evaluated and prototyped and found few limitations, hence choosing the proposed approach to use two flows.
- Number of sessions supported will be reduced.
- Service chaining and mirroring use cases complex agent code
- Code complexity in maintaining four flows and debugging
https://github.com/Juniper/contrail-specs/blob/master/fw_security_enhancements.md