The present invention relates in general to the field of computers and similar technologies, and in particular to software utilized in this field. Still more particularly, it relates to a method, system and computer-usable medium for providing a multi-access interface for Internet Protocol Security, in order to improve network security and efficiency.
Many existing network firewalls and gateways are capable of implementing multilink topologies and Virtual Private Network (VPN) technologies, thus allowing for secure connectivity between two endpoints. Security between two endpoints may be provided by Internet Protocol Security (IPsec), a network protocol suite that authenticates and encrypts the packets of data transmitted over a network. IPsec includes protocols for establishing mutual authentication between agents at the beginning of the session and negotiation of cryptographic keys to use during the session. IPsec can protect data flows between a pair of hosts (host-to-host), between a pair of security gateways (network-to-network), or between a security gateway and a host (network-to-host). IPsec uses cryptographic security services to protect communications over Internet Protocol (IP) networks. IPsec supports network-level peer authentication, data-origin authentication, data integrity, data confidentiality (encryption), and replay protection.
IPsec is an end-to-end security scheme operating in the Internet Layer of the Internet Protocol Suite (analogous to Layer 3 or the network layer in the Open Systems Interconnection (OSI) protocol stack), while some other Internet security systems in widespread use, such as Transport Layer Security (TLS) and Secure Shell (SSH), operate in the upper layers at the Transport Layer (TLS) and the Application layer (SSH). IPsec can automatically secure applications at the IP layer.
As discussed in Internet Engineering Task Force (IETF) Request for Comments (RFC) 7018, which is incorporated herein by reference, it is known that existing approaches to network implementations suffer from a problem of enabling a large number of systems to communicate directly using IPsec to protect traffic communicated between them.
In accordance with the teachings of the present disclosure, certain disadvantages and problems associated with existing approaches to network implementation have been reduced or eliminated.
In accordance with embodiments of the present disclosure, a method may include receiving information regarding topology of a virtual private network and storing the topology in the form of a routing table.
In accordance with these and other embodiments of the present disclosure, a method may include, in a virtual private network comprising a plurality of tunnels delivering only information associated with Open Systems Interconnect stack Level 3, receiving a network communication, and performing multicast forwarding among the plurality of tunnels using multicast forwarding from Open Systems Interconnect stack Level 2.
In accordance with these and other embodiments of the present disclosure, a method may include, in a virtual private network, establishing a connection between a first node of the virtual private network and a second node serving as a virtual private network broker and fetching, by the first node from the virtual private network broker, information regarding one or more other nodes of the virtual private network.
Technical advantages of the present disclosure may be readily apparent to one having ordinary skill in the art from the figures, description and claims included herein. The objects and advantages of the embodiments will be realized and achieved at least by the elements, features, and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are explanatory examples and are not restrictive of the claims set forth in this disclosure.
A more complete understanding of the example, present embodiments and certain advantages thereof may be acquired by referring to the following description taken in conjunction with the accompanying drawings, in which like reference numbers indicate like features, and wherein:
For the purposes of this disclosure, an information handling system may include any instrumentality or aggregate of instrumentalities operable to compute, classify, process, transmit, receive, retrieve, originate, switch, store, display, manifest, detect, record, reproduce, handle, or utilize any form of information, intelligence, or data for business, scientific, control, entertainment, or other purposes. For example, an information handling system may be a personal computer, a mobile device such as a tablet or smartphone, a consumer electronic device, a connected “smart device,” a network appliance, a network storage device, a network gateway device, a server or collection of servers or any other suitable device and may vary in size, shape, performance, functionality, and price. The information handling system may include volatile and/or non-volatile memory, and one or more processing resources such as a central processing unit (CPU) or hardware or software control logic. Additional components of the information handling system may include one or more storage systems, one or more wired or wireless interfaces for communicating with other networked devices, external devices, and various input and output (I/O) devices, such as a keyboard, a mouse, a microphone, speakers, a track pad, a touchscreen and a display device (including a touch sensitive display device). The information handling system may also include one or more buses operable to transmit communication between the various hardware components.
For the purposes of this disclosure, computer-readable media may include any instrumentality or aggregation of instrumentalities that may retain data and/or instructions for a period of time. Computer-readable media may include, without limitation, storage media such as a direct access storage device (e.g., a hard disk drive or solid state drive), a sequential access storage device (e.g., a tape disk drive), optical storage device, random access memory (RAM), read-only memory (ROM), electrically erasable programmable read-only memory (EEPROM), and/or flash memory; as well as communications media such as wires, optical fibers, microwaves, radio waves, and other electromagnetic and/or optical carriers; and/or any combination of the foregoing.
In various embodiments, multi-access interface driver 118 may perform operations relating to provision of a multi-access interface of network communications between two endpoint devices of a network, between two gateway devices of a network, or between a gateway device and an endpoint device of a network, as described in greater detail elsewhere in this disclosure. In some embodiments, multi-access interface driver 118 and the functionality thereof improves processor efficiency, and thus the efficiency of information handling system 100, by enabling and providing a multi-access interface with decreased processing resources as compared to existing approaches for communicating information over a network. In these and other embodiments, multi-access interface driver 118 and the functionality thereof may improve an efficiency (e.g., increase throughput, decrease latency), and thus the effectiveness of information handling system 100, by enabling network communication between endpoints and/or gateways with greater effectiveness than existing approaches for network communication. As will be appreciated, once information handling system 100 is configured to perform the functionality of multi-access interface driver 118, information handling system 100 becomes a specialized computing device specifically configured to perform the functionality of multi-access interface driver 118 and is not a general purpose computing device. Moreover, the implementation of functionality of multi-access interface driver 118 on information handling system 100 improves the functionality of information handling system 100 and provides a useful and concrete result of improving network communications by enabling a multi-access interface for IPsec.
Security device 220 may also include in some embodiments a repository of configuration settings 234 and a multi-access interface cache 236. In some embodiments, security configuration management interface 226 may be implemented to receive deep packet inspection configuration instructions from multi-access interface driver 118.
Security device 220 may also include in some embodiments a repository of multi-access interface configuration settings 234 and a multi-access interface cache 236. In some embodiments, security configuration management interface 226 may be implemented to receive multi-access interface configuration instructions from multi-access interface driver 118.
Skilled practitioners of the art will be familiar with multicast, which is commonly used in a network environment for simultaneously providing Internet Protocol (IP) datagrams, or packets, to a target group of recipient network addresses in real-time or near real-time. In some embodiments, the target group recipient network addresses may be respectively associated with a corresponding endpoint device ‘1’ 244 through ‘n’ 246. As used herein, an endpoint device refers to an information processing system such as a personal computer, a laptop computer, a tablet computer, a personal digital assistant (PDA), a smart phone, a mobile telephone, a digital camera, a video camera, or other device capable of storing, processing and communicating data via a network, such as an internal network 240. In various embodiments, the communication of the data may take place in real-time or near-real-time.
Embodiments of the invention may reflect an appreciation that network communication may represent an efficient means for communicating useful information. However, those of skill in the art will likewise appreciate that existing technologies do not provide full saturation of WAN links for communication of network traffic between endpoints. Those of skill in the art may appreciate that traditional approaches to WAN communication allow for accurate communication, but with undesirable throughput and latency.
Each of internal network 240A and 240B may include an instance of an internal network 240 of
In operation, skilled practitioners in the art may recognize that the various components of network 300 may be used to implement secured multi-link communication between a single endpoint within internal network 240A and a single endpoint within internal network 240B, in that communication between the single endpoint of network 240A and the single endpoint of network 240B may be simultaneously routed over multiple links of wide area network 308 in order to provide communication with high availability and high bandwidth.
In operation, multi-access interface driver 118 may reduce or eliminate some or all of the known problems associated with enabling a large number of systems to communication directly using IPsec to protect traffic communicated between them. For example, as described in greater detail elsewhere in this disclosure, multi-access interface driver 118 may be configured to store a VPN topology in a route format, perform Level 2-type multicast delivery through a collection of Level 3 tunnels, and provide a multi-access interface as a VPN interface with dynamic peer resolving.
Storing VPN Topology in Route Format
Typically, IPsec configuration requires relatively large capacity of memory, as the collection of IPsec tunnel data structures comprises a large amount of information, especially when detailed traffic selectors must be storable in those data structures. As long as there is not yet traffic through a VPN, there is still the need of detecting which traffic must go to a VPN.
In accordance with embodiments of the present disclosure, multi-access interface driver 118 may store VPN topology, including information regarding IPsec tunnels, in the form of a routing table (e.g., which may be stored in multi-access interface cache 236, multi-access interface configuration settings 234, or in other suitable media). Practically all kinds of networking-enabled devices have efficient implementations for storing and processing information in the routing table. Accordingly, VPN topology may be maintained in security device 220's normal routing table, without duplicating the table inside the VPN module. Multi-access interface driver 118 may maintain such VPN topology in any suitable way, including manually configured routes or by way of dynamic routing protocol. Thus, a VPN component may utilize standard commands or system APIs to inject routes into such routing table format when the component has relevant topology information. In addition, if VPN is presented as a multi-access network interface, normal next hop gateway definitions may be used in the route format to define VPN topology. On the other hand, if VPN is presented as point-to-point tunnels or point-to-multipoint tunnels, such information may also be used in the route format to define VPN topology. In operation, actual VPN tunnel definitions may not be needed in active memory for tunnels that have no traffic, and such definitions may be fetched from another location (e.g., permanent storage media, another server in a network, etc.) when a tunnel is actively needed.
Level 2-Type Multicast Delivery Through Collection of Level 3 Tunnels
Multi-access interface driver 118 may, in a network comprising a collection of tunnels delivering only information associated with Level 3 of the OSI stack, implement multicast forwarding between such tunnels using multicast forwarding from Level 2 of the OSI stack. Those of skill in the art may recognize that multicast forwarding in Level 2 may depend on two factors: building a logical loop free topology for multicast forwarding, and forwarding multicast packets through that topology without verifying a time-to-live (TTL) value and forwarding non-routable multicast addresses.
In operation, instead of performing multicast routing between delivered Level 3 multicast messages, multi-access interface driver 118 may enable only forwarding between tunnels in the same virtual Level 2 network. Multi-access interface driver 118 may further limit multicast forwarding to VPN gateways willing to receive multicast.
In some embodiments, multi-access interface driver 118 may also build multicast group and/or sender-specific delivery trees. For example, when building logical loop free topology, the complexity of creating logical loop free topology may be reduced if multi-access interface driver 118 divides involved gateways into two groups for multicast delivery. Such division may be multicast-group specific.
In hub-and-spoke topologies, a multi-access interface driver 118 executing on a spoke gateway that is willing to send and/or receive multicast traffic may identify a connection to one of its hubs at a time as multicast-enabled, and may exchange multicast traffic only with such selected hub.
Between non-spoke multicast handlers, a multi-access interface driver 118 may use a more complex schema of building logical loop free topology. For example, to build a logical loop free topology, a multi-access interface driver 118 may adjust protocols familiar from Level 2 bridging of the OSI stack (e.g., spanning tree protocol, rapid spanning tree protocol, etc.) to operate at Level 3 of the OSI stack. As another example, a multi-access interface driver 118 may use Level 2 connectivity and perform forwarding between hub nodes of a hub-and-spoke topology.
As a further example, multi-access interface driver 118 may utilize full mesh connectivity among hub nodes, especially when the number of non-spoke nodes are reasonable and it is possible to have redundant connectivity (like multilink VPN). In accordance with such example, when multicast traffic is not received from another hub node (either traffic received from spoke node or multicast sent by hub itself), multi-access interface driver 118 may cause the traffic to be forwarded to all other identified spoke connections and to all hubs, and when traffic is received from another hub, multi-access interface driver 118 may cause the traffic to be forwarded only to all identified spoke connections.
With this multicast delivery model, it is not mandatory to know all other members in the same VPN topology. In addition, implementing this model does not require full mesh VPN topology, but can be applied also in other topologies. Further, in this model, there is no need to have all possible full mesh tunnel activated for multicasting.
Multi-Access Interface as VPN Interface with Dynamic Peer Resolving
Traditionally VPN is seen as point-to-point or point-to-multipoint interface (or not seen as network interface at all). Thus, particularly in large-scale dynamic VPN solutions, a multi-access interface may have many benefits. However, in the case of a large-scale dynamic VPN, it is not fair to expect that each VPN node has full and up-to-date knowledge of all other VPN nodes. Accordingly, use of this kind of VPN interface must be combined with some sort of dynamic peer-resolving schema. If a VPN topology has implemented multicasting support, multicasting can be used as such schema. This may be particularly suitable for Internet Protocol version 6 (IPv6), as neighbor discovery is performed in IPv6 using multicast. In the case of Internet Protocol version 4 (IPv4), IPv4 Address Resolution Protocol (ARP) queries can be converted by multi-access interface driver 118 to IPv4 or IPv6 multicast messages. For other messages (e.g., queries requesting endpoint addresses), multi-access interface driver 118 may issue multicast queries.
In a more security-oriented model in which it is not desired that each VPN node have multicasting enabled, multi-access interface driver 118 may implement a VPN broker. In such a scenario, some nodes in a VPN (e.g., VPN hubs if present) would act as brokers configured to deliver information regarding other members of the same VPN. In some embodiments, a node acting as a VPN broker may not be part of the actual VPN topology. In such embodiments, the protocol used to communicate with a broker node may be separate from VPN (e.g., Domain Name Service). In this VPN broker model, a node may require knowledge of at least one VPN broker in order to join a VPN. In some embodiments, authentication between a node and a VPN broker may be required (e.g., via IPsec, Internet Key Exchange, Hypertext Transfer Protocol Secure, etc.). During the connection between a node and a VPN broker, the node may provide information regarding the node (e.g., endpoint addresses, various VPN or networking settings, etc.), and the VPN broker may determine some information from the authenticated connection itself (e.g., a source address and port seen by the VPN broker when the node is connecting). In addition, the VPN broker may have information about allowed VPN members in its own database (e.g., allowed IP addresses stored in multi-access configuration settings).
After connection with the VPN broker, the VPN node may fetch information regarding the VPN (e.g., an up to date list of other brokers, a list of hub nodes, routes through the VPN). When the VPN node learns that it requires communication with another VPN node (e.g., an ARP discovery query, neighbor discovery query, a packet with a destination MAC, a packet to be routed through next hop gateway) and the address is not yet mapped to a known VPN peer node, the VPN node may query information regarding the peer node from the VPN broker. In the same way, a VPN node receiving a VPN negotiation attempt from an unknown VPN peer may contact a VPN broker and query for information about the other VPN peer. A VPN broker may respond to such queries by providing responsive information (e.g., endpoint addresses, information needed for authentication, information about acceptable IP addresses at the other end of tunnel), and based on this information, VPN peers can create direct VPN connections.
Further Optimization
The functionality described above with respect to storing VPN topology in a route format, Level 2-Type multicast delivery through a collection of Level 3 tunnels, and multi-access interface as VPN interface with dynamic peer resolving, may be implemented by multi-access interface driver 118. Multi-access interface driver 118 may be implemented in a module, which appears as a network interface driver to the rest of the networking stack.
When aiming for high performance, implementation can be further optimized. As an example, in some embodiments, an Ethernet frame may first be created and then a Media Access Control (MAC) address may be read from it and removed before sending to a tunnel. As another example, in some embodiments, an implementation can do without ARP or neighbor discovery, and tunnels can be bound directly to a next hop gateway definition in a routing table. In a further example, the methods described above may be implemented without any use of Level 2 addresses.
In addition, although the foregoing contemplates use of the methods and systems described in connection with IPsec, such methods and systems may also be used in other environments in which partial full mesh connections are used.
As used herein, when two or more elements are referred to as “coupled” to one another, such term indicates that such two or more elements are in electronic communication or mechanical communication, as applicable, whether connected indirectly or directly, with or without intervening elements.
This disclosure encompasses all changes, substitutions, variations, alterations, and modifications to the exemplary embodiments herein that a person having ordinary skill in the art would comprehend. Similarly, where appropriate, the appended claims encompass all changes, substitutions, variations, alterations, and modifications to the exemplary embodiments herein that a person having ordinary skill in the art would comprehend. Moreover, reference in the appended claims to an apparatus or system or a component of an apparatus or system being adapted to, arranged to, capable of, configured to, enabled to, operable to, or operative to perform a particular function encompasses that apparatus, system, or component, whether or not it or that particular function is activated, turned on, or unlocked, as long as that apparatus, system, or component is so adapted, arranged, capable, configured, enabled, operable, or operative.
All examples and conditional language recited herein are intended for pedagogical objects to aid the reader in understanding this disclosure and the concepts contributed by the inventor to furthering the art, and are construed as being without limitation to such specifically recited examples and conditions. Although embodiments of the present disclosure have been described in detail, it should be understood that various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the disclosure.
This application is a divisional of U.S. patent application Ser. No. 15/897,515, filed Feb. 15, 2018, which is incorporated by reference herein in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
7779461 | Liu | Aug 2010 | B1 |
7848335 | Kang | Dec 2010 | B1 |
7889655 | Retana et al. | Feb 2011 | B2 |
7899928 | Naik et al. | Mar 2011 | B1 |
7924837 | Shabtay et al. | Apr 2011 | B1 |
8155125 | Borgione et al. | Apr 2012 | B1 |
8310957 | Rekhter | Nov 2012 | B1 |
8918631 | Kumar | Dec 2014 | B1 |
9036504 | Miller | May 2015 | B1 |
9270585 | Manion | Feb 2016 | B2 |
9374270 | Nakil et al. | Jun 2016 | B2 |
9596181 | Goel | Mar 2017 | B1 |
9667431 | Pani | May 2017 | B2 |
9825822 | Holland | Nov 2017 | B1 |
9979605 | Sinn | May 2018 | B2 |
10275416 | Felbinger et al. | Apr 2019 | B1 |
10764249 | Kommula | Sep 2020 | B1 |
10834053 | Harel | Nov 2020 | B1 |
11190491 | Kaciulis | Nov 2021 | B1 |
11240063 | Liu | Feb 2022 | B2 |
11546245 | Pande | Jan 2023 | B2 |
20030037042 | Kametani | Feb 2003 | A1 |
20030147403 | Border | Aug 2003 | A1 |
20050071681 | Benjamin | Mar 2005 | A1 |
20050163146 | Ota et al. | Jul 2005 | A1 |
20050169270 | Mutou et al. | Aug 2005 | A1 |
20050213574 | Yoshimura | Sep 2005 | A1 |
20050265308 | Barbir | Dec 2005 | A1 |
20060068785 | Kamijo | Mar 2006 | A1 |
20060133390 | Sreekantiah | Jun 2006 | A1 |
20060146730 | Zeng et al. | Jul 2006 | A1 |
20060187950 | Bou-Diab et al. | Aug 2006 | A1 |
20060203819 | Farinacci et al. | Sep 2006 | A1 |
20070064673 | Bhandaru et al. | Mar 2007 | A1 |
20070204339 | Bou-Diab | Aug 2007 | A1 |
20070253432 | Regale et al. | Nov 2007 | A1 |
20080080509 | Khanna | Apr 2008 | A1 |
20080101350 | Kreuk | May 2008 | A1 |
20080183853 | Manion et al. | Jul 2008 | A1 |
20090037607 | Farinacci et al. | Feb 2009 | A1 |
20090129383 | Maalouf et al. | May 2009 | A1 |
20090175194 | Akhter | Jul 2009 | A1 |
20100046531 | Louati | Feb 2010 | A1 |
20100118882 | Gao et al. | May 2010 | A1 |
20110087774 | Pope | Apr 2011 | A1 |
20120099420 | Dharwadkar | Apr 2012 | A1 |
20120201539 | Boertjes et al. | Aug 2012 | A1 |
20120294309 | Cai | Nov 2012 | A1 |
20120314618 | Ben-Houidi | Dec 2012 | A1 |
20130182651 | Kelkar | Jul 2013 | A1 |
20130208718 | Ashwood-Smith | Aug 2013 | A1 |
20130329727 | Rajagopalan et al. | Dec 2013 | A1 |
20140348022 | Jain | Nov 2014 | A1 |
20150098466 | Haramaty et al. | Apr 2015 | A1 |
20150172165 | Tessmer et al. | Jun 2015 | A1 |
20160261506 | Hegde | Sep 2016 | A1 |
20160277210 | Lin et al. | Sep 2016 | A1 |
20170070428 | Ng et al. | Mar 2017 | A1 |
20170070474 | Haramaty et al. | Mar 2017 | A1 |
20170171056 | Dong et al. | Jun 2017 | A1 |
20170187624 | Goel | Jun 2017 | A1 |
20170346686 | Mudigonda | Nov 2017 | A1 |
20170346727 | Perrett | Nov 2017 | A1 |
20180227195 | Dumitriu et al. | Aug 2018 | A1 |
20180241669 | Muscariello et al. | Aug 2018 | A1 |
20190013966 | Nagarajan et al. | Jan 2019 | A1 |
20190229937 | Nagarajan et al. | Jul 2019 | A1 |
20190372938 | Pasdar | Dec 2019 | A1 |
20200389469 | Litichever et al. | Dec 2020 | A1 |
20210036887 | Meng | Feb 2021 | A1 |
20230254287 | Belleau | Aug 2023 | A1 |
Entry |
---|
Jun, Sang-Woo, et al. “Scalable multi-access flash store for big data analytics.” Proceedings of the 2014 ACM/SIGDA international symposium on Field-programmable gate arrays. 2014. pp. 55-64. (Year: 2014). |
S. D. A. Shah, M. A. Gregory and S. Li, “Cloud-Native Network Slicing Using Software Defined Networking Based Multi-Access Edge Computing: A Survey,” in IEEE Access, vol. 9, pp. 10903-10924, 2021. (Year: 2021). |
C. M. Ramya, M. Shanmugaraj and R. Prabakaran, “Study on ZigBee technology,” 2011 3rd International Conference on Electronics Computer Technology, Kanyakumari, India, 2011, pp. 297-301. (Year: 2011). |
Sathyanarayan, Auto Discovery VPN Protocol, https://datatracker.ietf.org/doc/draft-sathyanarayan-ipsecme-advpn. |
Auto-Discovery VPN Problem Statement and Requirements, Internet Engineering Task Force, RFC 7018, https://tools.ietf.org/html/rfc7018. |
Virtual extensible Local Area Network (VXLAN): A Framework for Overlaying Virtualized Layer 2 Networks over Layer 3 Networks, RVC 7348, https://tools.ietf.org/html/rfc7348#section-4.2. |
Theodorou, Dimitrios, et al. “NRS: a system for automated network virtualization in iaas cloud infrastructures.” Proceedings of the 7th international workshop on Virtualization technologies in distributed computing. 2013, pp. 25-32. |
D. Allan, P. Ashwood-Smith, N. Bragg and D. Fedyk, “Provider link state bridging,” in IEEE Communications Magazine, vol. 46, No. 9, pp. 110-117, Sep. 2008. |
Number | Date | Country | |
---|---|---|---|
20210273915 A1 | Sep 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15897515 | Feb 2018 | US |
Child | 17322264 | US |