US20230254283A1 - Methods and apparatus to provide a distributed firewall in a network - Google Patents
Methods and apparatus to provide a distributed firewall in a network Download PDFInfo
- Publication number
- US20230254283A1 US20230254283A1 US18/302,030 US202318302030A US2023254283A1 US 20230254283 A1 US20230254283 A1 US 20230254283A1 US 202318302030 A US202318302030 A US 202318302030A US 2023254283 A1 US2023254283 A1 US 2023254283A1
- Authority
- US
- United States
- Prior art keywords
- firewall
- network
- subgroup
- nodes
- sdn
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims description 22
- 230000004044 response Effects 0.000 claims description 18
- 238000004458 analytical method Methods 0.000 claims description 6
- 238000004891 communication Methods 0.000 claims description 6
- 230000006855 networking Effects 0.000 description 26
- 238000003860 storage Methods 0.000 description 19
- 238000001914 filtration Methods 0.000 description 10
- 238000010586 diagram Methods 0.000 description 8
- 230000006870 function Effects 0.000 description 8
- 230000008569 process Effects 0.000 description 6
- 230000005540 biological transmission Effects 0.000 description 3
- 230000008859 change Effects 0.000 description 3
- 238000007726 management method Methods 0.000 description 3
- 238000012550 audit Methods 0.000 description 2
- 230000003139 buffering effect Effects 0.000 description 2
- 238000004519 manufacturing process Methods 0.000 description 2
- 238000012545 processing Methods 0.000 description 2
- 230000001902 propagating effect Effects 0.000 description 2
- 235000008694 Humulus lupulus Nutrition 0.000 description 1
- 230000009471 action Effects 0.000 description 1
- 230000008901 benefit Effects 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 238000013479 data entry Methods 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000002708 enhancing effect Effects 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 230000000246 remedial effect Effects 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 230000007704 transition Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/02—Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
- H04L63/0227—Filtering policies
- H04L63/0263—Rule management
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/02—Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
- H04L63/0209—Architectural arrangements, e.g. perimeter networks or demilitarized zones
- H04L63/0218—Distributed architectures, e.g. distributed firewalls
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/20—Network architectures or network communication protocols for network security for managing network security; network security policies in general
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
Definitions
- network functions are performed using specialized hardware that accelerates one or more functions relative to general-purpose machines.
- Control and configuration of the network is generally performed by accessing a device to be configured and performing configuration tasks specific to the hardware in the device.
- FIG. 1 is a block diagram of an example software-defined network constructed in accordance with the teachings of this disclosure to provide a distributed firewall in the software-defined network.
- FIG. 2 is a block diagram of an example software-defined networking firewall controller constructed in accordance with the teachings of this disclosure to control a distributed firewall in a software-defined network.
- FIG. 3 is a block diagram of an example SDN node to implement a firewall policy.
- FIG. 4 is a flowchart representative of example machine readable instructions which may be executed to implement the example software-defined networking firewall controller of FIGS. 1 and/or 2 to control a distributed firewall in a software-defined network.
- FIG. 5 is a flowchart representative of example machine readable instructions which may be executed to implement the example software-defined networking node of FIGS. 1 and/or 3 to implement a distributed firewall policy.
- FIG. 6 is a block diagram of an example processor platform capable of executing the instructions of FIGS. 4 and/or 5 to implement the apparatus of FIGS. 1 , 2 , and/or 3 .
- SDN Software-defined networking
- SDN is a network technology that addresses customization and optimization concerns within networks. SDN simplifies modern networks by decoupling the data-forwarding capability (e.g., the data plane or forwarding plane) from routing, resource, and other management functionality (e.g., the control plane). Both the control plane and data plane functions are performed at the network nodes in known networks. Network nodes that support SDN (e.g., that are SDN-compliant) may be configured to implement data plane functions. Control plane functions are performed by an SDN controller.
- SDN networks currently use Application Programming Interface (API) services, such as the OpenFlow protocol or OnePK protocol, to manage the interactions between the data plane and the control plane.
- API Application Programming Interface
- firewalls are centralized and operate independently of other firewalls and network elements.
- Known methods of operating firewalls independently of each other leads to requirements including a) funneling traffic (e.g., all traffic on the network) from the entry points through the firewalls to apply firewall policies and/or b) placing firewalls in every physical or logical location that a policy is needed, which increases infrastructure costs.
- Firewall hardware costs, limits on scalability, management costs, and deployment complexity limit the number of firewalls that can be cost-effectively deployed in a network.
- network traffic using known firewalls often must traverse a substantial portion of the network to reach the firewall. When such traffic is dropped due to the firewall policies, network capacity used to carry the dropped traffic to the firewall is wasted.
- Examples disclosed herein solve problems associated with known firewall implementations by using SDN to provide a distributed firewall application.
- the distributed firewall application permits any and/or every SDN node or element in a software-defined network to be programmed to provide firewall services, thereby reducing the need for funneling traffic and decreasing infrastructure costs.
- Examples disclosed herein deploy and manage instances of the firewall from a central management server or SDN node (e.g., an SDN firewall controller).
- SDN firewall controllers in disclosed examples define and analyze firewall policies for implementation in software-defined networks.
- security policies can be applied throughout a network (e.g., closer to data entry points rather than closer to a data destination).
- Examples disclosed herein enable the network to change a network wide security policy as often as needed to maintain network security and performance.
- example networks may update the firewall policies across the network, as often as every time a user logs onto the network, to accommodate the security policy of that specific user, the device(s) the user is using to access the network, and the resources to which the user needs access.
- known firewalls are updated only when a firewall policy update can be designed for each type of firewall in the network.
- example SDN firewalls disclosed herein are dynamic and adapt to the current circumstances and use(s) of the network.
- Examples disclosed herein identify, at a control plane, a network traffic rule to implement in a network; determine, at the control plane, a distributed firewall for a first firewall in the network to enforce the network traffic rule; instruct, using the control plane, a first software-defined networking node to instantiate the first firewall of the distributed firewall; configure a second software-defined networking node to route network traffic through the first firewall; and instruct the first software-defined networking node to enforce the network traffic rule.
- instructing the first software-defined networking node to instantiate the first firewall includes instructing the first software-defined networking node to instantiate a virtual machine to implement a firewall software application. Some examples further include instructing a third software-defined networking node to modify a first firewall policy of a second firewall at the third software-defined networking node to enforce the network traffic rule. In some such examples, instructing the third software-defined networking node includes instructing the third software-defined networking node to execute the second firewall using the first firewall policy, and instructing the first software-defined networking node to enforce the network traffic rule comprises instructing the first software-defined networking node to execute the first firewall using a second firewall policy, the first firewall policy being independent from the second firewall policy. In some examples, the first and second firewalls are part of the distributed firewall.
- the first software-defined networking node is an edge network node. Some examples further identify, at the control plane, a change to the network traffic rule to implement in the network; identify, at the control plane, a set of software-defined networking nodes on which firewalls of the distributed firewall are implemented; and transmit instructions from the control plane to the set of software-defined networking nodes to cause the firewalls to implement the change to the network traffic rule, the instructions to the software-defined networking nodes in the set being respectively customized for the firewall to which the instructions are transmitted.
- determining the distributed firewall for the network to enforce the network traffic rule includes determining, at the control plane, a portion of the network to which the network traffic rule is to be applied; identifying, at the control plane, software-defined networking nodes in the network to serve the portion of the network; transmitting instructions to a first portion of the identified software-defined networking nodes to cause the first portion of the identified software-defined networking nodes to instantiate respective firewall software applications; and transmitting instructions to the identified software-defined networking nodes to cause the identified software-defined networking nodes to implement the traffic rule via respective firewall software applications.
- FIG. 1 is a block diagram of an example software-defined network 100 constructed in accordance with the teachings of this disclosure to provide a distributed firewall in the software-defined network 100 .
- the example software-defined network 100 is divided into a control plane 102 and a data plane 104 .
- the example control plane 102 is implemented using one or more SDN nodes (e.g., computing devices), but is illustrated in FIG. 1 as a single logical entity.
- the control plane 102 includes one or more control devices that execute a network operating system 106 to control (e.g., configure, monitor) devices in the data plane 104 .
- the example network operating system 106 executes one or more SDN applications including an SDN firewall controller 110 .
- the example network operating system 106 supports the SDN firewall controller 110 and/or any additional SDN applications executed at the network operating system 106 .
- the example SDN firewall controller 110 controls, via the network operating system 106 , a distributed firewall that is implemented via the data plane 104 .
- the distributed firewall provides network traffic filtering to enhance security, reliability, and/or efficiency of the network.
- the distributed firewall of the example of FIG. 1 may include firewall services for private or virtual private networks, and/or any other firewall services (e.g., specialized firewall services) desired by users of the network.
- the example data plane 104 of FIG. 1 includes SDN nodes 112 - 118 (e.g., computing devices, network nodes) that implement the functions of the network (e.g., filtering, routing, etc.) for network traffic.
- the example SDN nodes 112 - 118 are controlled (e.g., configured) by the example control plane 102 (e.g., by the network operating system 106 ), which accesses application programming interfaces (APIs) of the SDN nodes 112 - 118 to configure the network services being provided by the SDN nodes 112 - 118 .
- the network operating system 106 abstracts all or part of the APIs of the SDN nodes 112 - 118 for access by the SDN firewall controller 110 .
- APIs enables the SDN firewall controller to access the API via the network operating system 106 using a consistent set of commands and/or configuration routines, which are then implemented by the network operating system 106 on the desired nodes 112 - 118 (e.g., nodes indicated as arguments in the API call) using device-specific commands and/or configuration routines.
- the example SDN nodes 112 - 118 operate as gateways, edge routers, and/or core routers.
- the SDN nodes 112 - 118 are configurable by the control plane 102 to implement any set or subset of SDN services. Examples of SDN services include routing, traffic filtering, and/or load balancing.
- the example network operating system 106 of FIG. 1 configures respective devices 120 , which may be consumer devices, routers, gateways, and/or edge routers, and/or SDN nodes implementing such consumer and/or networking devices, to route traffic to the SDN nodes 112 - 118 based on forwarding tables and/or other rules.
- each of the SDN nodes 112 , 114 , and 116 implements a respective firewall instance 122 , 124 , 126 .
- Each of the firewall instances 122 - 126 may be configured by the SDN firewall controller 110 independently of other ones of the firewall instances 122 - 126 . Accordingly, examples disclosed herein treat each of the firewall instances 122 - 126 as instances of a firewall service. However, the firewall instances 122 - 126 collectively provide a distributed firewall for the software-defined network 100 to implement the firewall strategy as it is defined at the SDN firewall controller 110 .
- the SDN node 118 does not implement an instance of the distributed firewall service (e.g., a firewall instance). Instead, the network operating system 106 and/or the SDN firewall controller 110 configures the SDN node 118 (e.g., a gateway, an edge router) to route network traffic through one or more of the SDN nodes 114 , 116 , which are executing firewall instances 124 , 126 . In some cases, routing the traffic to the SDN node(s) 114 , 116 for filtering via the firewall instances 124 , 126 is problematic.
- the SDN node(s) 114 , 116 for filtering via the firewall instances 124 , 126 is problematic.
- firewall instances 124 , 126 may become bottlenecks in traffic flow from the devices 120 due to traffic entering the network 100 at the SDN nodes 114 , 116 , traffic forwarded by the SDN node 118 to the SDN nodes 114 , 116 , or both.
- the SDN firewall controller 110 of the illustrated example may alleviate the problem by instantiating a firewall service at the SDN node 118 .
- the example SDN firewall controller 110 of FIG. 1 transmits instructions to the SDN node 118 via the network operating system 106 to cause the SDN node 118 to instantiate a new firewall instance in software, thereby enhancing the performance of the firewall services of the software-defined network 100 and adapting the firewall strategy to real time network conditions.
- the example software-defined network 100 illustrated in FIG. 1 can nearly instantly respond to network conditions involving the distributed firewall.
- the SDN nodes implementing the control plane 102 in the example of FIG. 1 are different nodes than the SDN nodes 112 , 114 , 116 , 118 implementing the data plane 104 .
- the control plane 102 may include one or more SDN nodes 128 to implement the network operating system 106 and/or the SDN firewall controller 110 .
- the example SDN nodes 128 of the control plane 102 communicate with the nodes 112 - 118 via control paths of the network 130 . While only 5 nodes 112 - 118 , 128 are shown in the example network 100 of FIG. 1 , a network may have hundreds, thousands, or more nodes.
- one or more SDN nodes 112 , 114 , 116 , 118 implementing the data plane 104 also implement the control plane 102 .
- FIG. 2 is a block diagram of an example implementation of the example SDN firewall controller 110 of FIG. 1 .
- the example SDN firewall controller 110 of FIG. 2 is implemented on one or more SDN nodes (e.g., the SDN node 128 of FIG. 1 ), which may be separate from SDN nodes 112 - 118 implementing the data plane 104 and/or may also implement the data plane 104 .
- SDN nodes e.g., the SDN node 128 of FIG. 1
- the example SDN firewall controller 110 of FIG. 2 includes a firewall policy interpreter 202 , a firewall node identifier 204 , a firewall instruction generator 206 , and a firewall configuration database 208 .
- firewall configuration e.g., all firewall configuration
- the example SDN firewall controller 110 of the illustrated example has knowledge of the firewall configuration of the software-defined network 100 and implements any and all user firewall configuration commands (e.g., all configuration commands) at the firewall nodes.
- the example SDN firewall controller 110 of the illustrated example also has (and/or can rapidly obtain from the network operating system 106 ) knowledge of the physical and/or logical topologies of the software-defined network 100 and/or the statuses (e.g., configurations, operational statuses, etc.) of the nodes 112 - 118 .
- the SDN firewall controller 110 receives and/or identifies network traffic rules for implementation in the software-defined network 100 .
- a network administrator may define and/or provide a filtering policy or rule to the firewall policy interpreter 202 for instructing the software-defined network 100 to drop packets having a particular source Internet Protocol (IP) address.
- IP Internet Protocol
- Another example rule may include granting a defined group of users in a system (e.g., a “marketing” group, a “field technicians” group, etc.) access to a designated set of applications in a corporate virtual private network. Rules provided manually may be provided using a user interface, a rule description language, and/or any other interface mechanism implemented in the software-defined network 100 .
- the example firewall policy interpreter 202 may receive a firewall policy or rule that is automatically generated by a security service based on activity in the network (e.g., by traffic analysis of the software-defined network). For example, the firewall policy interpreter 202 may receive a firewall rule to temporarily block traffic destined for a particular port at a particular IP address. The example firewall policy interpreter 202 may determine that the firewall rule is to be implemented at each firewall instance 122 - 126 in the software-defined network 100 (e.g., to drop packets matching the filter rule as early as possible).
- the example firewall node identifier 204 of the illustrated example determines a firewall configuration (e.g., identifies firewall nodes) for the software-defined network 100 to enforce the network traffic rule.
- a firewall configuration e.g., identifies firewall nodes
- some network traffic rules may affect only a limited number of firewall applications and/or SDN nodes 112 - 118 .
- the example firewall rule may then be selectively applied to the firewall instances and/or applications executing on those SDN nodes 112 - 118 to reduce the processing resource requirement on SDN nodes 112 - 118 that do not need to implement the policy.
- other network traffic rules may require all of the firewall instances in the software-defined network 100 to be instructed to implement the traffic rule.
- the firewall policy interpreter 202 determines that the distributed firewall is a traffic bottleneck at a particular node.
- the firewall node identifier 204 may determine that creating one or more additional firewall instances at designated nodes 112 - 118 (which may or may not already have a firewall instance such as the node 118 of FIG. 1 ) are to be created to handle the traffic, and/or that the traffic destined for the bottleneck firewalls may be redistributed to other SDN nodes 112 - 118 executing the firewall instances and/or applications.
- the firewall node identifier 204 of the example of FIG. 2 determines the appropriate instances 122 - 126 and/or nodes 112 - 118 of FIG. 1 for efficient implementation of the firewall, including adding firewall instances, migrating firewall instances between nodes, eliminating firewall instances, and/or updating firewall instances and/or routing forwarding tables of other nodes 112 - 118 and/or devices 120 .
- the example firewall instruction generator 206 of FIG. 2 instructs (e.g., via the network operating system 106 ) the appropriate SDN node 112 - 118 to instantiate firewall(s). For example, the firewall instruction generator 206 generates instructions for transmission to a first one of the SDN nodes 112 - 118 (e.g., to the SDN node 112 via an SDN API of the SDN node 112 ). In this example, the instructions cause the SDN node 112 - 118 to instantiate a virtual machine and implement (e.g., install, load, etc.) a firewall application for execution on the virtual machine.
- implement e.g., install, load, etc.
- the SDN node(s) 112 - 118 provide the hardware (e.g., computing, communications) resources used by the corresponding virtual machine(s) and the firewall application(s) to perform the firewall actions.
- a given SDN node 112 - 118 is already executing one or more firewall instances and instantiates an additional firewall instance in response to the instruction from the firewall instruction generator 206 .
- the example firewall configuration database 208 of FIG. 2 stores the firewall configuration of the software-defined network 100 .
- the firewall configuration database 208 stores the locations of the firewall instances 122 - 126 (e.g., physical locations and/or virtual locations), the firewall policies and/or rules configured at the firewall instances 122 - 126 , and/or portions of the software-defined network that are served by the firewall instances 122 - 126 .
- some firewall instances may be configured to serve a particular virtual private local area network, while other firewall instances may be configured to serve traffic routed through a public network.
- a subset of gateways, edge routers, and/or core routers in the network 100 are served by a particular firewall instance (e.g., executing on one or more of the SDN node(s) 112 - 118 ).
- the example firewall node identifier 204 selects the gateways, edge routers, and/or core routers and the firewall instruction generator 206 configures them to route traffic for filtering by the firewall instance.
- the example firewall configuration database 208 of FIG. 2 stores the information associated with the newly-instantiated firewall instance for reference by the firewall policy interpreter 202 , the firewall node identifier 204 , and/or the firewall instruction generator 206 .
- the example firewall configuration database 208 also stores firewall audit logs obtained from the firewall instances in response to success/fail audits of the firewall instances. Additionally or alternatively, the firewall configuration database 208 stores notable network events from the firewall instances.
- the example firewall policy interpreter 202 of the illustrated example analyzes the disparate network events from the firewall instances that are distributed across the software-defined network 100 to identify traffic trends (e.g., increasing traffic from and/or in a portion of the network) and/or identify distributed attacks (e.g., distributed denial of service attacks). In response to identifying trends and/or attacks, the firewall policy interpreter 202 of FIG. 2 generates remedial firewall rules or policies for implementation at the firewall instances.
- the example firewall instruction generator 206 configures one or more other software-defined networking nodes (e.g., network gateways, edge routers, etc.) to route network traffic through the firewall instance.
- the firewall node identifier 204 identifies ones of the SDN nodes 112 - 118 and/or the devices 120 in the software-defined network 100 that are to be configured to route traffic to the newly-instantiated firewall instance.
- the example firewall instruction generator 206 also instructs the firewall instance executing on the SDN node 112 - 118 to enforce the network traffic rule as interpreted by the firewall policy interpreter 202 .
- the firewall instruction generator 206 generates and sends instructions to the firewall instance via the network operating system 106 .
- FIG. 3 is a block diagram of an example SDN node 300 to implement a firewall policy.
- the example SDN node 300 of FIG. 3 may implement any of the example SDN nodes 112 - 118 of FIG. 1 .
- the example SDN node 300 of FIG. 3 includes a packet forwarder 302 , a service manager 304 , a firewall instance 306 , and one or more other virtual service instance(s) 308 .
- the example packet forwarder 302 of FIG. 3 executes on the underlying hardware of the SDN node 300 , including processor(s), memory, and/or communications interfaces (e.g., incoming data ports, outgoing data ports, hardware interconnects, etc.).
- the example packet forwarder 302 of this example receives network traffic (e.g., data packets), processes the traffic in accordance with the services executing on the SDN node 300 (e.g., the firewall instance 306 and/or other virtual service instances 308 ), and forwards the traffic or drops the traffic accordingly.
- the packet forwarder 302 executes on and/or is implemented by multiple scalable hardware devices controlled as a single logical device by the service manager 304 .
- the example service manager 304 of FIG. 3 manages services executing on the SDN node 300 and provides an interface between the services 306 , 308 and the packet forwarder 302 .
- the service manager 304 may include a virtual machine manager that manages virtual machines 310 implementing SDN services and/or software applications. Examples of such services that are managed by the service manager 304 include the firewall instance 306 .
- the service manager 304 may support any number of virtual services. Additionally or alternatively, the service manager 304 provides access for the firewall instance 306 to the hardware resources of the packet forwarder 302 to, for example, enable the firewall instance 306 to apply the firewall rules to the traffic received at the packet forwarder 302 .
- the service manager 304 configures the firewall instance 306 such that the firewall instance 306 logically receives the traffic that is received at the packet forwarder 302 .
- the service manager 304 further provides the firewall instance 306 with the processing resources to apply the firewall rules to the packet forwarder 302 .
- the service manager 304 of FIG. 3 exposes an API that may be accessed by the network operating system 106 and/or the SDN firewall controller 110 of FIG. 1 .
- the service manager 304 receives instructions from the SDN firewall controller 110 of FIG. 1 via the API for implementing and/or configuring the firewall instance 306 (and/or additional firewall instances).
- the service manager 304 instantiates the firewall instance 306 in a virtual machine 310 , for example, in response to an instruction from the firewall instruction generator 206 to instantiate a firewall.
- the service manager 304 exposes a specialized API in response to instantiating the firewall instance 306 .
- the example service manager 304 provides configuration information to the firewall instance 306 when the service manager 304 receives, via a public or private firewall API (e.g., an API that provides access to functions specific to the firewall) of the service manager 304 , instructions from the firewall instruction generator 206 that include configuration instructions.
- a public or private firewall API e.g., an API that provides access to functions specific to the firewall
- FIGS. 1 , 2 , and 3 While an example manner of implementing the software-defined network 100 , the SDN firewall controller 110 , and the SDN nodes 112 - 118 is illustrated in FIGS. 1 , 2 , and 3 , one or more of the elements, processes and/or devices illustrated in FIGS. 1 , 2 , and 3 may be combined, divided, re-arranged, omitted, eliminated and/or implemented in any other way.
- the example control plane 102 , the example data plane 104 , the example network operating system 106 , the example SDN firewall controller 110 , the example SDN nodes 112 - 118 , the example devices 120 , the example firewall services 122 - 126 , the example firewall policy interpreter 202 , the example firewall node identifier 204 , firewall instruction generator 206 , firewall configuration database 208 , the example packet forwarder 302 , the example service manager 304 , the example firewall instance 306 and/or, more generally, the example service-defined network 100 of FIG. 1 may be implemented by hardware, software, firmware and/or any combination of hardware, software and/or firmware.
- any of the example control plane 102 , the example data plane 104 , the example network operating system 106 , the example SDN firewall controller 110 , the example SDN nodes 112 - 118 , the example devices 120 , the example firewall services 122 - 126 , the example firewall policy interpreter 202 , the example firewall node identifier 204 , firewall instruction generator 206 , firewall configuration database 208 , the example packet forwarder 302 , the example service manager 304 , the example firewall instance 306 and/or, more generally, the example service-defined network 100 could be implemented by one or more analog or digital circuit(s), logic circuits, programmable processor(s), application specific integrated circuit(s) (ASIC(s)), programmable logic device(s) (PLD(s)) and/or field programmable logic device(s) (FPLD(s)).
- ASIC application specific integrated circuit
- PLD programmable logic device
- FPLD field programmable logic device
- At least one of the example control plane 102 , the example data plane 104 , the example network operating system 106 , the example SDN firewall controller 110 , the example SDN nodes 112 - 118 , the example devices 120 , the example firewall services 122 - 126 , the example firewall policy interpreter 202 , the example firewall node identifier 204 , firewall instruction generator 206 , firewall configuration database 208 , the example packet forwarder 302 , the example service manager 304 , and/or the example firewall instance 306 is/are hereby expressly defined to include a tangible computer readable storage device or storage disk such as a memory, a digital versatile disk (DVD), a compact disk (CD), a Blu-ray disk, etc.
- DVD digital versatile disk
- CD compact disk
- Blu-ray disk etc.
- the example service-defined network 100 of FIG. 1 may include one or more elements, processes and/or devices in addition to, or instead of, those illustrated in FIGS. 1 , 2 , and/or 3 , and/or may include more than one of any or all of the illustrated elements, processes and devices.
- FIGS. 4 and 5 Flowcharts representative of example machine readable instructions for implementing the SDN firewall controller 110 and/or the SDN node 300 of FIGS. 1 , 2 , and/or 3 are shown in FIGS. 4 and 5 .
- the machine readable instructions comprise programs for execution by a processor such as the processor 612 shown in the example processor platform 600 discussed below in connection with FIG. 6 .
- the programs may be embodied in software stored on a tangible computer readable storage medium such as a CD-ROM, a floppy disk, a hard drive, a digital versatile disk (DVD), a Blu-ray disk, or a memory associated with the processor 612 , but the entire programs and/or parts thereof could alternatively be executed by a device other than the processor 612 and/or embodied in firmware or dedicated hardware.
- a tangible computer readable storage medium such as a CD-ROM, a floppy disk, a hard drive, a digital versatile disk (DVD), a Blu-ray disk, or a memory associated with the processor 612 , but the entire programs and/or parts thereof could alternatively be executed by a device other than the processor 612 and/or embodied in firmware or dedicated hardware.
- FIGS. 4 and 5 many other methods of implementing the example SDN firewall controller 110 and/or the example SDN node 300 may alternatively be used. For example, the order of execution of the blocks may be changed, and/or some of the
- FIGS. 4 and/or 5 may be implemented using coded instructions (e.g., computer and/or machine readable instructions) stored on a tangible computer readable storage medium such as a hard disk drive, a flash memory, a read-only memory (ROM), a compact disk (CD), a digital versatile disk (DVD), a cache, a random-access memory (RAM) and/or any other storage device or storage disk in which information is stored for any duration (e.g., for extended time periods, permanently, for brief instances, for temporarily buffering, and/or for caching of the information).
- a tangible computer readable storage medium is expressly defined to include any type of computer readable storage device and/or storage disk and to exclude propagating signals and transmission media.
- tangible computer readable storage medium and “tangible machine readable storage medium” are used interchangeably. Additionally or alternatively, the example processes of FIGS. 4 and/or 5 may be implemented using coded instructions (e.g., computer and/or machine readable instructions) stored on a non-transitory computer and/or machine readable medium such as a hard disk drive, a flash memory, a read-only memory, a compact disk, a digital versatile disk, a cache, a random-access memory and/or any other storage device or storage disk in which information is stored for any duration (e.g., for extended time periods, permanently, for brief instances, for temporarily buffering, and/or for caching of the information).
- coded instructions e.g., computer and/or machine readable instructions
- a non-transitory computer and/or machine readable medium such as a hard disk drive, a flash memory, a read-only memory, a compact disk, a digital versatile disk, a cache, a random-access memory and/or any other storage device or storage
- non-transitory computer readable medium is expressly defined to include any type of computer readable storage device and/or storage disk and to exclude propagating signals and transmission media.
- phrase “at least” is used as the transition term in a preamble of a claim, it is open-ended in the same manner as the term “comprising” is open ended.
- FIG. 4 is a flowchart representative of example machine readable instructions 400 which may be executed to implement the example SDN firewall controller 110 of FIGS. 1 and/or 2 to control a distributed firewall in the software-defined network 100 of FIG. 1 .
- the example firewall policy interpreter 202 of FIG. 2 identifies a traffic rule for implementation in a software-defined network (block 402 ).
- the firewall policy interpreter 202 may receive a rule configuration from an administrator of the software-defined network 100 and/or may receive a network traffic rule from a traffic analyzer.
- the example firewall policy interpreter 202 determines a firewall configuration for the network to enforce the network traffic rule (block 404 ).
- the firewall policy interpreter 202 may determine a physical location, a virtual location, a subset of the network 100 to be served by the rule, traffic characteristics to result in filtering traffic, and/or any other configuration details to implement the network traffic rule.
- the example firewall node identifier 204 selects a firewall instance associated with the firewall configuration (block 406 ). For example, the firewall instance may be selected based on network conditions and/or the firewall policy being enacted.
- the example firewall node identifier 204 determines whether the selected firewall instance is instantiated (block 408 ). For example, the firewall node identifier 204 may determine whether a firewall instance determined by the firewall rule interpreter 202 as part of the rule is identified or stored in the firewall configuration database 208 . If the selected firewall instance is not instantiated (block 408 ), the example firewall instruction generator 206 instructs a physical SDN node (e.g., one of the SDN nodes 112 - 118 , 300 of FIGS.
- a physical SDN node e.g., one of the SDN nodes 112 - 118 , 300 of FIGS.
- firewall instruction generator 206 generates instructions to access the API of the SDN node 300 .
- the instructions cause the SDN node 300 to instantiate a virtual machine 310 and to implement the firewall service on the newly-instantiated virtual machine 310 .
- the example firewall instruction generator 206 instructs the selected firewall instance to implement the network traffic rule (block 412 ). For example, the firewall instruction generator 206 generates an instruction including firewall rule configuration information and transmits the instruction to the SDN node 112 - 118 , 300 implementing the selected firewall instance. On receipt, the firewall instance adds, modifies, and/or removes applicable firewall filtering rules to implement the network traffic rule.
- the example firewall node identifier 204 determines the SDN nodes that are to be routed to the selected firewall instance (block 414 ). The firewall node identifier 204 selects one of the determined SDN nodes (block 416 ) and the firewall instruction generator 206 instructs the selected SDN node to route network traffic through the selected firewall instance (block 418 ). For example, the firewall instruction generator 206 may instruct one or more gateways, edge routers, and/or core routers to route applicable network traffic to the selected firewall instance (e.g., instead of a firewall instance to which the selected SDN node was previously directing traffic).
- the example firewall node identifier 204 of this example determines whether there are any additional SDN nodes to be configured (block 420 ). If there are additional SDN nodes (as needed address current network conditions and/or the desired firewall configuration responsive to the needs of the current network) (block 420 ), control returns to block 416 to select another SDN node. When there are any additional SDN nodes to be configured (block 420 ), the example firewall node identifier 204 determines whether there are any additional firewall instances to be configured (as needed address current network conditions and/or the desired firewall configuration responsive to the needs of the current network) (block 422 ). If there are additional firewall instances to be configured (block 422 ), control returns to block 406 to select another firewall instance. When there are no additional firewall instances (block 422 ), the example instructions 400 of FIG. 4 end.
- FIG. 5 is a flowchart representative of example machine readable instructions 500 which may be executed to implement the example SDN nodes 112 - 118 , 300 of FIGS. 1 and/or 3 to implement a distributed firewall policy.
- the example service manager 304 of FIG. 3 exposes SDN APIs for control by an SDN firewall controller (e.g., the SDN firewall controller 110 via the network operating system 106 of FIG. 1 ) (block 502 ).
- the SDN APIs are public APIs that may be used by other SDN services or applications to control services on the SDN node 300 .
- one or more SDN APIs are private APIs that are exposed when the firewall instance 306 is instantiated at the SDN node 300 .
- the example service manager 304 of the illustrated example determines whether instruction(s) have been received (e.g., from the SDN firewall controller 110 ) to instantiate a firewall (block 504 ). If instruction(s) have been received to instantiate a firewall (block 504 ), the example service manager 304 instantiates a virtual machine for the firewall instance (block 506 ).
- the example service manager applies firewall node properties (e.g., install firewall application components, basic SDN properties associated with the SDN node 300 , etc.) to the virtual machine (block 508 ).
- the firewall instance 306 is executed upon application of the firewall properties and begins filtering network traffic received at the SDN node 300 (e.g., at the packet forwarder 302 ) in accordance with the properties of the firewall instance 306 .
- the example service manager 304 of FIG. 3 registers the firewall instance 306 with the network (e.g., with the operating system 106 ) and/or with the SDN firewall controller 110 .
- a registration message may be returned to the SDN firewall controller 110 as a response to an access of the API by the SDN firewall controller 110 .
- the example service manager 304 of FIG. 3 determines whether instruction(s) have been received to enforce firewall rule(s) at the firewall instance 306 of the SDN node (block 512 ).
- the service manager 304 may receive configuration information from the SDN firewall controller 110 via the same API, a different public API, and/or a private, firewall-specific API.
- the instruction(s) to enforce a firewall rule may include, for example, new and/or updated traffic filtering rules, load balancing rules, and/or any other firewall implementation rules determined by the SDN firewall controller 110 to be implemented (at least partially) at the firewall instance 306 .
- the example service manager 304 and/or the firewall instance 306 configure the firewall instance 306 to enforce the firewall rule (block 514 ).
- the example instructions 500 of FIG. 5 end.
- blocks 504 - 514 may be repeated to maintain exposed SDN APIs for configuration by the control plane 102 (e.g., via the SDN firewall controller 110 ).
- FIG. 6 is a block diagram of an example processor platform 600 capable of executing the instructions of FIGS. 4 and/or 5 to implement the SDN firewall controller 110 and/or the SDN node 300 of FIGS. 1 , 2 , and/or 3 .
- the processor platform 600 can be, for example, a server, a personal computer, or any other type of computing device.
- the processor platform 600 of the illustrated example includes a processor 612 .
- the processor 612 of the illustrated example is hardware.
- the processor 612 can be implemented by one or more integrated circuits, logic circuits, microprocessors or controllers from any desired family or manufacturer.
- the processor 612 of the illustrated example includes a local memory 613 (e.g., a cache).
- the processor 612 of the illustrated example is in communication with a main memory including a volatile memory 614 and a non-volatile memory 616 via a bus 618 .
- the volatile memory 614 may be implemented by Synchronous Dynamic Random Access Memory (SDRAM), Dynamic Random Access Memory (DRAM), RAMBUS Dynamic Random Access Memory (RDRAM) and/or any other type of random access memory device.
- the non-volatile memory 616 may be implemented by flash memory and/or any other desired type of memory device. Access to the main memory 614 , 616 is controlled by a memory controller.
- the processor platform 600 of the illustrated example also includes an interface circuit 620 .
- the interface circuit 620 may be implemented by any type of interface standard, such as an Ethernet interface, a universal serial bus (USB), and/or a PCI express interface.
- one or more input devices 622 are connected to the interface circuit 620 .
- the input device(s) 622 permit(s) a user to enter data and commands into the processor 612 .
- the input device(s) can be implemented by, for example, an audio sensor, a microphone, a camera (still or video), a keyboard, a button, a mouse, a touchscreen, a track-pad, a trackball, isopoint and/or a voice recognition system.
- One or more output devices 624 are also connected to the interface circuit 620 of the illustrated example.
- the output devices 624 can be implemented, for example, by display devices (e.g., a light emitting diode (LED), an organic light emitting diode (OLED), a liquid crystal display, a cathode ray tube display (CRT), a touchscreen, a tactile output device, a light emitting diode (LED), a printer and/or speakers).
- the interface circuit 620 of the illustrated example thus, typically includes a graphics driver card, a graphics driver chip or a graphics driver processor.
- the interface circuit 620 of the illustrated example also includes a communication device such as a transmitter, a receiver, a transceiver, a modem and/or network interface card to facilitate exchange of data with external machines (e.g., computing devices of any kind) via a network 626 (e.g., an Ethernet connection, a digital subscriber line (DSL), a telephone line, coaxial cable, a cellular telephone system, etc.).
- a communication device such as a transmitter, a receiver, a transceiver, a modem and/or network interface card to facilitate exchange of data with external machines (e.g., computing devices of any kind) via a network 626 (e.g., an Ethernet connection, a digital subscriber line (DSL), a telephone line, coaxial cable, a cellular telephone system, etc.).
- DSL digital subscriber line
- the processor platform 600 of the illustrated example also includes one or more mass storage devices 628 for storing software and/or data.
- mass storage devices 628 include floppy disk drives, hard drive disks, compact disk drives, Blu-ray disk drives, RAID systems, and digital versatile disk (DVD) drives.
- the coded instructions 632 of FIGS. 4 and/or 5 may be stored in the mass storage device 628 , in the volatile memory 614 , in the non-volatile memory 616 , and/or on a removable tangible computer readable storage medium such as a CD or DVD.
- Examples disclosed herein have advantages over known firewalls that include reducing the complexity of network design and network security implementation. Examples disclosed herein also enable deployment of security policies throughout entire networks such that, in contrast to networks using known firewalls, network attacks or other restricted traffic can be blocked prior to exposing the network nodes to the attacks or restricted traffic.
- Examples disclosed herein also increase the performance of entire networks (relative to known firewalls) because the network is freed from carrying restricted traffic additional hops toward the destination before the traffic can be filtered.
- Examples disclosed herein may be structured to distribute the firewall at or closer to the edges of the network, which allows each firewall to filter smaller numbers of traffic flows, and (in contrast to known centralized firewalls that must have highly-scalable throughput) to successfully block large numbers of traffic flows at concentrated locations.
- the entire software-defined network can be configured to function as a firewall at each SDN node, rather than as a network that includes attached firewalls.
- examples disclosed herein are more adaptable to current network conditions.
- example firewalls disclosed herein are adaptable to current users and/or traffic patterns of a network that enable the firewall policies of the network to be efficiently applied.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Security & Cryptography (AREA)
- Computer Hardware Design (AREA)
- Computing Systems (AREA)
- General Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- General Business, Economics & Management (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
Description
- The subject patent application is a continuation of, and claims priority to each of, U.S. patent application Ser. No. 17/321,566, filed May 17, 2021, and entitled “METHODS AND APPARATUS TO PROVIDE A DISTRIBUTED FIREWALL IN A NETWORK,” which is a continuation of U.S. patent application Ser. No. 16/836,514 (now U.S. Pat. No. 11,044,232), filed Mar. 31, 2020, and entitled “METHODS AND APPARATUS TO PROVIDE A DISTRIBUTED FIREWALL IN A NETWORK,” which is a continuation of U.S. patent application Ser. No. 15/594,010 (now U.S. Pat. No. 10,623,373), filed May 12, 2017, and entitled, “METHODS AND APPARATUS TO PROVIDE A DISTRIBUTED FIREWALL IN A NETWORK,” which is a continuation of U.S. patent application Ser. No. 14/271,185 (now U.S. Pat. No. 9,674,147), filed May 6, 2014, and entitled, “METHODS AND APPARATUS TO PROVIDE A DISTRIBUTED FIREWALL IN A NETWORK,” the respective entireties of which priority applications are hereby incorporated by reference herein.
- In known communications networks, network functions are performed using specialized hardware that accelerates one or more functions relative to general-purpose machines. Control and configuration of the network is generally performed by accessing a device to be configured and performing configuration tasks specific to the hardware in the device.
-
FIG. 1 is a block diagram of an example software-defined network constructed in accordance with the teachings of this disclosure to provide a distributed firewall in the software-defined network. -
FIG. 2 is a block diagram of an example software-defined networking firewall controller constructed in accordance with the teachings of this disclosure to control a distributed firewall in a software-defined network. -
FIG. 3 is a block diagram of an example SDN node to implement a firewall policy. -
FIG. 4 is a flowchart representative of example machine readable instructions which may be executed to implement the example software-defined networking firewall controller ofFIGS. 1 and/or 2 to control a distributed firewall in a software-defined network. -
FIG. 5 is a flowchart representative of example machine readable instructions which may be executed to implement the example software-defined networking node ofFIGS. 1 and/or 3 to implement a distributed firewall policy. -
FIG. 6 is a block diagram of an example processor platform capable of executing the instructions ofFIGS. 4 and/or 5 to implement the apparatus ofFIGS. 1, 2 , and/or 3. - The figures are not to scale. Wherever appropriate, the same reference numbers will be used throughout the drawing(s) and accompanying written description to refer to the same or like parts.
- Software-defined networking (SDN) is a network technology that addresses customization and optimization concerns within networks. SDN simplifies modern networks by decoupling the data-forwarding capability (e.g., the data plane or forwarding plane) from routing, resource, and other management functionality (e.g., the control plane). Both the control plane and data plane functions are performed at the network nodes in known networks. Network nodes that support SDN (e.g., that are SDN-compliant) may be configured to implement data plane functions. Control plane functions are performed by an SDN controller. SDN networks currently use Application Programming Interface (API) services, such as the OpenFlow protocol or OnePK protocol, to manage the interactions between the data plane and the control plane.
- Known implementations of network firewalls are centralized and operate independently of other firewalls and network elements. Known methods of operating firewalls independently of each other leads to requirements including a) funneling traffic (e.g., all traffic on the network) from the entry points through the firewalls to apply firewall policies and/or b) placing firewalls in every physical or logical location that a policy is needed, which increases infrastructure costs. Firewall hardware costs, limits on scalability, management costs, and deployment complexity limit the number of firewalls that can be cost-effectively deployed in a network. As a result, network traffic using known firewalls often must traverse a substantial portion of the network to reach the firewall. When such traffic is dropped due to the firewall policies, network capacity used to carry the dropped traffic to the firewall is wasted.
- Examples disclosed herein solve problems associated with known firewall implementations by using SDN to provide a distributed firewall application. In some examples, the distributed firewall application permits any and/or every SDN node or element in a software-defined network to be programmed to provide firewall services, thereby reducing the need for funneling traffic and decreasing infrastructure costs.
- Examples disclosed herein deploy and manage instances of the firewall from a central management server or SDN node (e.g., an SDN firewall controller). SDN firewall controllers in disclosed examples define and analyze firewall policies for implementation in software-defined networks. As a result, security policies can be applied throughout a network (e.g., closer to data entry points rather than closer to a data destination). Examples disclosed herein enable the network to change a network wide security policy as often as needed to maintain network security and performance. For example, example networks may update the firewall policies across the network, as often as every time a user logs onto the network, to accommodate the security policy of that specific user, the device(s) the user is using to access the network, and the resources to which the user needs access. In contrast, known firewalls are updated only when a firewall policy update can be designed for each type of firewall in the network. Thus, in contrast to the relatively static firewalls of known networks, example SDN firewalls disclosed herein are dynamic and adapt to the current circumstances and use(s) of the network.
- Examples disclosed herein identify, at a control plane, a network traffic rule to implement in a network; determine, at the control plane, a distributed firewall for a first firewall in the network to enforce the network traffic rule; instruct, using the control plane, a first software-defined networking node to instantiate the first firewall of the distributed firewall; configure a second software-defined networking node to route network traffic through the first firewall; and instruct the first software-defined networking node to enforce the network traffic rule.
- In some examples, instructing the first software-defined networking node to instantiate the first firewall includes instructing the first software-defined networking node to instantiate a virtual machine to implement a firewall software application. Some examples further include instructing a third software-defined networking node to modify a first firewall policy of a second firewall at the third software-defined networking node to enforce the network traffic rule. In some such examples, instructing the third software-defined networking node includes instructing the third software-defined networking node to execute the second firewall using the first firewall policy, and instructing the first software-defined networking node to enforce the network traffic rule comprises instructing the first software-defined networking node to execute the first firewall using a second firewall policy, the first firewall policy being independent from the second firewall policy. In some examples, the first and second firewalls are part of the distributed firewall.
- In some examples, the first software-defined networking node is an edge network node. Some examples further identify, at the control plane, a change to the network traffic rule to implement in the network; identify, at the control plane, a set of software-defined networking nodes on which firewalls of the distributed firewall are implemented; and transmit instructions from the control plane to the set of software-defined networking nodes to cause the firewalls to implement the change to the network traffic rule, the instructions to the software-defined networking nodes in the set being respectively customized for the firewall to which the instructions are transmitted.
- In some examples, determining the distributed firewall for the network to enforce the network traffic rule includes determining, at the control plane, a portion of the network to which the network traffic rule is to be applied; identifying, at the control plane, software-defined networking nodes in the network to serve the portion of the network; transmitting instructions to a first portion of the identified software-defined networking nodes to cause the first portion of the identified software-defined networking nodes to instantiate respective firewall software applications; and transmitting instructions to the identified software-defined networking nodes to cause the identified software-defined networking nodes to implement the traffic rule via respective firewall software applications.
-
FIG. 1 is a block diagram of an example software-defined network 100 constructed in accordance with the teachings of this disclosure to provide a distributed firewall in the software-defined network 100. The example software-defined network 100 is divided into acontrol plane 102 and adata plane 104. Theexample control plane 102 is implemented using one or more SDN nodes (e.g., computing devices), but is illustrated inFIG. 1 as a single logical entity. - The
control plane 102 includes one or more control devices that execute anetwork operating system 106 to control (e.g., configure, monitor) devices in thedata plane 104. The examplenetwork operating system 106 executes one or more SDN applications including anSDN firewall controller 110. The examplenetwork operating system 106 supports theSDN firewall controller 110 and/or any additional SDN applications executed at thenetwork operating system 106. - As disclosed below in more detail, the example
SDN firewall controller 110 controls, via thenetwork operating system 106, a distributed firewall that is implemented via thedata plane 104. As described in more detail below, the distributed firewall provides network traffic filtering to enhance security, reliability, and/or efficiency of the network. The distributed firewall of the example ofFIG. 1 may include firewall services for private or virtual private networks, and/or any other firewall services (e.g., specialized firewall services) desired by users of the network. - The
example data plane 104 ofFIG. 1 includes SDN nodes 112-118 (e.g., computing devices, network nodes) that implement the functions of the network (e.g., filtering, routing, etc.) for network traffic. The example SDN nodes 112-118 are controlled (e.g., configured) by the example control plane 102 (e.g., by the network operating system 106), which accesses application programming interfaces (APIs) of the SDN nodes 112-118 to configure the network services being provided by the SDN nodes 112-118. In some examples, thenetwork operating system 106 abstracts all or part of the APIs of the SDN nodes 112-118 for access by theSDN firewall controller 110. Abstracting the APIs enables the SDN firewall controller to access the API via thenetwork operating system 106 using a consistent set of commands and/or configuration routines, which are then implemented by thenetwork operating system 106 on the desired nodes 112-118 (e.g., nodes indicated as arguments in the API call) using device-specific commands and/or configuration routines. - The example SDN nodes 112-118 operate as gateways, edge routers, and/or core routers. The SDN nodes 112-118 are configurable by the
control plane 102 to implement any set or subset of SDN services. Examples of SDN services include routing, traffic filtering, and/or load balancing. The examplenetwork operating system 106 ofFIG. 1 configuresrespective devices 120, which may be consumer devices, routers, gateways, and/or edge routers, and/or SDN nodes implementing such consumer and/or networking devices, to route traffic to the SDN nodes 112-118 based on forwarding tables and/or other rules. - In the example of
FIG. 1 , each of theSDN nodes respective firewall instance SDN firewall controller 110 independently of other ones of the firewall instances 122-126. Accordingly, examples disclosed herein treat each of the firewall instances 122-126 as instances of a firewall service. However, the firewall instances 122-126 collectively provide a distributed firewall for the software-definednetwork 100 to implement the firewall strategy as it is defined at theSDN firewall controller 110. - In the example of
FIG. 1 , theSDN node 118 does not implement an instance of the distributed firewall service (e.g., a firewall instance). Instead, thenetwork operating system 106 and/or theSDN firewall controller 110 configures the SDN node 118 (e.g., a gateway, an edge router) to route network traffic through one or more of theSDN nodes firewall instances firewall instances SDN node 118 to theSDN nodes firewall instances firewall instances devices 120 due to traffic entering thenetwork 100 at theSDN nodes SDN node 118 to theSDN nodes - When the example
SDN firewall controller 110 recognizes these or other problems, theSDN firewall controller 110 of the illustrated example may alleviate the problem by instantiating a firewall service at theSDN node 118. In contrast to known networks that require specialized firewall hardware to be physically installed and/or configured, the exampleSDN firewall controller 110 ofFIG. 1 transmits instructions to theSDN node 118 via thenetwork operating system 106 to cause theSDN node 118 to instantiate a new firewall instance in software, thereby enhancing the performance of the firewall services of the software-definednetwork 100 and adapting the firewall strategy to real time network conditions. The example software-definednetwork 100 illustrated inFIG. 1 can nearly instantly respond to network conditions involving the distributed firewall. - The SDN nodes implementing the
control plane 102 in the example ofFIG. 1 are different nodes than theSDN nodes data plane 104. For example, thecontrol plane 102 may include one ormore SDN nodes 128 to implement thenetwork operating system 106 and/or theSDN firewall controller 110. Theexample SDN nodes 128 of thecontrol plane 102 communicate with the nodes 112-118 via control paths of thenetwork 130. While only 5 nodes 112-118, 128 are shown in theexample network 100 ofFIG. 1 , a network may have hundreds, thousands, or more nodes. In some examples, one ormore SDN nodes data plane 104 also implement thecontrol plane 102. -
FIG. 2 is a block diagram of an example implementation of the exampleSDN firewall controller 110 ofFIG. 1 . The exampleSDN firewall controller 110 ofFIG. 2 is implemented on one or more SDN nodes (e.g., theSDN node 128 ofFIG. 1 ), which may be separate from SDN nodes 112-118 implementing thedata plane 104 and/or may also implement thedata plane 104. - The example
SDN firewall controller 110 ofFIG. 2 includes afirewall policy interpreter 202, afirewall node identifier 204, afirewall instruction generator 206, and afirewall configuration database 208. In the example ofFIG. 1 , firewall configuration (e.g., all firewall configuration) occurs via theSDN firewall controller 110 and/or is controlled by theSDN firewall controller 110. Thus, the exampleSDN firewall controller 110 of the illustrated example has knowledge of the firewall configuration of the software-definednetwork 100 and implements any and all user firewall configuration commands (e.g., all configuration commands) at the firewall nodes. The exampleSDN firewall controller 110 of the illustrated example also has (and/or can rapidly obtain from the network operating system 106) knowledge of the physical and/or logical topologies of the software-definednetwork 100 and/or the statuses (e.g., configurations, operational statuses, etc.) of the nodes 112-118. - In the example of
FIG. 2 , the SDN firewall controller 110 (e.g., via thefirewall policy interpreter 202 ofFIG. 2 ) receives and/or identifies network traffic rules for implementation in the software-definednetwork 100. For example, a network administrator may define and/or provide a filtering policy or rule to thefirewall policy interpreter 202 for instructing the software-definednetwork 100 to drop packets having a particular source Internet Protocol (IP) address. Another example rule may include granting a defined group of users in a system (e.g., a “marketing” group, a “field technicians” group, etc.) access to a designated set of applications in a corporate virtual private network. Rules provided manually may be provided using a user interface, a rule description language, and/or any other interface mechanism implemented in the software-definednetwork 100. - Additionally or alternatively, the example
firewall policy interpreter 202 may receive a firewall policy or rule that is automatically generated by a security service based on activity in the network (e.g., by traffic analysis of the software-defined network). For example, thefirewall policy interpreter 202 may receive a firewall rule to temporarily block traffic destined for a particular port at a particular IP address. The examplefirewall policy interpreter 202 may determine that the firewall rule is to be implemented at each firewall instance 122-126 in the software-defined network 100 (e.g., to drop packets matching the filter rule as early as possible). - The example
firewall node identifier 204 of the illustrated example determines a firewall configuration (e.g., identifies firewall nodes) for the software-definednetwork 100 to enforce the network traffic rule. For example, some network traffic rules may affect only a limited number of firewall applications and/or SDN nodes 112-118. The example firewall rule may then be selectively applied to the firewall instances and/or applications executing on those SDN nodes 112-118 to reduce the processing resource requirement on SDN nodes 112-118 that do not need to implement the policy. On the other hand, other network traffic rules may require all of the firewall instances in the software-definednetwork 100 to be instructed to implement the traffic rule. - In some examples, the
firewall policy interpreter 202 determines that the distributed firewall is a traffic bottleneck at a particular node. In some such examples, thefirewall node identifier 204 may determine that creating one or more additional firewall instances at designated nodes 112-118 (which may or may not already have a firewall instance such as thenode 118 ofFIG. 1 ) are to be created to handle the traffic, and/or that the traffic destined for the bottleneck firewalls may be redistributed to other SDN nodes 112-118 executing the firewall instances and/or applications. - The
firewall node identifier 204 of the example ofFIG. 2 determines the appropriate instances 122-126 and/or nodes 112-118 ofFIG. 1 for efficient implementation of the firewall, including adding firewall instances, migrating firewall instances between nodes, eliminating firewall instances, and/or updating firewall instances and/or routing forwarding tables of other nodes 112-118 and/ordevices 120. - The example
firewall instruction generator 206 ofFIG. 2 instructs (e.g., via the network operating system 106) the appropriate SDN node 112-118 to instantiate firewall(s). For example, thefirewall instruction generator 206 generates instructions for transmission to a first one of the SDN nodes 112-118 (e.g., to theSDN node 112 via an SDN API of the SDN node 112). In this example, the instructions cause the SDN node 112-118 to instantiate a virtual machine and implement (e.g., install, load, etc.) a firewall application for execution on the virtual machine. The SDN node(s) 112-118 provide the hardware (e.g., computing, communications) resources used by the corresponding virtual machine(s) and the firewall application(s) to perform the firewall actions. In some examples, a given SDN node 112-118 is already executing one or more firewall instances and instantiates an additional firewall instance in response to the instruction from thefirewall instruction generator 206. - The example
firewall configuration database 208 ofFIG. 2 stores the firewall configuration of the software-definednetwork 100. For example, thefirewall configuration database 208 stores the locations of the firewall instances 122-126 (e.g., physical locations and/or virtual locations), the firewall policies and/or rules configured at the firewall instances 122-126, and/or portions of the software-defined network that are served by the firewall instances 122-126. For example, some firewall instances may be configured to serve a particular virtual private local area network, while other firewall instances may be configured to serve traffic routed through a public network. In some examples, a subset of gateways, edge routers, and/or core routers in thenetwork 100 are served by a particular firewall instance (e.g., executing on one or more of the SDN node(s) 112-118). - In the illustrated example, when a firewall instance is created at an SDN node 112-118, the example
firewall node identifier 204 selects the gateways, edge routers, and/or core routers and thefirewall instruction generator 206 configures them to route traffic for filtering by the firewall instance. The examplefirewall configuration database 208 ofFIG. 2 stores the information associated with the newly-instantiated firewall instance for reference by thefirewall policy interpreter 202, thefirewall node identifier 204, and/or thefirewall instruction generator 206. - In the example of
FIG. 2 , the examplefirewall configuration database 208 also stores firewall audit logs obtained from the firewall instances in response to success/fail audits of the firewall instances. Additionally or alternatively, thefirewall configuration database 208 stores notable network events from the firewall instances. The examplefirewall policy interpreter 202 of the illustrated example analyzes the disparate network events from the firewall instances that are distributed across the software-definednetwork 100 to identify traffic trends (e.g., increasing traffic from and/or in a portion of the network) and/or identify distributed attacks (e.g., distributed denial of service attacks). In response to identifying trends and/or attacks, thefirewall policy interpreter 202 ofFIG. 2 generates remedial firewall rules or policies for implementation at the firewall instances. - In the example of
FIG. 2 , after instructing an SDN node 112-118 to create a firewall instance (or if the firewall instance is already present), the examplefirewall instruction generator 206 configures one or more other software-defined networking nodes (e.g., network gateways, edge routers, etc.) to route network traffic through the firewall instance. In some examples, thefirewall node identifier 204 identifies ones of the SDN nodes 112-118 and/or thedevices 120 in the software-definednetwork 100 that are to be configured to route traffic to the newly-instantiated firewall instance. - The example
firewall instruction generator 206 also instructs the firewall instance executing on the SDN node 112-118 to enforce the network traffic rule as interpreted by thefirewall policy interpreter 202. For example, thefirewall instruction generator 206 generates and sends instructions to the firewall instance via thenetwork operating system 106. -
FIG. 3 is a block diagram of anexample SDN node 300 to implement a firewall policy. Theexample SDN node 300 ofFIG. 3 may implement any of the example SDN nodes 112-118 ofFIG. 1 . Theexample SDN node 300 ofFIG. 3 includes apacket forwarder 302, aservice manager 304, afirewall instance 306, and one or more other virtual service instance(s) 308. - The
example packet forwarder 302 ofFIG. 3 executes on the underlying hardware of theSDN node 300, including processor(s), memory, and/or communications interfaces (e.g., incoming data ports, outgoing data ports, hardware interconnects, etc.). Theexample packet forwarder 302 of this example receives network traffic (e.g., data packets), processes the traffic in accordance with the services executing on the SDN node 300 (e.g., thefirewall instance 306 and/or other virtual service instances 308), and forwards the traffic or drops the traffic accordingly. In some examples, thepacket forwarder 302 executes on and/or is implemented by multiple scalable hardware devices controlled as a single logical device by theservice manager 304. - The
example service manager 304 ofFIG. 3 manages services executing on theSDN node 300 and provides an interface between theservices packet forwarder 302. For example, theservice manager 304 may include a virtual machine manager that managesvirtual machines 310 implementing SDN services and/or software applications. Examples of such services that are managed by theservice manager 304 include thefirewall instance 306. Theservice manager 304 may support any number of virtual services. Additionally or alternatively, theservice manager 304 provides access for thefirewall instance 306 to the hardware resources of thepacket forwarder 302 to, for example, enable thefirewall instance 306 to apply the firewall rules to the traffic received at thepacket forwarder 302. In some examples, theservice manager 304 configures thefirewall instance 306 such that thefirewall instance 306 logically receives the traffic that is received at thepacket forwarder 302. Theservice manager 304 further provides thefirewall instance 306 with the processing resources to apply the firewall rules to thepacket forwarder 302. - The
service manager 304 ofFIG. 3 exposes an API that may be accessed by thenetwork operating system 106 and/or theSDN firewall controller 110 ofFIG. 1 . For example, theservice manager 304 receives instructions from theSDN firewall controller 110 ofFIG. 1 via the API for implementing and/or configuring the firewall instance 306 (and/or additional firewall instances). Theservice manager 304 instantiates thefirewall instance 306 in avirtual machine 310, for example, in response to an instruction from thefirewall instruction generator 206 to instantiate a firewall. - In some examples, the
service manager 304 exposes a specialized API in response to instantiating thefirewall instance 306. For example, theexample service manager 304 provides configuration information to thefirewall instance 306 when theservice manager 304 receives, via a public or private firewall API (e.g., an API that provides access to functions specific to the firewall) of theservice manager 304, instructions from thefirewall instruction generator 206 that include configuration instructions. - While an example manner of implementing the software-defined
network 100, theSDN firewall controller 110, and the SDN nodes 112-118 is illustrated inFIGS. 1, 2, and 3 , one or more of the elements, processes and/or devices illustrated inFIGS. 1, 2, and 3 may be combined, divided, re-arranged, omitted, eliminated and/or implemented in any other way. Further, theexample control plane 102, theexample data plane 104, the examplenetwork operating system 106, the exampleSDN firewall controller 110, the example SDN nodes 112-118, theexample devices 120, the example firewall services 122-126, the examplefirewall policy interpreter 202, the examplefirewall node identifier 204,firewall instruction generator 206,firewall configuration database 208, theexample packet forwarder 302, theexample service manager 304, theexample firewall instance 306 and/or, more generally, the example service-definednetwork 100 ofFIG. 1 may be implemented by hardware, software, firmware and/or any combination of hardware, software and/or firmware. Thus, for example, any of theexample control plane 102, theexample data plane 104, the examplenetwork operating system 106, the exampleSDN firewall controller 110, the example SDN nodes 112-118, theexample devices 120, the example firewall services 122-126, the examplefirewall policy interpreter 202, the examplefirewall node identifier 204,firewall instruction generator 206,firewall configuration database 208, theexample packet forwarder 302, theexample service manager 304, theexample firewall instance 306 and/or, more generally, the example service-definednetwork 100 could be implemented by one or more analog or digital circuit(s), logic circuits, programmable processor(s), application specific integrated circuit(s) (ASIC(s)), programmable logic device(s) (PLD(s)) and/or field programmable logic device(s) (FPLD(s)). When reading any of the apparatus or system claims of this patent to cover a purely software and/or firmware implementation, at least one of theexample control plane 102, theexample data plane 104, the examplenetwork operating system 106, the exampleSDN firewall controller 110, the example SDN nodes 112-118, theexample devices 120, the example firewall services 122-126, the examplefirewall policy interpreter 202, the examplefirewall node identifier 204,firewall instruction generator 206,firewall configuration database 208, theexample packet forwarder 302, theexample service manager 304, and/or theexample firewall instance 306 is/are hereby expressly defined to include a tangible computer readable storage device or storage disk such as a memory, a digital versatile disk (DVD), a compact disk (CD), a Blu-ray disk, etc. storing the software and/or firmware. Further still, the example the example service-definednetwork 100 ofFIG. 1 may include one or more elements, processes and/or devices in addition to, or instead of, those illustrated inFIGS. 1, 2 , and/or 3, and/or may include more than one of any or all of the illustrated elements, processes and devices. - Flowcharts representative of example machine readable instructions for implementing the
SDN firewall controller 110 and/or theSDN node 300 ofFIGS. 1, 2 , and/or 3 are shown inFIGS. 4 and 5 . In this example, the machine readable instructions comprise programs for execution by a processor such as theprocessor 612 shown in theexample processor platform 600 discussed below in connection withFIG. 6 . The programs may be embodied in software stored on a tangible computer readable storage medium such as a CD-ROM, a floppy disk, a hard drive, a digital versatile disk (DVD), a Blu-ray disk, or a memory associated with theprocessor 612, but the entire programs and/or parts thereof could alternatively be executed by a device other than theprocessor 612 and/or embodied in firmware or dedicated hardware. Further, although the example programs are described with reference to the flowcharts illustrated inFIGS. 4 and 5 , many other methods of implementing the exampleSDN firewall controller 110 and/or theexample SDN node 300 may alternatively be used. For example, the order of execution of the blocks may be changed, and/or some of the blocks described may be changed, eliminated, or combined. - As mentioned above, the example processes of
FIGS. 4 and/or 5 may be implemented using coded instructions (e.g., computer and/or machine readable instructions) stored on a tangible computer readable storage medium such as a hard disk drive, a flash memory, a read-only memory (ROM), a compact disk (CD), a digital versatile disk (DVD), a cache, a random-access memory (RAM) and/or any other storage device or storage disk in which information is stored for any duration (e.g., for extended time periods, permanently, for brief instances, for temporarily buffering, and/or for caching of the information). As used herein, the term tangible computer readable storage medium is expressly defined to include any type of computer readable storage device and/or storage disk and to exclude propagating signals and transmission media. As used herein, “tangible computer readable storage medium” and “tangible machine readable storage medium” are used interchangeably. Additionally or alternatively, the example processes ofFIGS. 4 and/or 5 may be implemented using coded instructions (e.g., computer and/or machine readable instructions) stored on a non-transitory computer and/or machine readable medium such as a hard disk drive, a flash memory, a read-only memory, a compact disk, a digital versatile disk, a cache, a random-access memory and/or any other storage device or storage disk in which information is stored for any duration (e.g., for extended time periods, permanently, for brief instances, for temporarily buffering, and/or for caching of the information). As used herein, the term non-transitory computer readable medium is expressly defined to include any type of computer readable storage device and/or storage disk and to exclude propagating signals and transmission media. As used herein, when the phrase “at least” is used as the transition term in a preamble of a claim, it is open-ended in the same manner as the term “comprising” is open ended. -
FIG. 4 is a flowchart representative of example machinereadable instructions 400 which may be executed to implement the exampleSDN firewall controller 110 ofFIGS. 1 and/or 2 to control a distributed firewall in the software-definednetwork 100 ofFIG. 1 . - The example
firewall policy interpreter 202 ofFIG. 2 identifies a traffic rule for implementation in a software-defined network (block 402). For example, thefirewall policy interpreter 202 may receive a rule configuration from an administrator of the software-definednetwork 100 and/or may receive a network traffic rule from a traffic analyzer. The examplefirewall policy interpreter 202 determines a firewall configuration for the network to enforce the network traffic rule (block 404). For example, thefirewall policy interpreter 202 may determine a physical location, a virtual location, a subset of thenetwork 100 to be served by the rule, traffic characteristics to result in filtering traffic, and/or any other configuration details to implement the network traffic rule. - The example
firewall node identifier 204 selects a firewall instance associated with the firewall configuration (block 406). For example, the firewall instance may be selected based on network conditions and/or the firewall policy being enacted. The examplefirewall node identifier 204 determines whether the selected firewall instance is instantiated (block 408). For example, thefirewall node identifier 204 may determine whether a firewall instance determined by thefirewall rule interpreter 202 as part of the rule is identified or stored in thefirewall configuration database 208. If the selected firewall instance is not instantiated (block 408), the examplefirewall instruction generator 206 instructs a physical SDN node (e.g., one of the SDN nodes 112-118, 300 ofFIGS. 1 and/or 3 ) to instantiate a firewall application (e.g., the firewall services 122-126, 306 ofFIGS. 1 and/or 3 ) (block 410). For example, thefirewall instruction generator 206 generates instructions to access the API of theSDN node 300. The instructions cause theSDN node 300 to instantiate avirtual machine 310 and to implement the firewall service on the newly-instantiatedvirtual machine 310. - After instructing the physical SDN node to instantiate the firewall application (block 410), or if the selected firewall instance is already instantiated (block 408), the example
firewall instruction generator 206 instructs the selected firewall instance to implement the network traffic rule (block 412). For example, thefirewall instruction generator 206 generates an instruction including firewall rule configuration information and transmits the instruction to the SDN node 112-118, 300 implementing the selected firewall instance. On receipt, the firewall instance adds, modifies, and/or removes applicable firewall filtering rules to implement the network traffic rule. - The example
firewall node identifier 204 determines the SDN nodes that are to be routed to the selected firewall instance (block 414). Thefirewall node identifier 204 selects one of the determined SDN nodes (block 416) and thefirewall instruction generator 206 instructs the selected SDN node to route network traffic through the selected firewall instance (block 418). For example, thefirewall instruction generator 206 may instruct one or more gateways, edge routers, and/or core routers to route applicable network traffic to the selected firewall instance (e.g., instead of a firewall instance to which the selected SDN node was previously directing traffic). - The example
firewall node identifier 204 of this example determines whether there are any additional SDN nodes to be configured (block 420). If there are additional SDN nodes (as needed address current network conditions and/or the desired firewall configuration responsive to the needs of the current network) (block 420), control returns to block 416 to select another SDN node. When there are any additional SDN nodes to be configured (block 420), the examplefirewall node identifier 204 determines whether there are any additional firewall instances to be configured (as needed address current network conditions and/or the desired firewall configuration responsive to the needs of the current network) (block 422). If there are additional firewall instances to be configured (block 422), control returns to block 406 to select another firewall instance. When there are no additional firewall instances (block 422), theexample instructions 400 ofFIG. 4 end. -
FIG. 5 is a flowchart representative of example machinereadable instructions 500 which may be executed to implement the example SDN nodes 112-118, 300 ofFIGS. 1 and/or 3 to implement a distributed firewall policy. - The
example service manager 304 ofFIG. 3 exposes SDN APIs for control by an SDN firewall controller (e.g., theSDN firewall controller 110 via thenetwork operating system 106 ofFIG. 1 ) (block 502). In some examples, the SDN APIs are public APIs that may be used by other SDN services or applications to control services on theSDN node 300. In some other examples, one or more SDN APIs are private APIs that are exposed when thefirewall instance 306 is instantiated at theSDN node 300. - The
example service manager 304 of the illustrated example determines whether instruction(s) have been received (e.g., from the SDN firewall controller 110) to instantiate a firewall (block 504). If instruction(s) have been received to instantiate a firewall (block 504), theexample service manager 304 instantiates a virtual machine for the firewall instance (block 506). The example service manager applies firewall node properties (e.g., install firewall application components, basic SDN properties associated with theSDN node 300, etc.) to the virtual machine (block 508). In some examples, thefirewall instance 306 is executed upon application of the firewall properties and begins filtering network traffic received at the SDN node 300 (e.g., at the packet forwarder 302) in accordance with the properties of thefirewall instance 306. - The
example service manager 304 ofFIG. 3 registers thefirewall instance 306 with the network (e.g., with the operating system 106) and/or with theSDN firewall controller 110. For example, a registration message may be returned to theSDN firewall controller 110 as a response to an access of the API by theSDN firewall controller 110. - After registering the firewall instance 306 (block 510), and/or if instructions have not been received to instantiate the firewall instance (block 504), the
example service manager 304 ofFIG. 3 determines whether instruction(s) have been received to enforce firewall rule(s) at thefirewall instance 306 of the SDN node (block 512). For example, theservice manager 304 may receive configuration information from theSDN firewall controller 110 via the same API, a different public API, and/or a private, firewall-specific API. The instruction(s) to enforce a firewall rule may include, for example, new and/or updated traffic filtering rules, load balancing rules, and/or any other firewall implementation rules determined by theSDN firewall controller 110 to be implemented (at least partially) at thefirewall instance 306. - If instruction(s) to enforce firewall rules have been received (block 512), the
example service manager 304 and/or thefirewall instance 306 configure thefirewall instance 306 to enforce the firewall rule (block 514). After configuring the firewall instance 306 (block 514), or if instruction(s) to enforce the firewall rule have not been received (block 512), theexample instructions 500 ofFIG. 5 end. In some other examples, blocks 504-514 may be repeated to maintain exposed SDN APIs for configuration by the control plane 102 (e.g., via the SDN firewall controller 110). -
FIG. 6 is a block diagram of anexample processor platform 600 capable of executing the instructions ofFIGS. 4 and/or 5 to implement theSDN firewall controller 110 and/or theSDN node 300 ofFIGS. 1, 2 , and/or 3. Theprocessor platform 600 can be, for example, a server, a personal computer, or any other type of computing device. - The
processor platform 600 of the illustrated example includes aprocessor 612. Theprocessor 612 of the illustrated example is hardware. For example, theprocessor 612 can be implemented by one or more integrated circuits, logic circuits, microprocessors or controllers from any desired family or manufacturer. - The
processor 612 of the illustrated example includes a local memory 613 (e.g., a cache). Theprocessor 612 of the illustrated example is in communication with a main memory including avolatile memory 614 and anon-volatile memory 616 via abus 618. Thevolatile memory 614 may be implemented by Synchronous Dynamic Random Access Memory (SDRAM), Dynamic Random Access Memory (DRAM), RAMBUS Dynamic Random Access Memory (RDRAM) and/or any other type of random access memory device. Thenon-volatile memory 616 may be implemented by flash memory and/or any other desired type of memory device. Access to themain memory - The
processor platform 600 of the illustrated example also includes aninterface circuit 620. Theinterface circuit 620 may be implemented by any type of interface standard, such as an Ethernet interface, a universal serial bus (USB), and/or a PCI express interface. - In the illustrated example, one or
more input devices 622 are connected to theinterface circuit 620. The input device(s) 622 permit(s) a user to enter data and commands into theprocessor 612. The input device(s) can be implemented by, for example, an audio sensor, a microphone, a camera (still or video), a keyboard, a button, a mouse, a touchscreen, a track-pad, a trackball, isopoint and/or a voice recognition system. - One or
more output devices 624 are also connected to theinterface circuit 620 of the illustrated example. Theoutput devices 624 can be implemented, for example, by display devices (e.g., a light emitting diode (LED), an organic light emitting diode (OLED), a liquid crystal display, a cathode ray tube display (CRT), a touchscreen, a tactile output device, a light emitting diode (LED), a printer and/or speakers). Theinterface circuit 620 of the illustrated example, thus, typically includes a graphics driver card, a graphics driver chip or a graphics driver processor. - The
interface circuit 620 of the illustrated example also includes a communication device such as a transmitter, a receiver, a transceiver, a modem and/or network interface card to facilitate exchange of data with external machines (e.g., computing devices of any kind) via a network 626 (e.g., an Ethernet connection, a digital subscriber line (DSL), a telephone line, coaxial cable, a cellular telephone system, etc.). - The
processor platform 600 of the illustrated example also includes one or moremass storage devices 628 for storing software and/or data. Examples of suchmass storage devices 628 include floppy disk drives, hard drive disks, compact disk drives, Blu-ray disk drives, RAID systems, and digital versatile disk (DVD) drives. - The coded
instructions 632 ofFIGS. 4 and/or 5 may be stored in themass storage device 628, in thevolatile memory 614, in thenon-volatile memory 616, and/or on a removable tangible computer readable storage medium such as a CD or DVD. - Examples disclosed herein have advantages over known firewalls that include reducing the complexity of network design and network security implementation. Examples disclosed herein also enable deployment of security policies throughout entire networks such that, in contrast to networks using known firewalls, network attacks or other restricted traffic can be blocked prior to exposing the network nodes to the attacks or restricted traffic.
- Examples disclosed herein also increase the performance of entire networks (relative to known firewalls) because the network is freed from carrying restricted traffic additional hops toward the destination before the traffic can be filtered. Examples disclosed herein may be structured to distribute the firewall at or closer to the edges of the network, which allows each firewall to filter smaller numbers of traffic flows, and (in contrast to known centralized firewalls that must have highly-scalable throughput) to successfully block large numbers of traffic flows at concentrated locations. In some cases, the entire software-defined network can be configured to function as a firewall at each SDN node, rather than as a network that includes attached firewalls.
- Relative to known firewalls, examples disclosed herein are more adaptable to current network conditions. For example, example firewalls disclosed herein are adaptable to current users and/or traffic patterns of a network that enable the firewall policies of the network to be efficiently applied.
- Although certain example methods, apparatus and articles of manufacture have been disclosed herein, the scope of coverage of this patent is not limited thereto. On the contrary, this patent covers all methods, apparatus and articles of manufacture fairly falling within the scope of the claims of this patent.
Claims (20)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US18/302,030 US20230254283A1 (en) | 2014-05-06 | 2023-04-18 | Methods and apparatus to provide a distributed firewall in a network |
Applications Claiming Priority (5)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/271,185 US9674147B2 (en) | 2014-05-06 | 2014-05-06 | Methods and apparatus to provide a distributed firewall in a network |
US15/594,010 US10623373B2 (en) | 2014-05-06 | 2017-05-12 | Methods and apparatus to provide a distributed firewall in a network |
US16/836,514 US11044232B2 (en) | 2014-05-06 | 2020-03-31 | Methods and apparatus to provide a distributed firewall in a network |
US17/321,566 US11665140B2 (en) | 2014-05-06 | 2021-05-17 | Methods and apparatus to provide a distributed firewall in a network |
US18/302,030 US20230254283A1 (en) | 2014-05-06 | 2023-04-18 | Methods and apparatus to provide a distributed firewall in a network |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US17/321,566 Continuation US11665140B2 (en) | 2014-05-06 | 2021-05-17 | Methods and apparatus to provide a distributed firewall in a network |
Publications (1)
Publication Number | Publication Date |
---|---|
US20230254283A1 true US20230254283A1 (en) | 2023-08-10 |
Family
ID=54368832
Family Applications (5)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/271,185 Active 2035-08-07 US9674147B2 (en) | 2014-05-06 | 2014-05-06 | Methods and apparatus to provide a distributed firewall in a network |
US15/594,010 Expired - Fee Related US10623373B2 (en) | 2014-05-06 | 2017-05-12 | Methods and apparatus to provide a distributed firewall in a network |
US16/836,514 Active US11044232B2 (en) | 2014-05-06 | 2020-03-31 | Methods and apparatus to provide a distributed firewall in a network |
US17/321,566 Active 2034-07-11 US11665140B2 (en) | 2014-05-06 | 2021-05-17 | Methods and apparatus to provide a distributed firewall in a network |
US18/302,030 Pending US20230254283A1 (en) | 2014-05-06 | 2023-04-18 | Methods and apparatus to provide a distributed firewall in a network |
Family Applications Before (4)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/271,185 Active 2035-08-07 US9674147B2 (en) | 2014-05-06 | 2014-05-06 | Methods and apparatus to provide a distributed firewall in a network |
US15/594,010 Expired - Fee Related US10623373B2 (en) | 2014-05-06 | 2017-05-12 | Methods and apparatus to provide a distributed firewall in a network |
US16/836,514 Active US11044232B2 (en) | 2014-05-06 | 2020-03-31 | Methods and apparatus to provide a distributed firewall in a network |
US17/321,566 Active 2034-07-11 US11665140B2 (en) | 2014-05-06 | 2021-05-17 | Methods and apparatus to provide a distributed firewall in a network |
Country Status (1)
Country | Link |
---|---|
US (5) | US9674147B2 (en) |
Families Citing this family (32)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9674147B2 (en) | 2014-05-06 | 2017-06-06 | At&T Intellectual Property I, L.P. | Methods and apparatus to provide a distributed firewall in a network |
DE102015107073A1 (en) * | 2014-09-08 | 2016-03-10 | Rheinmetall Defence Electronics Gmbh | Device and method for controlling a communication network |
US9438560B2 (en) * | 2014-12-31 | 2016-09-06 | Symantec Corporation | Systems and methods for automatically applying firewall policies within data center applications |
CN105827425B (en) * | 2015-01-08 | 2020-07-24 | 华为技术有限公司 | Network control method and device |
US10771475B2 (en) | 2015-03-23 | 2020-09-08 | Extreme Networks, Inc. | Techniques for exchanging control and configuration information in a network visibility system |
US20160285735A1 (en) * | 2015-03-23 | 2016-09-29 | Brocade Communications Systems, Inc. | Techniques for efficiently programming forwarding rules in a network system |
US10911353B2 (en) | 2015-06-17 | 2021-02-02 | Extreme Networks, Inc. | Architecture for a network visibility system |
US10185638B2 (en) * | 2015-09-29 | 2019-01-22 | NeuVector, Inc. | Creating additional security containers for transparent network security for application containers based on conditions |
CN105338003B (en) * | 2015-12-09 | 2018-05-11 | 中国电子科技集团公司第二十八研究所 | A kind of method of realizing fireproof wall applied to software defined network |
WO2017127102A1 (en) * | 2016-01-22 | 2017-07-27 | Nokia Solutions And Networks Oy | Application relocation between clouds |
US11038845B2 (en) * | 2016-02-23 | 2021-06-15 | Nicira, Inc. | Firewall in a virtualized computing environment using physical network interface controller (PNIC) level firewall rules |
US10454777B2 (en) * | 2016-04-06 | 2019-10-22 | Omni Ai, Inc. | Network data processing driver for a cognitive artifical intelligence system |
US10805238B1 (en) | 2016-09-23 | 2020-10-13 | Amazon Technologies, Inc. | Management of alternative resources |
US10666569B1 (en) * | 2016-09-23 | 2020-05-26 | Amazon Technologies, Inc. | Journal service with named clients |
US20180091369A1 (en) * | 2016-09-28 | 2018-03-29 | Intel Corporation | Techniques to detect anomalies in software defined networking environments |
US10958623B2 (en) * | 2017-05-26 | 2021-03-23 | Futurewei Technologies, Inc. | Identity and metadata based firewalls in identity enabled networks |
US10951414B2 (en) * | 2018-01-29 | 2021-03-16 | Hub data security Ltd. | Method for securing digital currency |
US10742607B2 (en) * | 2018-02-06 | 2020-08-11 | Juniper Networks, Inc. | Application-aware firewall policy enforcement by data center controller |
US11252258B2 (en) | 2018-09-27 | 2022-02-15 | Hewlett Packard Enterprise Development Lp | Device-aware dynamic protocol adaptation in a software-defined network |
KR102160187B1 (en) | 2018-11-20 | 2020-09-25 | 광주과학기술원 | Apparatus and method deploying firewall on SDN, and network using the same |
US11233816B2 (en) * | 2019-02-15 | 2022-01-25 | Verizon Patent And Licensing Inc. | User-determined network traffic filtering |
US11470017B2 (en) * | 2019-07-30 | 2022-10-11 | At&T Intellectual Property I, L.P. | Immersive reality component management via a reduced competition core network component |
US11057348B2 (en) * | 2019-08-22 | 2021-07-06 | Saudi Arabian Oil Company | Method for data center network segmentation |
US11563722B2 (en) * | 2019-08-22 | 2023-01-24 | Hewlett Packard Enterprise Development Lp | Firewall coordination in a network |
US11792134B2 (en) | 2020-09-28 | 2023-10-17 | Vmware, Inc. | Configuring PNIC to perform flow processing offload using virtual port identifiers |
US11875172B2 (en) | 2020-09-28 | 2024-01-16 | VMware LLC | Bare metal computer for booting copies of VM images on multiple computing devices using a smart NIC |
US20240129232A1 (en) * | 2020-12-31 | 2024-04-18 | Aviatrix Systems, Inc. | Systems and methods for load balancing network traffic at firewalls deployed in a cloud computing environment |
US11995024B2 (en) | 2021-12-22 | 2024-05-28 | VMware LLC | State sharing between smart NICs |
CN114500058B (en) * | 2022-01-28 | 2024-07-12 | 优刻得科技股份有限公司 | Network access control method, system, equipment and medium |
US11928062B2 (en) | 2022-06-21 | 2024-03-12 | VMware LLC | Accelerating data message classification with smart NICs |
US11928367B2 (en) | 2022-06-21 | 2024-03-12 | VMware LLC | Logical memory addressing for network devices |
US11899594B2 (en) | 2022-06-21 | 2024-02-13 | VMware LLC | Maintenance of data message classification cache on smart NIC |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030084331A1 (en) * | 2001-10-26 | 2003-05-01 | Microsoft Corporation | Method for providing user authentication/authorization and distributed firewall utilizing same |
US20050076235A1 (en) * | 2003-10-03 | 2005-04-07 | Ormazabal Gaston S. | Network firewall test methods and apparatus |
US20060075478A1 (en) * | 2004-09-30 | 2006-04-06 | Nortel Networks Limited | Method and apparatus for enabling enhanced control of traffic propagation through a network firewall |
US20140143854A1 (en) * | 2011-02-16 | 2014-05-22 | Fortinet, Inc. | Load balancing among a cluster of firewall security devices |
Family Cites Families (33)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5922051A (en) | 1997-05-14 | 1999-07-13 | Ncr Corporation | System and method for traffic management in a network management system |
US6317837B1 (en) | 1998-09-01 | 2001-11-13 | Applianceware, Llc | Internal network node with dedicated firewall |
US6226372B1 (en) | 1998-12-11 | 2001-05-01 | Securelogix Corporation | Tightly integrated cooperative telecommunications firewall and scanner with distributed capabilities |
US7836494B2 (en) | 1999-12-29 | 2010-11-16 | Intel Corporation | System and method for regulating the flow of information to or from an application |
US6584454B1 (en) | 1999-12-31 | 2003-06-24 | Ge Medical Technology Services, Inc. | Method and apparatus for community management in remote system servicing |
US20020078382A1 (en) | 2000-11-29 | 2002-06-20 | Ali Sheikh | Scalable system for monitoring network system and components and methodology therefore |
US7624434B2 (en) | 2002-03-01 | 2009-11-24 | 3Com Corporation | System for providing firewall capabilities to a communication device |
US8578015B2 (en) | 2002-04-29 | 2013-11-05 | Harris Corporation | Tracking traffic in a mobile ad hoc network |
US7818565B2 (en) | 2002-06-10 | 2010-10-19 | Quest Software, Inc. | Systems and methods for implementing protocol enforcement rules |
US20040015719A1 (en) | 2002-07-16 | 2004-01-22 | Dae-Hyung Lee | Intelligent security engine and intelligent and integrated security system using the same |
AU2003301482A1 (en) | 2002-10-16 | 2004-05-04 | Rocksteady Networks, Inc. | System and method for dynamic bandwidth provisioning |
US7844731B1 (en) | 2003-11-14 | 2010-11-30 | Symantec Corporation | Systems and methods for address spacing in a firewall cluster |
US7610621B2 (en) | 2004-03-10 | 2009-10-27 | Eric White | System and method for behavior-based firewall modeling |
US7509493B2 (en) * | 2004-11-19 | 2009-03-24 | Microsoft Corporation | Method and system for distributing security policies |
CA2594020C (en) * | 2004-12-22 | 2014-12-09 | Wake Forest University | Method, systems, and computer program products for implementing function-parallel network firewall |
EP1864226B1 (en) * | 2005-03-28 | 2013-05-15 | Wake Forest University | Methods, systems, and computer program products for network firewall policy optimization |
US8291483B2 (en) * | 2007-04-30 | 2012-10-16 | Hewlett-Packard Development Company, L.P. | Remote network device with security policy failsafe |
US8112800B1 (en) * | 2007-11-08 | 2012-02-07 | Juniper Networks, Inc. | Multi-layered application classification and decoding |
US8089187B2 (en) | 2008-03-03 | 2012-01-03 | Budde William A | High-efficiency, variable-speed permanent magnet motor and control system |
US8565108B1 (en) | 2010-09-28 | 2013-10-22 | Amazon Technologies, Inc. | Network data transmission analysis |
JP6050240B2 (en) | 2010-11-30 | 2016-12-21 | コニンクリーケ・ケイピーエヌ・ナムローゼ・フェンノートシャップ | Dynamic allocation of serving network nodes |
US8880726B2 (en) | 2010-12-16 | 2014-11-04 | Openet Telecom Ltd. | Methods, systems and devices for dynamic context-based routing using a topology tree |
US8612744B2 (en) * | 2011-02-10 | 2013-12-17 | Varmour Networks, Inc. | Distributed firewall architecture using virtual machines |
CN102088413B (en) | 2011-03-02 | 2012-07-04 | 华为技术有限公司 | Network flow shunting method, network node and network system |
US8677471B2 (en) | 2011-12-12 | 2014-03-18 | Mcafee, Inc. | Port allocation in a firewall cluster |
US9350671B2 (en) | 2012-03-22 | 2016-05-24 | Futurewei Technologies, Inc. | Supporting software defined networking with application layer traffic optimization |
US9313048B2 (en) | 2012-04-04 | 2016-04-12 | Cisco Technology, Inc. | Location aware virtual service provisioning in a hybrid cloud environment |
US8955093B2 (en) * | 2012-04-11 | 2015-02-10 | Varmour Networks, Inc. | Cooperative network security inspection |
US10333827B2 (en) * | 2012-04-11 | 2019-06-25 | Varmour Networks, Inc. | Adaptive session forwarding following virtual machine migration detection |
US8949931B2 (en) * | 2012-05-02 | 2015-02-03 | Cisco Technology, Inc. | System and method for monitoring application security in a network environment |
US9674147B2 (en) | 2014-05-06 | 2017-06-06 | At&T Intellectual Property I, L.P. | Methods and apparatus to provide a distributed firewall in a network |
US10050938B2 (en) * | 2014-10-31 | 2018-08-14 | Jeffrey H. Moskow | Highly secure firewall system |
US9294442B1 (en) * | 2015-03-30 | 2016-03-22 | Varmour Networks, Inc. | System and method for threat-driven security policy controls |
-
2014
- 2014-05-06 US US14/271,185 patent/US9674147B2/en active Active
-
2017
- 2017-05-12 US US15/594,010 patent/US10623373B2/en not_active Expired - Fee Related
-
2020
- 2020-03-31 US US16/836,514 patent/US11044232B2/en active Active
-
2021
- 2021-05-17 US US17/321,566 patent/US11665140B2/en active Active
-
2023
- 2023-04-18 US US18/302,030 patent/US20230254283A1/en active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030084331A1 (en) * | 2001-10-26 | 2003-05-01 | Microsoft Corporation | Method for providing user authentication/authorization and distributed firewall utilizing same |
US20050076235A1 (en) * | 2003-10-03 | 2005-04-07 | Ormazabal Gaston S. | Network firewall test methods and apparatus |
US20060075478A1 (en) * | 2004-09-30 | 2006-04-06 | Nortel Networks Limited | Method and apparatus for enabling enhanced control of traffic propagation through a network firewall |
US20140143854A1 (en) * | 2011-02-16 | 2014-05-22 | Fortinet, Inc. | Load balancing among a cluster of firewall security devices |
Also Published As
Publication number | Publication date |
---|---|
US10623373B2 (en) | 2020-04-14 |
US20210273912A1 (en) | 2021-09-02 |
US9674147B2 (en) | 2017-06-06 |
US11665140B2 (en) | 2023-05-30 |
US20150326532A1 (en) | 2015-11-12 |
US20200228501A1 (en) | 2020-07-16 |
US20170250955A1 (en) | 2017-08-31 |
US11044232B2 (en) | 2021-06-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11665140B2 (en) | Methods and apparatus to provide a distributed firewall in a network | |
US11372671B2 (en) | Architecture of networks with middleboxes | |
US10498765B2 (en) | Virtual infrastructure perimeter regulator | |
US9203703B2 (en) | Packet conflict resolution | |
US9602404B2 (en) | Last-hop processing for reverse direction packets | |
US20150117454A1 (en) | Dynamic Generation of Flow Entries for Last-Hop Processing | |
AU2015255293A1 (en) | Architecture of networks with middleboxes | |
US20210168071A1 (en) | Management of the application of a policy in an sdn environment of a communications network | |
US10110477B2 (en) | Integrated data plane for heterogeneous network services |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: AT&T INTELLECTUAL PROPERTY I, L.P., GEORGIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:GRANT, DUSTIN;GUPTA, SANDEEP;NARAHARI, SRIDHAR;AND OTHERS;SIGNING DATES FROM 20140503 TO 20140506;REEL/FRAME:063352/0322 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NOTICE OF ALLOWANCE MAILED -- APPLICATION RECEIVED IN OFFICE OF PUBLICATIONS |