US20160197812A1 - Network status mapping - Google Patents

Network status mapping Download PDF

Info

Publication number
US20160197812A1
US20160197812A1 US14/590,396 US201514590396A US2016197812A1 US 20160197812 A1 US20160197812 A1 US 20160197812A1 US 201514590396 A US201514590396 A US 201514590396A US 2016197812 A1 US2016197812 A1 US 2016197812A1
Authority
US
United States
Prior art keywords
network
map tag
field
electronic device
network map
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.)
Abandoned
Application number
US14/590,396
Inventor
Mohan Kalkunte
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Avago Technologies International Sales Pte Ltd
Original Assignee
Broadcom Corp
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Broadcom Corp filed Critical Broadcom Corp
Priority to US14/590,396 priority Critical patent/US20160197812A1/en
Assigned to BROADCOM CORPORATION reassignment BROADCOM CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: KALKUNTE, MOHAN
Assigned to BANK OF AMERICA, N.A., AS COLLATERAL AGENT reassignment BANK OF AMERICA, N.A., AS COLLATERAL AGENT PATENT SECURITY AGREEMENT Assignors: BROADCOM CORPORATION
Publication of US20160197812A1 publication Critical patent/US20160197812A1/en
Assigned to AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD. reassignment AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BROADCOM CORPORATION
Assigned to BROADCOM CORPORATION reassignment BROADCOM CORPORATION TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS Assignors: BANK OF AMERICA, N.A., AS COLLATERAL AGENT
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/10Active monitoring, e.g. heartbeat, ping or trace-route
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/06Generation of reports
    • H04L43/062Generation of reports related to network traffic
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/08Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters
    • H04L43/0876Network utilisation, e.g. volume of load or congestion level
    • H04L43/0882Utilisation of link capacity

Definitions

  • packets may be sent to their respective destinations via various paths. If multiple stations send packets along the same nodes or hops, congestion may occur at these nodes or hops. Also, congestion may result from speed mismatches between network input and output ports or links. Such congestion may slow down the transmission of the packets and/or result in some of the packets being lost.
  • FIG. 1 is a diagram of a computer network according to an exemplary embodiment of the present disclosure.
  • FIG. 2 is a block diagram of a network map tag according to an exemplary embodiment of the present disclosure.
  • FIG. 3 is a flow chart diagram describing an exemplary process for monitoring network status levels within a computer network according to embodiments of the present disclosure.
  • FIG. 4 is a flow chart diagram describing an exemplary process for responding to a network map tag according to embodiments of the present disclosure.
  • FIG. 5 is a flow chart diagram describing an exemplary process for building a network map for flows associated with a computer network according to embodiments of the present disclosure.
  • FIG. 6 is a block diagram depicting a network controller and network station according to an exemplary embodiment of the present disclosure.
  • Embodiments of the present disclosure provide systems and methods for network status mapping.
  • Such an exemplary system and method involves inserting a network map tag in a flow set of packets in a computer network and receiving a response to the network map tag.
  • the response from a network element includes populated fields of the network map tag comprising a field to identify a network element, a field to identify the outgoing port of the network element, a field to identify a queue of the outgoing port; and a status field for the queue of the outgoing port. Therefore, a network controller in a computer network can monitor congestion status of network elements in the network and choose a path for forwarding packets based on a network congestion map formed from compiled congestion information, in one embodiment, among others.
  • FIG. 1 is a diagram of a computer network 100 according to an exemplary embodiment.
  • the network 100 may include, for example, a mesh network topology or a partial mesh network topology with multiple routes for messages to travel from source to destination.
  • the network 100 may include a wired (guided) network, using twisted pairs, coaxial cables, or optical fibers, or wireless (unguided) network, or any combination of these, according to example embodiments.
  • the network 100 may include a packet-switched network, in which stations break messages up into packets and send these packets, one at a time, into the network 100 .
  • the network 100 may utilize a virtual circuit approach to routing packets, in which a sending station follows forwarding rules for each packet before sending the packet into the network.
  • the network 100 may be a Layer 2 and/or Layer 3 network, such as a data center network (e.g., private or public cloud).
  • the packets originating from a network element or given station may be hashed and bound to flow sets based on fields in and/or attributes of the respective packets.
  • a component in the network 100 such as a router, switch, or switch fabric, may identify the flow set for each packet by hashing certain packet fields for the given packet.
  • a flow set may be considered a set of state attributes (such as active, ingress port, path ID, move counter, and/or time stamp, discussed below) bound to a macroflow. Flows that hash to the same flow set may be considered to belong to a same macroflow, where a macroflow is a collection of smaller microflows.
  • Packets that hash to the same flow set, and/or macroflows belonging to a flow set may be assigned to a same path through the network 100 by a network controller 103 or other network device such as a router, switch, or switch fabric, unless the path assignment maintained by the flow set is changed and/or the flow set is rerouted, in various embodiments.
  • a path assignment may include, for example, a series of next hops, such as in an equal cost multipath approach, a link aggregation group (LAG) member, or a trunk member (such as HiGig trunks), according to example embodiments.
  • LAG link aggregation group
  • trunk member such as HiGig trunks
  • the network 100 may include various network elements, including network station 102 .
  • the station 102 may include any type of computing device, such as a server, gateway, router, switch, or relay node, according to example embodiments.
  • the station 102 may have packets to send to a receiver 104 through the network 100 .
  • the receiver 104 may also include any type of computing device, such as a server, gateway, router, switch, relay node, personal computer, laptop or notebook computer, smartphone, personal digital assistant (PDA), or cellular telephone, according to example embodiments.
  • PDA personal digital assistant
  • the network station 102 may receive forwarding rules from a network controller 103 and may apply those rules to assign a path via which to send the packets to the receiver 104 .
  • a path may include a series of hops through specified nodes in the network 100 .
  • the paths to the receiver 104 may include any number of nodes 106 , 108 , 110 which store and forward the packets along the path to the receiver 104 .
  • the nodes 106 , 108 , 110 may also include any type of computing device, such as a server, gateway, router, switch, or network station according to example embodiments. While three nodes 106 , 108 , 110 are shown FIG.
  • any number of nodes 106 , 108 , 110 may be included in the network 100 , and the network 100 may include any number of hops between the station 102 and the receiver 104 .
  • networks are multi-pathed between station end points to increase network bi-section bandwidth.
  • the network station 102 may receive the packets from a source 112 .
  • the station 102 may include a plurality of ports, and may receive the packets from the source 112 via one or more of the ports.
  • the source 112 may also include any type of computing device, such as a server, gateway, router, switch, relay node, personal computer, laptop or notebook computer, smartphone, personal digital assistant (PDA), or cellular telephone, according to example embodiments.
  • PDA personal digital assistant
  • the network controller 103 may determine an optimal path for each flow, including packets received from source 112 destined for receiver 104 , based on a multitude of criteria and convey this information to the network station 102 . Accordingly, the source 112 may send packets to the station 102 as parts of flow sets.
  • the network station 102 may contend with other senders 114 , 116 for resources in the network 100 .
  • the senders 114 , 116 may also include any type of computing device, such as a server, gateway, router, switch, relay node, personal computer, laptop or notebook computer, smartphone, personal digital assistant (PDA), or cellular telephone, according to example embodiments.
  • the senders 114 , 116 may send packets to the nodes 106 , 108 , 110 .
  • the station 102 , receiver 104 , nodes 106 , 108 , 110 , source 112 , and senders 114 , 116 may communicate via links 118 , 120 , 122 , 124 , 126 , 128 , 130 , 132 , 134 .
  • the links 118 , 120 , 122 , 124 , 126 , 128 , 130 , 132 , 134 may include wired (guided) or wireless (unguided) media.
  • the station 102 , receiver 104 , nodes 106 , 108 , 110 , source 112 , and senders 114 , 116 may communicate via the links 118 , 120 , 122 , 124 , 126 , 128 , 130 , 132 , 134 according to various protocols, such as Ethernet (IEEE 802.3), Wireless Local Area Networks (802.11), Bluetooth (802.15), or Worldwide Interoperability for Microwave Access (802.16), as non-limiting examples.
  • the network controller 103 and station 102 may communicate via the links 136 , 138 , 140 , 142 in addition to the links described above.
  • Congestion may occur when a node 106 , 108 , 110 is receiving packets from both a sender 114 , 116 , and the station 102 , for example.
  • the node 106 may be unable to process and forward the packets at the same rates as the sum of the station 102 and the sender 114 .
  • the latency or delay of the paths via which the station 102 and/or sender 114 are sending packets to the receiver 104 may increase, resulting in slower packet delivery, and some packets may be dropped, as the packets exceed the node's 106 buffer capacity.
  • the network controller 103 may become aware of the congestion and reprogram a flow set table used by network station 102 that associates flow sets to particular paths that are used to reach respective destinations. Accordingly, the network controller 103 may reassign a flow set from a first forwarding path or link (that is congested) to an alternative forwarding path or link. By having visibility within the network 100 , the network controller 103 is equipped to identify if a network element is experiencing congestion and re-balance the assignment of flows to network paths. Accordingly, the network controller 102 may be part of a software defined networking (SDN) architecture.
  • SDN software defined networking
  • the network station 102 may hash fields of a packet to determine a flow set (to which the packet is a member) and then use the table to identify a path to be used in routing the packet.
  • Examples of hashing functions which the station 102 may perform to obtain the hash value may include, for example, CRC 16, CRC32, XOR operations, and/or Pearson's hash, according to example embodiments.
  • Packets that hash to a given flow set may have the same source address and destination address. Packets in a flow set may also have consecutive sequence numbers; the receiver 104 may use the sequence numbers to put the message, which was broken down into packets, back into its original order, according to an example embodiment.
  • the network controller 103 causes a network map tag to be sent as part of a flow so that the network controller 103 can acquire useful status information on the network and make intelligent routing or forwarding decisions.
  • the network controller 103 can obtain a global view of the network 100 . Accordingly, embodiments of the present disclosure are directed to acquiring such status information within the network 100 .
  • an exemplary network controller 103 may reroute packets based on a network map generated from status information returned from network map tags in accordance with embodiments of the present disclosure.
  • FIG. 2 is a block diagram of a network map tag 200 according to an example non-limiting embodiment.
  • the network map tag 200 contains a network element identification (ID) field (such as a switch identification number when applicable), a port ID field, a queue ID field, congestion (CNG) status field, and a reserved (Rsvd) field.
  • ID network element identification
  • CNG congestion
  • Rsvd reserved
  • the sizes of the network element ID field, port ID field, a queue ID field, CNG field, and Rsvd field are 12 bits, 8 bits, 4 bits, 2 bits, and 8 bits respectively.
  • the 12-bit size of the network element ID field allows for 4096 network elements to be identified in the network 100 .
  • the size of the network element ID field may be increased or decreased within a network map tag 200 to account for network particularities. Accordingly, the overall size of the network map tag 200 may vary within different embodiments.
  • the 8-bit size of the port field allows for 256 ports to be identified; the 4-bit queue ID field allows for 16 queues to be identified (per port); and the 2-bit CNG field allows for 4 levels of congestion to be identified in this example. Again, in different embodiments, different levels of congestion may be identified and/or different types of status information may be acquired.
  • the network map tag 200 may be inserted in a flow of packets the flow or stream of packets may be received by a network element having a network element ID.
  • each of the network elements in the network 100 that are capable of providing network status information are associated with network element IDs.
  • the network element such as network station 102 , forwards the flow within the network 100 . Accordingly, the flow is directed to one of a number of physical ports of the network station 102 and associated with the port is a number of queues. After forwarding the flow, the network map tag 200 is populated with the information associated with the outgoing port and queue by the network station 102 .
  • the network controller 103 is configured to acquire the network statuses of the queues for the network station 102 and other network elements in the network 100 . Accordingly, the network station 102 qualifies the congestion status of a queue used to forward the packet carrying the network map tag 200 and populates the CNG field of the network map tag 200 with the appropriate status.
  • the network station 102 may be programmed by the network controller 103 to assign one of three congestion levels to indicate the current congestion status: High, Medium, or Low. Accordingly, if the congestion status is 75% full, then the level may be assigned as 2 (High) and a 10 bit representation is populated in the CNG field. If the congestion status at the queue within the port is at 10% full capacity, then the level may be assigned as 0 (Low) and a 00 bit representation is populated in the CNG field. Correspondingly, a middling level between the Low and High levels may be assigned as a 01 bit representation indicating a Medium level.
  • the network map tag 200 is populated with identifiers for the network station, the port of the network station, the queue of the port, and a congestion status for the queue.
  • a copy of a packet containing the network map tag 200 is sent to the network controller 103 from the network station 102 , where the network controller 103 (or an agent of the network controller) is responsible for constructing a network congestion map or table (e.g., flow-path-congestion table) which can be used by the network controller 103 to make decisions on flow load balancing, among other uses.
  • a network congestion map or table e.g., flow-path-congestion table
  • the network controller 103 may elect to choose or reroute to a different path (at a low or medium CGN level) than one employing the congested queue. Accordingly, status information returned to the network controller 103 as populated network map tags from network elements allow the network controller 103 to become aware of the network conditions and statuses of the network elements.
  • One possible approach of introducing the network map tag 200 in a flow of packets is to insert the tag within a layer 2 packet or frame.
  • the network map tag 200 may be inserted after a VLAN tag of the layer 2 packet using a private Ethertype.
  • Another possible approach is to insert the network map tag 200 in the IP options field of a layer 3 packet.
  • the packet containing the network map tag 200 may be a probe packet specifically generated to carry the network map tag 200 or may be a packet containing a payload which is used to piggyback the network map tag 200 .
  • a header of the packet may be marked to indicate that the packet is a probe which will allow for network elements to recognize the probe. While the term, “packet” is used herein, “packet” may also include frames or other formats which include data and other fields which may be used to determine a flow set.
  • the rate at which network map tags 200 are inserted within network packets is programmable by the network controller 103 .
  • the rate may occur at periodic or random intervals, according to various exemplary embodiments.
  • network elements such as network switches, may have authority to decide when a network map tag 200 should be inserted in a flow to comply with the forwarding rules (e.g., to satisfy a desired sampling rate), since a sufficient rate of packet sampling is desired such that sampling of network conditions is valid. This includes possibly inserting the network map tag 200 in every layer 2 packet of a flow.
  • the network map tag 200 may be carried by probe packets for a flow, in some embodiments. Accordingly, a network controller 103 may request a probe packet on a per flow basis, since different flows may take different paths. On the other hand, networks with dynamically hashed flows, the network map tag 200 may be inserted into sampled packets of a flow.
  • the network controller 103 that inserts the network map tag 200 in a packet.
  • a server administrator may then implement intelligent algorithms at the end points to manage traffic.
  • a network element such as a switch
  • a network element can be programmed to introduce the network map tag 200 in a packet of a flow. Accordingly, a first network element in a path assigned to a flow set may be instructed to introduce and send the network map tag 200 .
  • a network administrator can implement intelligent algorithms at the network element, such as a switch, to manage traffic.
  • a flow set may be assigned, by the network controller 103 , to a particular path which will be used to reach its destination, such as receiver 104 .
  • the path may be associated with an index number, which may compared to a flow set table which indicates which nodes 106 , 108 , 110 or hops the packet (carrying the network map tag) will travel through to reach its destination for the path (having the index number).
  • the flow set table may include addresses for each node 106 , 108 , 110 or hop the packet will travel through, as well as the address of the destination, which may be the receiver 104 , according to example embodiments.
  • the path ID may have been determined, for example, by the network controller 103 performing a hashing function on fields in the packet, such as a source address field and a destination address field. Accordingly, the network controller 103 may hash the fields in the packet to identify a flow set for the packet.
  • the network controller 103 may provide or update the applicable flow set table to network elements, such as station 102 , to be used in forwarding packets within flow sets. Additionally, as the network controller 103 determines that an active path is congested for a flow set, the network controller 103 may reassign the flow set to a different path.
  • FIG. 3 a flow chart is provided showing a process (e.g., algorithm) for monitoring network status levels within a computer network according to an exemplary embodiment.
  • the flow chart of FIG. 3 provides one example of the operation of a portion of the network controller 103 according to various embodiments. It is understood that the flow chart of FIG. 3 provides merely an example of the many different types of functional arrangements that may be employed to implement the operation of the portion of the network controller 103 as described herein, including a network mapping service 606 ( FIG. 6 ).
  • a network controller 103 may insert ( 310 ) a network map tag 200 in a flow set of packets assigned to a network path.
  • the network map tag 200 includes a field to identify a network element (e.g., network station 102 ), a field to identify an outgoing port of the network element, a queue of the outgoing port; and a congestion field for the queue of the outgoing port, in one embodiment. Accordingly, the network map tag 200 is intended to be carried along the flow and will be received by a network element, such as a network station 102 , in a path.
  • the network station 102 is programmed to recognize the network map tag of the packet and prepare a response for the network controller 103 after forwarding the packet as part of the flow set in accordance with forwarding rules being implemented by the network station 102 . If by chance a particular network element receives the packet and is not configured to recognize the network map tag, the network element may then forward the packet without attempting to prepare a response and populate the network map tag fields.
  • Such a response prepared by the network station 102 includes the populated fields of the network map tag 200 in which the network station 102 is identified. Also, the port used to forward the packet, the queue of the port used to forward the packet, and the congestion level for the queue of the outgoing port are each identified. Accordingly, each network element that receives the network map tag 200 along a path may also provide updated status information to the network controller. Subsequently, when any of the network elements receives a new network map tag, then the network controller 103 is provided with another updated status for the network 100 .
  • the network controller 103 receives ( 320 ) the response with the populated fields of the network map tag and then compiles or constructs ( 330 ) a network map (a/k/a network status map or network congestion map) indicating congestion levels across a plurality of network elements of the computer network 100 .
  • the network map may be in the form of a table with cells for identification of network elements in the computer network, identification of an outgoing port for each of the network elements, identification of a queue for each of the outgoing port; and identification of a network congestion status for each of the queues.
  • the status information obtained from network map tag 200 may also be used to graphically depict a diagram or map of network architecture with current network status levels represented.
  • a generated network map therefore may include each network element, each port, each queue, and their corresponding condition levels. This information may be the basis for performing rerouting and forwarding decisions by the network controller 103 (or other network element having access to the network map). For example, by considering a current mapping of a network 100 , a network condition may be detected on a network element used in a particular path, and as a result, a decision may be made to reroute a flow set using a different path.
  • FIG. 4 is a flow chart showing a process (e.g., algorithm) for responding to a network map tag according to an exemplary embodiment.
  • the flow chart of FIG. 4 provides one example of the operation of a portion of the network controller 103 according to various embodiments. It is understood that the flow chart of FIG. 4 provides merely an example of the many different types of functional arrangements that may be employed to implement the operation of the portion of the network station 102 as described herein, including a network mapping agent 614 ( FIG. 6 ).
  • a network controller 103 sends a probe packet or a network map tag 200 is inserted in a sampled packet of a flow.
  • a network element such as the network station 102 , receives ( 410 ) a packet carrying the network map tag and extracts the network map tag 200 .
  • the network station 102 populates ( 420 ) identification fields of the network map tag 200 , which may include an ID for the network station 102 (or other network element), an outgoing port ID, and a queue ID.
  • the network station 102 also populates a congestion level (e.g., low, medium, high) for the queue. The congestion level may depend on buffer sizes and associated queue levels for the network element.
  • the network station 102 sends ( 430 ) a copy of the populated network map tag fields to the network controller 103 so that the network controller 103 can build a network map for each of a plurality of flows in the network 100 .
  • a network map (e.g., flow-network map table) may be useful for many software defined networking applications.
  • FIG. 5 is a flow chart showing a process according to an example embodiment.
  • a network controller 103 receives ( 510 ) network map tagged packets from network elements in a computer network 100 that perform packet forwarding. From the received network map tagged packets, the network controller 103 populates ( 520 ) congestion information within a network map for each of the network elements and builds ( 530 ) a network map for flows associated with the computer network.
  • the flow chart of FIG. 5 provides merely an example of the many different types of functional arrangements that may be employed to implement the operation of the portion of the network controller 103 as described herein, including a network mapping service 606 ( FIG. 6 ).
  • FIG. 6 a block diagram is depicted showing the network controller 103 and a network element (network station 102 ) according to an exemplary embodiment.
  • a network connection 602 along with the network controller device 103 and a network station 102 , there is shown a network connection 602 ; network interface 604 , a network mapping service 606 , a memory 608 , and a processor 610 for the network controller 103 ; and a network interface 612 (associated with ports/queues 613 ), remote network mapping agent 614 , a memory 616 ; and a processor 618 for the network station 102 .
  • the network controller 103 may comprise suitable logic, circuitry, code, and/or interfaces that may enable monitoring of network status levels within network elements of a computer network 100 via a network connection 602 , such as network mapping service 606 .
  • the network station 102 may also comprise suitable logic, circuitry, code, and/or interfaces that may enable provisioning of network status levels to the network controller 103 via the network connection 602 , such as the remote network mapping agent 614 .
  • the network mapping service 606 may comprise a logical and/or software entity that may be integrated within an operating system (OS) running in the network controller 103 to generate network map(s) 609 in memory.
  • network mapping agent 614 may comprise a logical and/or software entity that may be integrated within an OS running in the network station 102 ; and/or a logical and/or software entity that may be integrated within a network interface controller (NIC) which may be running in the network station 102 .
  • NIC network interface controller
  • the processor 610 may comprise suitable logic, circuitry, code, and/or interfaces that may enable performing control and/or processing operations in the network controller 103 .
  • the present disclosure may not be limited to a specific processor, but may comprise for example, a general purpose processor, a specialized processor or any combination of suitable hardware, firmware, software and/or code, which may be enabled to support and/or control operations of the network controller 103 .
  • the memory 608 may comprise suitable logic, circuitry, code, and/or interfaces that may enable permanent and/or non-permanent storage and fetch of data and/or code used by the processor 610 , for example, during network mapping related processing operations.
  • the memory 608 may comprise various combinations of memory technologies, including, for example, read-only memory (ROM), random access memory (RAM), and/or Flash memory.
  • the network mapping agent 614 may comprise a dedicated entity that is operable to enable performing and/or supporting network mapping operations in the network station 102 , including provisioning of network status metrics.
  • the network mapping agent 614 may comprise a logical and/or software entity that may be integrated within an OS running in the network station 102 ; and/or a logical and/or software entity that may be integrated within a network interface controller (NIC) which may be running in the network station 104 .
  • NIC network interface controller
  • the processor 618 (of the network station 102 ) may comprise suitable logic, circuitry, code, and/or interfaces that may enable performing control and/or processing operations in the network station 102 .
  • the present disclosure may not be limited to a specific processor, but may comprise for example, a general purpose processor, a specialized processor or any combination of suitable hardware, firmware, software and/or code, which may be enabled to support network mapping operations in accordance with the various embodiments of the present disclosure.
  • the memory 616 may comprise suitable logic, circuitry, code, and/or interfaces that may enable permanent and/or non-permanent storage and fetch of data and/or code used by the processor 618 , for example, during network mapping related processing operations.
  • the memory 616 may comprise various combinations of memory technologies, including, for example, read-only memory (ROM), random access memory (RAM), and/or Flash memory.
  • the network connection 602 may comprise networking interfaces and/or link that may enable communicating network mapping based traffic between network devices, for example the network controller 103 , and network elements, such as the network station 102 .
  • the network connection 602 may comprise Ethernet (IEEE 802.3) based networking connections, which may operable to communicate network mapping and/or non-network mapping traffic packets, to and/or from the network devices 102 , 103 , to facilitate exchange of data between the network station 102 and the network controller 103 .
  • Implementations of the various techniques described herein may be implemented in digital electronic circuitry, or in computer hardware, firmware, software, or in combinations of them. Implementations may implemented as a computer program product, i.e., a computer program tangibly embodied in an information carrier, e.g., in a machine readable storage device, for execution by, or to control the operation of, data processing apparatus, e.g., a programmable processor, a computer, or multiple computers.
  • a computer program such as the computer program(s) described above, can be written in any form of programming language, including compiled or interpreted languages, and can be deployed in any form, including as a standalone program or as a module, component, subroutine, or other unit suitable for use in a computing environment.
  • a computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a communication network.
  • a computer program product or “computer-readable medium” can be any means that can contain, store, communicate, propagate, or transport the computer program for use by or in connection with the instruction execution system, apparatus, or device.
  • the computer readable medium can be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium.
  • the computer-readable medium includes the following: an electrical connection (electronic) having one or more wires, a portable computer diskette (magnetic), a random access memory (RAM) (electronic), a read-only memory (ROM) (electronic), an erasable programmable read-only memory (EPROM or Flash memory) (electronic), an optical fiber (optical), and a portable compact disc read-only memory (CDROM) (optical).
  • an electrical connection having one or more wires
  • a portable computer diskette magnetic
  • RAM random access memory
  • ROM read-only memory
  • EPROM or Flash memory erasable programmable read-only memory
  • CDROM portable compact disc read-only memory
  • the scope of the certain embodiments includes embodying the functionality of certain embodiments of the present disclosure in logic embodied in hardware or software-configured mediums.
  • Method or process steps may be performed by one or more programmable processors executing a computer program to perform functions by operating on input data and generating output. Method or process steps also may be performed by, and an apparatus may be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit).
  • FPGA field programmable gate array
  • ASIC application specific integrated circuit
  • processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer.
  • a processor will receive instructions and data from a read-only memory or a random access memory or both.
  • Elements of a computer may include at least one processor for executing instructions and one or more memory devices for storing instructions and data.
  • a computer also may include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
  • implementations may be implemented on a computer having a display device, e.g., a cathode ray tube (CRT) liquid crystal display (LCD) monitor, etc., for displaying information to the user and a keyboard and a pointing device, e.g., a mouse or a trackball, by which the user can provide input to the computer, including a touch screen.
  • a display device e.g., a cathode ray tube (CRT) liquid crystal display (LCD) monitor, etc.
  • a keyboard and a pointing device e.g., a mouse or a trackball
  • Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input.
  • Implementations may be implemented in a computing system that includes a backend component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a frontend component, e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation, or any combination of such backend, middleware, or frontend components.
  • Components may be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include, but are not limited to, a local area network (LAN) and a wide area network (WAN), e.g., the Internet.
  • LAN local area network
  • WAN wide area network

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Health & Medical Sciences (AREA)
  • Cardiology (AREA)
  • General Health & Medical Sciences (AREA)
  • Environmental & Geological Engineering (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

Embodiments of the present disclosure provide systems and methods for network status mapping. Such an exemplary system and method involves inserting a network map tag in a flow set of packets in a computer network and receiving a response to the network map tag from a network element that includes populated fields of the network map tag comprising a field to identify a network element, a field to identify the outgoing port of the network element, a field to identify queue of the outgoing port; and a status field for the queue of the outgoing port.

Description

    CROSS-REFERENCE TO RELATED APPLICATIONS
  • This application is a continuation of and is based upon and claims the benefit of priority under 35 U.S.C. § 120 for U.S. patent application Ser. No. 13/716,871, filed Dec. 17, 2012, the entire contents of which is incorporated herein by reference.
  • BACKGROUND OF THE INVENTION
  • In computer networks, packets may be sent to their respective destinations via various paths. If multiple stations send packets along the same nodes or hops, congestion may occur at these nodes or hops. Also, congestion may result from speed mismatches between network input and output ports or links. Such congestion may slow down the transmission of the packets and/or result in some of the packets being lost.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • Many aspects of the present disclosure can be better understood with reference to the following drawings. The components in the drawings are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the present disclosure. Moreover, in the drawings, like reference numerals designate corresponding parts throughout the several views.
  • FIG. 1 is a diagram of a computer network according to an exemplary embodiment of the present disclosure.
  • FIG. 2 is a block diagram of a network map tag according to an exemplary embodiment of the present disclosure.
  • FIG. 3 is a flow chart diagram describing an exemplary process for monitoring network status levels within a computer network according to embodiments of the present disclosure.
  • FIG. 4 is a flow chart diagram describing an exemplary process for responding to a network map tag according to embodiments of the present disclosure.
  • FIG. 5 is a flow chart diagram describing an exemplary process for building a network map for flows associated with a computer network according to embodiments of the present disclosure.
  • FIG. 6 is a block diagram depicting a network controller and network station according to an exemplary embodiment of the present disclosure.
  • DETAILED DESCRIPTION
  • Embodiments of the present disclosure provide systems and methods for network status mapping. Such an exemplary system and method involves inserting a network map tag in a flow set of packets in a computer network and receiving a response to the network map tag. In some embodiments, the response from a network element includes populated fields of the network map tag comprising a field to identify a network element, a field to identify the outgoing port of the network element, a field to identify a queue of the outgoing port; and a status field for the queue of the outgoing port. Therefore, a network controller in a computer network can monitor congestion status of network elements in the network and choose a path for forwarding packets based on a network congestion map formed from compiled congestion information, in one embodiment, among others.
  • FIG. 1 is a diagram of a computer network 100 according to an exemplary embodiment. The network 100 may include, for example, a mesh network topology or a partial mesh network topology with multiple routes for messages to travel from source to destination. The network 100 may include a wired (guided) network, using twisted pairs, coaxial cables, or optical fibers, or wireless (unguided) network, or any combination of these, according to example embodiments. The network 100 may include a packet-switched network, in which stations break messages up into packets and send these packets, one at a time, into the network 100. The network 100 may utilize a virtual circuit approach to routing packets, in which a sending station follows forwarding rules for each packet before sending the packet into the network. In some embodiments, the network 100 may be a Layer 2 and/or Layer 3 network, such as a data center network (e.g., private or public cloud).
  • In an example embodiment, the packets originating from a network element or given station may be hashed and bound to flow sets based on fields in and/or attributes of the respective packets. A component in the network 100, such as a router, switch, or switch fabric, may identify the flow set for each packet by hashing certain packet fields for the given packet. A flow set may be considered a set of state attributes (such as active, ingress port, path ID, move counter, and/or time stamp, discussed below) bound to a macroflow. Flows that hash to the same flow set may be considered to belong to a same macroflow, where a macroflow is a collection of smaller microflows.
  • Packets that hash to the same flow set, and/or macroflows belonging to a flow set, may be assigned to a same path through the network 100 by a network controller 103 or other network device such as a router, switch, or switch fabric, unless the path assignment maintained by the flow set is changed and/or the flow set is rerouted, in various embodiments. A path assignment may include, for example, a series of next hops, such as in an equal cost multipath approach, a link aggregation group (LAG) member, or a trunk member (such as HiGig trunks), according to example embodiments.
  • The network 100 may include various network elements, including network station 102. The station 102 may include any type of computing device, such as a server, gateway, router, switch, or relay node, according to example embodiments. The station 102 may have packets to send to a receiver 104 through the network 100. The receiver 104 may also include any type of computing device, such as a server, gateway, router, switch, relay node, personal computer, laptop or notebook computer, smartphone, personal digital assistant (PDA), or cellular telephone, according to example embodiments.
  • The network station 102 may receive forwarding rules from a network controller 103 and may apply those rules to assign a path via which to send the packets to the receiver 104. A path may include a series of hops through specified nodes in the network 100. The paths to the receiver 104 may include any number of nodes 106, 108, 110 which store and forward the packets along the path to the receiver 104. The nodes 106, 108, 110 may also include any type of computing device, such as a server, gateway, router, switch, or network station according to example embodiments. While three nodes 106, 108, 110 are shown FIG. 1, with only single-hop paths, any number of nodes 106, 108, 110 may be included in the network 100, and the network 100 may include any number of hops between the station 102 and the receiver 104. In various embodiments, networks are multi-pathed between station end points to increase network bi-section bandwidth.
  • The network station 102 may receive the packets from a source 112. The station 102 may include a plurality of ports, and may receive the packets from the source 112 via one or more of the ports. The source 112 may also include any type of computing device, such as a server, gateway, router, switch, relay node, personal computer, laptop or notebook computer, smartphone, personal digital assistant (PDA), or cellular telephone, according to example embodiments.
  • The network controller 103 may determine an optimal path for each flow, including packets received from source 112 destined for receiver 104, based on a multitude of criteria and convey this information to the network station 102. Accordingly, the source 112 may send packets to the station 102 as parts of flow sets.
  • The network station 102 may contend with other senders 114, 116 for resources in the network 100. The senders 114, 116 may also include any type of computing device, such as a server, gateway, router, switch, relay node, personal computer, laptop or notebook computer, smartphone, personal digital assistant (PDA), or cellular telephone, according to example embodiments. The senders 114, 116 may send packets to the nodes 106, 108, 110. The station 102, receiver 104, nodes 106, 108, 110, source 112, and senders 114, 116 may communicate via links 118, 120, 122, 124, 126, 128, 130, 132, 134. The links 118, 120, 122, 124, 126, 128, 130, 132, 134 may include wired (guided) or wireless (unguided) media. The station 102, receiver 104, nodes 106, 108, 110, source 112, and senders 114, 116 may communicate via the links 118, 120, 122, 124, 126, 128, 130, 132, 134 according to various protocols, such as Ethernet (IEEE 802.3), Wireless Local Area Networks (802.11), Bluetooth (802.15), or Worldwide Interoperability for Microwave Access (802.16), as non-limiting examples. The network controller 103 and station 102, among others, may communicate via the links 136, 138, 140, 142 in addition to the links described above.
  • Congestion may occur when a node 106, 108, 110 is receiving packets from both a sender 114, 116, and the station 102, for example. For example, if both the station 102 and the sender 114 are sending packets to the node 106, the node 106 may be unable to process and forward the packets at the same rates as the sum of the station 102 and the sender 114. The latency or delay of the paths via which the station 102 and/or sender 114 are sending packets to the receiver 104 may increase, resulting in slower packet delivery, and some packets may be dropped, as the packets exceed the node's 106 buffer capacity.
  • The network controller 103 may become aware of the congestion and reprogram a flow set table used by network station 102 that associates flow sets to particular paths that are used to reach respective destinations. Accordingly, the network controller 103 may reassign a flow set from a first forwarding path or link (that is congested) to an alternative forwarding path or link. By having visibility within the network 100, the network controller 103 is equipped to identify if a network element is experiencing congestion and re-balance the assignment of flows to network paths. Accordingly, the network controller 102 may be part of a software defined networking (SDN) architecture.
  • Therefore, the network station 102 may hash fields of a packet to determine a flow set (to which the packet is a member) and then use the table to identify a path to be used in routing the packet. Examples of hashing functions which the station 102 may perform to obtain the hash value may include, for example, CRC 16, CRC32, XOR operations, and/or Pearson's hash, according to example embodiments. Packets that hash to a given flow set may have the same source address and destination address. Packets in a flow set may also have consecutive sequence numbers; the receiver 104 may use the sequence numbers to put the message, which was broken down into packets, back into its original order, according to an example embodiment.
  • In one embodiment, the network controller 103 causes a network map tag to be sent as part of a flow so that the network controller 103 can acquire useful status information on the network and make intelligent routing or forwarding decisions. By knowing a state of the network 100, including congestion statuses, or other metrics, at a port level, a queue level, and/or other desired level of granularity for network elements, the network controller 103 can obtain a global view of the network 100. Accordingly, embodiments of the present disclosure are directed to acquiring such status information within the network 100. In particular, an exemplary network controller 103 may reroute packets based on a network map generated from status information returned from network map tags in accordance with embodiments of the present disclosure.
  • FIG. 2 is a block diagram of a network map tag 200 according to an example non-limiting embodiment. In this example, the network map tag 200 contains a network element identification (ID) field (such as a switch identification number when applicable), a port ID field, a queue ID field, congestion (CNG) status field, and a reserved (Rsvd) field. Also, in this example, the sizes of the network element ID field, port ID field, a queue ID field, CNG field, and Rsvd field are 12 bits, 8 bits, 4 bits, 2 bits, and 8 bits respectively. The 12-bit size of the network element ID field allows for 4096 network elements to be identified in the network 100. However, the size of the network element ID field (or any other field) may be increased or decreased within a network map tag 200 to account for network particularities. Accordingly, the overall size of the network map tag 200 may vary within different embodiments. Correspondingly, the 8-bit size of the port field allows for 256 ports to be identified; the 4-bit queue ID field allows for 16 queues to be identified (per port); and the 2-bit CNG field allows for 4 levels of congestion to be identified in this example. Again, in different embodiments, different levels of congestion may be identified and/or different types of status information may be acquired.
  • Consider that the network map tag 200 may be inserted in a flow of packets the flow or stream of packets may be received by a network element having a network element ID. In one embodiment, each of the network elements in the network 100 that are capable of providing network status information are associated with network element IDs. After receiving the network map tag 200, the network element, such as network station 102, forwards the flow within the network 100. Accordingly, the flow is directed to one of a number of physical ports of the network station 102 and associated with the port is a number of queues. After forwarding the flow, the network map tag 200 is populated with the information associated with the outgoing port and queue by the network station 102.
  • In accordance with embodiments of the present disclosure, the network controller 103 is configured to acquire the network statuses of the queues for the network station 102 and other network elements in the network 100. Accordingly, the network station 102 qualifies the congestion status of a queue used to forward the packet carrying the network map tag 200 and populates the CNG field of the network map tag 200 with the appropriate status.
  • In one example, the network station 102 may be programmed by the network controller 103 to assign one of three congestion levels to indicate the current congestion status: High, Medium, or Low. Accordingly, if the congestion status is 75% full, then the level may be assigned as 2 (High) and a 10 bit representation is populated in the CNG field. If the congestion status at the queue within the port is at 10% full capacity, then the level may be assigned as 0 (Low) and a 00 bit representation is populated in the CNG field. Correspondingly, a middling level between the Low and High levels may be assigned as a 01 bit representation indicating a Medium level.
  • Then, the network map tag 200 is populated with identifiers for the network station, the port of the network station, the queue of the port, and a congestion status for the queue. A copy of a packet containing the network map tag 200 is sent to the network controller 103 from the network station 102, where the network controller 103 (or an agent of the network controller) is responsible for constructing a network congestion map or table (e.g., flow-path-congestion table) which can be used by the network controller 103 to make decisions on flow load balancing, among other uses.
  • Therefore, if the congestion status of a queue of a network element is ¾ths full, the network controller 103 may elect to choose or reroute to a different path (at a low or medium CGN level) than one employing the congested queue. Accordingly, status information returned to the network controller 103 as populated network map tags from network elements allow the network controller 103 to become aware of the network conditions and statuses of the network elements.
  • One possible approach of introducing the network map tag 200 in a flow of packets is to insert the tag within a layer 2 packet or frame. In one exemplary embodiment, the network map tag 200 may be inserted after a VLAN tag of the layer 2 packet using a private Ethertype. Another possible approach is to insert the network map tag 200 in the IP options field of a layer 3 packet.
  • In one embodiment, the packet containing the network map tag 200 may be a probe packet specifically generated to carry the network map tag 200 or may be a packet containing a payload which is used to piggyback the network map tag 200. For the probe packet, a header of the packet may be marked to indicate that the packet is a probe which will allow for network elements to recognize the probe. While the term, “packet” is used herein, “packet” may also include frames or other formats which include data and other fields which may be used to determine a flow set.
  • In accordance with embodiments of the present disclosure, the rate at which network map tags 200 are inserted within network packets is programmable by the network controller 103. For example, the rate may occur at periodic or random intervals, according to various exemplary embodiments. Also, network elements, such as network switches, may have authority to decide when a network map tag 200 should be inserted in a flow to comply with the forwarding rules (e.g., to satisfy a desired sampling rate), since a sufficient rate of packet sampling is desired such that sampling of network conditions is valid. This includes possibly inserting the network map tag 200 in every layer 2 packet of a flow.
  • For networks with statistically hashed flows, the network map tag 200 may be carried by probe packets for a flow, in some embodiments. Accordingly, a network controller 103 may request a probe packet on a per flow basis, since different flows may take different paths. On the other hand, networks with dynamically hashed flows, the network map tag 200 may be inserted into sampled packets of a flow.
  • In one embodiment, it is the network controller 103 that inserts the network map tag 200 in a packet. In such an arrangement, a server administrator may then implement intelligent algorithms at the end points to manage traffic. Alternatively, a network element, such as a switch, can be programmed to introduce the network map tag 200 in a packet of a flow. Accordingly, a first network element in a path assigned to a flow set may be instructed to introduce and send the network map tag 200. In such an arrangement, a network administrator can implement intelligent algorithms at the network element, such as a switch, to manage traffic.
  • For instance, a flow set may be assigned, by the network controller 103, to a particular path which will be used to reach its destination, such as receiver 104. The path may be associated with an index number, which may compared to a flow set table which indicates which nodes 106, 108, 110 or hops the packet (carrying the network map tag) will travel through to reach its destination for the path (having the index number). Alternatively, the flow set table may include addresses for each node 106, 108, 110 or hop the packet will travel through, as well as the address of the destination, which may be the receiver 104, according to example embodiments. The path ID may have been determined, for example, by the network controller 103 performing a hashing function on fields in the packet, such as a source address field and a destination address field. Accordingly, the network controller 103 may hash the fields in the packet to identify a flow set for the packet.
  • Correspondingly, the network controller 103 may provide or update the applicable flow set table to network elements, such as station 102, to be used in forwarding packets within flow sets. Additionally, as the network controller 103 determines that an active path is congested for a flow set, the network controller 103 may reassign the flow set to a different path.
  • Referring now to FIG. 3, a flow chart is provided showing a process (e.g., algorithm) for monitoring network status levels within a computer network according to an exemplary embodiment. The flow chart of FIG. 3 provides one example of the operation of a portion of the network controller 103 according to various embodiments. It is understood that the flow chart of FIG. 3 provides merely an example of the many different types of functional arrangements that may be employed to implement the operation of the portion of the network controller 103 as described herein, including a network mapping service 606 (FIG. 6).
  • In this example, a network controller 103 may insert (310) a network map tag 200 in a flow set of packets assigned to a network path. The network map tag 200 includes a field to identify a network element (e.g., network station 102), a field to identify an outgoing port of the network element, a queue of the outgoing port; and a congestion field for the queue of the outgoing port, in one embodiment. Accordingly, the network map tag 200 is intended to be carried along the flow and will be received by a network element, such as a network station 102, in a path.
  • In one embodiment, the network station 102 is programmed to recognize the network map tag of the packet and prepare a response for the network controller 103 after forwarding the packet as part of the flow set in accordance with forwarding rules being implemented by the network station 102. If by chance a particular network element receives the packet and is not configured to recognize the network map tag, the network element may then forward the packet without attempting to prepare a response and populate the network map tag fields.
  • Such a response prepared by the network station 102 includes the populated fields of the network map tag 200 in which the network station 102 is identified. Also, the port used to forward the packet, the queue of the port used to forward the packet, and the congestion level for the queue of the outgoing port are each identified. Accordingly, each network element that receives the network map tag 200 along a path may also provide updated status information to the network controller. Subsequently, when any of the network elements receives a new network map tag, then the network controller 103 is provided with another updated status for the network 100.
  • Therefore, in FIG. 3, the network controller 103 receives (320) the response with the populated fields of the network map tag and then compiles or constructs (330) a network map (a/k/a network status map or network congestion map) indicating congestion levels across a plurality of network elements of the computer network 100. In one embodiment, as discussed, the network map may be in the form of a table with cells for identification of network elements in the computer network, identification of an outgoing port for each of the network elements, identification of a queue for each of the outgoing port; and identification of a network congestion status for each of the queues. In some embodiments, the status information obtained from network map tag 200 may also be used to graphically depict a diagram or map of network architecture with current network status levels represented.
  • According to various embodiments, a generated network map therefore may include each network element, each port, each queue, and their corresponding condition levels. This information may be the basis for performing rerouting and forwarding decisions by the network controller 103 (or other network element having access to the network map). For example, by considering a current mapping of a network 100, a network condition may be detected on a network element used in a particular path, and as a result, a decision may be made to reroute a flow set using a different path.
  • Next, FIG. 4 is a flow chart showing a process (e.g., algorithm) for responding to a network map tag according to an exemplary embodiment. The flow chart of FIG. 4 provides one example of the operation of a portion of the network controller 103 according to various embodiments. It is understood that the flow chart of FIG. 4 provides merely an example of the many different types of functional arrangements that may be employed to implement the operation of the portion of the network station 102 as described herein, including a network mapping agent 614 (FIG. 6).
  • In this example, a network controller 103 sends a probe packet or a network map tag 200 is inserted in a sampled packet of a flow. Accordingly, a network element, such as the network station 102, receives (410) a packet carrying the network map tag and extracts the network map tag 200. After a forwarding decision is made for the packet, the network station 102 populates (420) identification fields of the network map tag 200, which may include an ID for the network station 102 (or other network element), an outgoing port ID, and a queue ID. The network station 102 also populates a congestion level (e.g., low, medium, high) for the queue. The congestion level may depend on buffer sizes and associated queue levels for the network element. Then, the network station 102 sends (430) a copy of the populated network map tag fields to the network controller 103 so that the network controller 103 can build a network map for each of a plurality of flows in the network 100. Such a network map, (e.g., flow-network map table) may be useful for many software defined networking applications.
  • FIG. 5 is a flow chart showing a process according to an example embodiment. In this example, a network controller 103 (or agent of the network controller 103) receives (510) network map tagged packets from network elements in a computer network 100 that perform packet forwarding. From the received network map tagged packets, the network controller 103 populates (520) congestion information within a network map for each of the network elements and builds (530) a network map for flows associated with the computer network. It is understood that the flow chart of FIG. 5 provides merely an example of the many different types of functional arrangements that may be employed to implement the operation of the portion of the network controller 103 as described herein, including a network mapping service 606 (FIG. 6).
  • Referring now to FIG. 6, a block diagram is depicted showing the network controller 103 and a network element (network station 102) according to an exemplary embodiment. Along with the network controller device 103 and a network station 102, there is shown a network connection 602; network interface 604, a network mapping service 606, a memory 608, and a processor 610 for the network controller 103; and a network interface 612 (associated with ports/queues 613), remote network mapping agent 614, a memory 616; and a processor 618 for the network station 102.
  • The network controller 103 may comprise suitable logic, circuitry, code, and/or interfaces that may enable monitoring of network status levels within network elements of a computer network 100 via a network connection 602, such as network mapping service 606. As such a network element, the network station 102 may also comprise suitable logic, circuitry, code, and/or interfaces that may enable provisioning of network status levels to the network controller 103 via the network connection 602, such as the remote network mapping agent 614.
  • In particular, the network mapping service 606 may comprise a logical and/or software entity that may be integrated within an operating system (OS) running in the network controller 103 to generate network map(s) 609 in memory. Correspondingly, network mapping agent 614 may comprise a logical and/or software entity that may be integrated within an OS running in the network station 102; and/or a logical and/or software entity that may be integrated within a network interface controller (NIC) which may be running in the network station 102.
  • Additionally, the processor 610 (of the network controller 103) may comprise suitable logic, circuitry, code, and/or interfaces that may enable performing control and/or processing operations in the network controller 103. The present disclosure may not be limited to a specific processor, but may comprise for example, a general purpose processor, a specialized processor or any combination of suitable hardware, firmware, software and/or code, which may be enabled to support and/or control operations of the network controller 103. The memory 608 may comprise suitable logic, circuitry, code, and/or interfaces that may enable permanent and/or non-permanent storage and fetch of data and/or code used by the processor 610, for example, during network mapping related processing operations. In this regard, the memory 608 may comprise various combinations of memory technologies, including, for example, read-only memory (ROM), random access memory (RAM), and/or Flash memory.
  • The network mapping agent 614 may comprise a dedicated entity that is operable to enable performing and/or supporting network mapping operations in the network station 102, including provisioning of network status metrics. The network mapping agent 614 may comprise a logical and/or software entity that may be integrated within an OS running in the network station 102; and/or a logical and/or software entity that may be integrated within a network interface controller (NIC) which may be running in the network station 104.
  • The processor 618 (of the network station 102) may comprise suitable logic, circuitry, code, and/or interfaces that may enable performing control and/or processing operations in the network station 102. The present disclosure may not be limited to a specific processor, but may comprise for example, a general purpose processor, a specialized processor or any combination of suitable hardware, firmware, software and/or code, which may be enabled to support network mapping operations in accordance with the various embodiments of the present disclosure. The memory 616 may comprise suitable logic, circuitry, code, and/or interfaces that may enable permanent and/or non-permanent storage and fetch of data and/or code used by the processor 618, for example, during network mapping related processing operations. In this regard, the memory 616 may comprise various combinations of memory technologies, including, for example, read-only memory (ROM), random access memory (RAM), and/or Flash memory.
  • The network connection 602 may comprise networking interfaces and/or link that may enable communicating network mapping based traffic between network devices, for example the network controller 103, and network elements, such as the network station 102. As a non-limiting example, the network connection 602 may comprise Ethernet (IEEE 802.3) based networking connections, which may operable to communicate network mapping and/or non-network mapping traffic packets, to and/or from the network devices 102, 103, to facilitate exchange of data between the network station 102 and the network controller 103.
  • Implementations of the various techniques described herein may be implemented in digital electronic circuitry, or in computer hardware, firmware, software, or in combinations of them. Implementations may implemented as a computer program product, i.e., a computer program tangibly embodied in an information carrier, e.g., in a machine readable storage device, for execution by, or to control the operation of, data processing apparatus, e.g., a programmable processor, a computer, or multiple computers. A computer program, such as the computer program(s) described above, can be written in any form of programming language, including compiled or interpreted languages, and can be deployed in any form, including as a standalone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a communication network.
  • In the context of this document, a computer program product or “computer-readable medium” can be any means that can contain, store, communicate, propagate, or transport the computer program for use by or in connection with the instruction execution system, apparatus, or device. The computer readable medium can be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples (a nonexhaustive list) of the computer-readable medium would include the following: an electrical connection (electronic) having one or more wires, a portable computer diskette (magnetic), a random access memory (RAM) (electronic), a read-only memory (ROM) (electronic), an erasable programmable read-only memory (EPROM or Flash memory) (electronic), an optical fiber (optical), and a portable compact disc read-only memory (CDROM) (optical). In addition, the scope of the certain embodiments includes embodying the functionality of certain embodiments of the present disclosure in logic embodied in hardware or software-configured mediums.
  • Method or process steps may be performed by one or more programmable processors executing a computer program to perform functions by operating on input data and generating output. Method or process steps also may be performed by, and an apparatus may be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit).
  • Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. Elements of a computer may include at least one processor for executing instructions and one or more memory devices for storing instructions and data. Generally, a computer also may include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
  • To provide for interaction with a user, implementations may be implemented on a computer having a display device, e.g., a cathode ray tube (CRT) liquid crystal display (LCD) monitor, etc., for displaying information to the user and a keyboard and a pointing device, e.g., a mouse or a trackball, by which the user can provide input to the computer, including a touch screen. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input.
  • Implementations may be implemented in a computing system that includes a backend component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a frontend component, e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation, or any combination of such backend, middleware, or frontend components. Components may be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include, but are not limited to, a local area network (LAN) and a wide area network (WAN), e.g., the Internet.
  • Any process descriptions or blocks in flow charts should be understood as representing modules, segments, or portions of code which include one or more executable instructions for implementing specific logical functions or steps in the process, and alternate implementations are included within the scope of embodiments of the present disclosure in which functions may be executed out of order from that shown or discussed, including substantially concurrently or in reverse order, depending on the functionality involved, as would be understood by those reasonably skilled in the art.
  • While certain features of the described implementations have been illustrated as described herein, many modifications, substitutions, changes and equivalents will now occur to those skilled in the art. It is, therefore, to be understood that the appended claims are intended to cover all such modifications and changes as fall within the true spirit of the embodiments of the present disclosure.

Claims (20)

1. An electronic device comprising:
circuitry configured to
insert a network map tag in a flow set of packets of a computer network, wherein the network map tag includes at least one of a field to identify a network element, a field to identify an outgoing port of the network element, a field to identify a queue of the outgoing port, and a congestion field for the queue of the outgoing port;
receive a response to the network map tag from the network element that extracted and populated the network map tag, and forwarded a packet including the network map tag; and
generate a network map indicating congestion levels across a plurality of network elements of the computer network based on at least the response received from the network element.
2. The electronic device of claim 1, wherein the packet carrying the network map tag comprises a probe packet.
3. The electronic device of claim 2, wherein the electronic device is a network controller, and the network controller, a network switch, or a sending station generates the probe packet.
4. The electronic device of claim 1, wherein the packet carrying the network map tag comprises a packet having a payload from a remote sender.
5. The electronic device of claim 1, wherein the circuitry is configured to control a rate at which the network map tag is introduced in the flow set of packets.
6. The electronic device of claim 1, wherein the network map tag includes the congestion field, and the congestion field indicates a current level of congestion for the queue of the outgoing port of the network element.
7. The electronic device of claim 1, wherein the network map includes identification of network elements in the computer network, identification of an outgoing port for each of the network elements, identification of a queue for each of the outgoing port, and identification of a network congestion status for each of the queues.
8. The electronic device of claim 1, wherein the circuitry is configured to modify forwarding rules based on content of the network map tag and provide the modified forwarding rules to a network station that performs routing within a computer network.
9. An electronic device comprising:
circuitry configured to
insert a network map tag in a flow set of packets of a computer network, wherein the network map tag includes at least one of a field to identify a network element, a field to identify an outgoing port of the network element, a field to identify a queue of the outgoing port, and a congestion field for the queue of the outgoing port;
receive a response to the network map tag from the network element that extracted and populated the network map tag, and forwarded a packet including the network map tag; and
determine at least a first network forwarding rule based on at least the response received from the network element.
10. The electronic device of claim 9, wherein the packet carrying the network map tag comprises a probe packet.
11. The electronic device of claim 10, wherein the electronic device is a network controller, and the network controller, a network switch, or a sending station generates the probe packet.
12. The electronic device of claim 9, wherein the packet carrying the network map tag comprises a packet having a payload from a remote sender.
13. The electronic device of claim 9, wherein the circuitry is configured to control a rate at which the network map tag is introduced in the flow set of packets.
14. The electronic device of claim 9, wherein the network map tag includes the congestion field, and the congestion field indicates a current level of congestion for the queue of the outgoing port of the network element.
15. A method comprising:
inserting a network map tag in a flow set of packets of a computer network, wherein the network map tag includes at least one of a field to identify a network element, a field to identify an outgoing port of the network element, a field to identify a queue of the outgoing port, and a congestion field for the queue of the outgoing port; and
receiving a response to the network map tag from the network element that extracted and populated the network map tag, and forwarded a packet including the network map tag.
16. The method of claim 15, further comprising:
generating a network map indicating congestion levels across a plurality of network elements of the computer network based on at least the response received from the network element.
17. The method of claim 15, further comprising:
determining at least a first network forwarding rule based on at least the response received from the network element.
18. The method of claim 15, wherein a rate at which the network map tag is introduced in the flow set of packets is programmable.
19. The method of claim 15, further comprising:
constructing a network map indicating congestion levels across a plurality of network elements of the computer network.
20. The method of claim 15, wherein the processor is configured to determine network forwarding rules based on at least the response received from the network element.
US14/590,396 2012-12-17 2015-01-06 Network status mapping Abandoned US20160197812A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US14/590,396 US20160197812A1 (en) 2012-12-17 2015-01-06 Network status mapping

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US13/716,871 US8976697B2 (en) 2012-12-17 2012-12-17 Network status mapping
US14/590,396 US20160197812A1 (en) 2012-12-17 2015-01-06 Network status mapping

Publications (1)

Publication Number Publication Date
US20160197812A1 true US20160197812A1 (en) 2016-07-07

Family

ID=50821660

Family Applications (2)

Application Number Title Priority Date Filing Date
US13/716,871 Active 2033-04-23 US8976697B2 (en) 2012-12-17 2012-12-17 Network status mapping
US14/590,396 Abandoned US20160197812A1 (en) 2012-12-17 2015-01-06 Network status mapping

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US13/716,871 Active 2033-04-23 US8976697B2 (en) 2012-12-17 2012-12-17 Network status mapping

Country Status (3)

Country Link
US (2) US8976697B2 (en)
CN (1) CN103873377B (en)
DE (1) DE102013225692B4 (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111756564A (en) * 2019-03-29 2020-10-09 瞻博网络公司 Supporting concurrency of graph-based advanced configuration models
CN112312425A (en) * 2019-07-31 2021-02-02 杭州九阳小家电有限公司 Internet access method and device for household electrical appliance
US11296954B2 (en) 2019-03-29 2022-04-05 Juniper Networks, Inc. Supporting near real time service level agreements

Families Citing this family (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8976697B2 (en) * 2012-12-17 2015-03-10 Broadcom Corporation Network status mapping
FI124397B (en) * 2013-01-04 2014-08-15 Tellabs Oy Method and apparatus for determining search system for a network element of software-defined network
US9444748B2 (en) * 2013-03-15 2016-09-13 International Business Machines Corporation Scalable flow and congestion control with OpenFlow
US9596192B2 (en) 2013-03-15 2017-03-14 International Business Machines Corporation Reliable link layer for control links between network controllers and switches
US9769074B2 (en) 2013-03-15 2017-09-19 International Business Machines Corporation Network per-flow rate limiting
US9407560B2 (en) 2013-03-15 2016-08-02 International Business Machines Corporation Software defined network-based load balancing for physical and virtual networks
US9609086B2 (en) 2013-03-15 2017-03-28 International Business Machines Corporation Virtual machine mobility using OpenFlow
US9928104B2 (en) * 2013-06-19 2018-03-27 Nvidia Corporation System, method, and computer program product for a two-phase queue
US9473408B1 (en) * 2014-01-14 2016-10-18 Google Inc. Shortest first longer next routing with congestion reduction
US9674046B2 (en) 2014-10-21 2017-06-06 At&T Intellectual Property I, L.P. Automatic detection and prevention of network overload conditions using SDN
US10205938B2 (en) * 2014-11-10 2019-02-12 Keysight Technologies Singapore (Holdings) Pte. Ltd. Methods, systems, and computer readable media for monitoring and/or testing network communications
CN105721329A (en) * 2014-12-05 2016-06-29 中兴通讯股份有限公司 Shunting method, OpenFlow switch, controller and shunting system
US9525608B2 (en) 2015-02-25 2016-12-20 Quanta Computer, Inc. Out-of band network port status detection
US10268416B2 (en) * 2015-10-28 2019-04-23 Advanced Micro Devices, Inc. Method and systems of controlling memory-to-memory copy operations
RO132010A2 (en) 2015-12-22 2017-06-30 Ixia, A California Corporation Methods, systems and computer readable media for network diagnosis
US10439867B2 (en) 2015-12-31 2019-10-08 At&T Intellectual Property I, L.P. Method and apparatus for optimizing a software defined network configuration
US10389643B1 (en) 2016-01-30 2019-08-20 Innovium, Inc. Reflected packets
US10355981B1 (en) 2016-03-02 2019-07-16 Innovium, Inc. Sliding windows
US10511516B2 (en) 2016-08-29 2019-12-17 Keysight Technologies Singapore (Sales) Pte. Ltd. Methods, systems and computer readable media for quiescence-informed network testing
US10735339B1 (en) * 2017-01-16 2020-08-04 Innovium, Inc. Intelligent packet queues with efficient delay tracking
US11075847B1 (en) 2017-01-16 2021-07-27 Innovium, Inc. Visibility sampling
US20180213540A1 (en) * 2017-01-25 2018-07-26 Acer Incorporated Method of mapping data packets and related apparatuses using the same
US10616280B2 (en) 2017-10-25 2020-04-07 Bank Of America Corporation Network security system with cognitive engine for dynamic automation
US10437984B2 (en) 2017-10-26 2019-10-08 Bank Of America Corporation Authentication protocol elevation triggering system
US10686684B2 (en) 2017-11-02 2020-06-16 Bank Of America Corporation Individual application flow isotope tagging within a network infrastructure
CN111050353B (en) * 2018-10-11 2021-12-03 华为技术有限公司 Data transmission method and device for wireless backhaul network
US11552874B1 (en) 2019-01-18 2023-01-10 Keysight Technologies, Inc. Methods, systems and computer readable media for proactive network testing
US11115334B1 (en) * 2020-03-31 2021-09-07 Lenovo Enterprise Solutions (Singapore) Pte. Ltd. Optimized network latency using in-band telemetry
US11621904B1 (en) 2020-11-06 2023-04-04 Innovium, Inc. Path telemetry data collection
US11784932B2 (en) 2020-11-06 2023-10-10 Innovium, Inc. Delay-based automatic queue management and tail drop

Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050100011A1 (en) * 2003-11-07 2005-05-12 Girish Chiruvolu Method and apparatus for performing scalable selective backpressure in packet-switched networks using internal tags
US20060143300A1 (en) * 2002-06-27 2006-06-29 Micahael See Method and apparatus for mirroring traffic over a network
US20060221974A1 (en) * 2005-04-02 2006-10-05 Cisco Technology, Inc. Method and apparatus for dynamic load balancing over a network link bundle
US20070047446A1 (en) * 2005-08-30 2007-03-01 Mitesh Dalal Method and apparatus for updating best path based on real-time congestion feedback
US20070153683A1 (en) * 2005-12-30 2007-07-05 Mcalpine Gary L Traffic rate control in a network
US20070268903A1 (en) * 2006-05-22 2007-11-22 Fujitsu Limited System and Method for Assigning Packets to Output Queues
US20110261696A1 (en) * 2010-04-22 2011-10-27 International Business Machines Corporation Network data congestion management probe system
US20120008502A1 (en) * 2001-07-23 2012-01-12 Shiri Kadambi Flow based congestion control
US20140169189A1 (en) * 2012-12-17 2014-06-19 Broadcom Corporation Network Status Mapping
US20140226475A1 (en) * 2013-02-12 2014-08-14 Adara Networks, Inc. Controlling congestion controlled flows

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7447222B2 (en) * 2003-11-12 2008-11-04 Hewlett-Packard Development Company, L.P. Automated path tracing through switching mesh
US8611212B2 (en) * 2011-03-30 2013-12-17 Fujitsu Limited Method and system for writing to a VLAN tag
CN102594713B (en) * 2012-03-29 2015-09-09 杭州华三通信技术有限公司 A kind of method and apparatus realizing Explicit Congestion and notice

Patent Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120008502A1 (en) * 2001-07-23 2012-01-12 Shiri Kadambi Flow based congestion control
US20060143300A1 (en) * 2002-06-27 2006-06-29 Micahael See Method and apparatus for mirroring traffic over a network
US20050100011A1 (en) * 2003-11-07 2005-05-12 Girish Chiruvolu Method and apparatus for performing scalable selective backpressure in packet-switched networks using internal tags
US20060221974A1 (en) * 2005-04-02 2006-10-05 Cisco Technology, Inc. Method and apparatus for dynamic load balancing over a network link bundle
US20070047446A1 (en) * 2005-08-30 2007-03-01 Mitesh Dalal Method and apparatus for updating best path based on real-time congestion feedback
US20070153683A1 (en) * 2005-12-30 2007-07-05 Mcalpine Gary L Traffic rate control in a network
US20070268903A1 (en) * 2006-05-22 2007-11-22 Fujitsu Limited System and Method for Assigning Packets to Output Queues
US20110261696A1 (en) * 2010-04-22 2011-10-27 International Business Machines Corporation Network data congestion management probe system
US20140169189A1 (en) * 2012-12-17 2014-06-19 Broadcom Corporation Network Status Mapping
US20140226475A1 (en) * 2013-02-12 2014-08-14 Adara Networks, Inc. Controlling congestion controlled flows

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111756564A (en) * 2019-03-29 2020-10-09 瞻博网络公司 Supporting concurrency of graph-based advanced configuration models
US11296954B2 (en) 2019-03-29 2022-04-05 Juniper Networks, Inc. Supporting near real time service level agreements
US11689419B2 (en) 2019-03-29 2023-06-27 Juniper Networks, Inc. Supporting concurrency for graph-based high level configuration models
CN112312425A (en) * 2019-07-31 2021-02-02 杭州九阳小家电有限公司 Internet access method and device for household electrical appliance

Also Published As

Publication number Publication date
US20140169189A1 (en) 2014-06-19
DE102013225692A1 (en) 2014-06-18
DE102013225692B4 (en) 2020-02-13
CN103873377A (en) 2014-06-18
US8976697B2 (en) 2015-03-10
CN103873377B (en) 2017-04-12

Similar Documents

Publication Publication Date Title
US8976697B2 (en) Network status mapping
EP3259885B1 (en) Traffic engineering feeder for packet switched networks
US8897130B2 (en) Network traffic management
US6538991B1 (en) Constraint-based routing between ingress-egress points in a packet network
KR102113749B1 (en) System and method for routing traffic between distinct infiniband subnets based on source routing
US9167501B2 (en) Implementing a 3G packet core in a cloud computer with openflow data and control planes
US8694654B1 (en) Host side protocols for use with distributed control plane of a switch
EP2405608B1 (en) Performing path-orientated systems management
US9049137B1 (en) Hash based ECMP load balancing with non-power-of-2 port group sizes
US10277686B2 (en) Service discovery optimization in a network based on bloom filter
US9065745B2 (en) Network traffic distribution
US9401868B2 (en) Method of traffic engineering for provisioning routing and storage in content-oriented networks
US10931530B1 (en) Managing routing resources of a network
WO2018032962A1 (en) Method, device and system for information synchronization
US20190028300A1 (en) Maintaining data-plane connectivity between hosts
EP3140964A1 (en) Implementing a 3g packet core in a cloud computer with openflow data and control planes
CN111147372B (en) Downlink message sending and forwarding method and device
WO2018233580A1 (en) Method, controller and system for establishing forwarding path in network
US11228524B1 (en) Methods and apparatus for efficient use of link aggregation groups
CN108123878B (en) Routing method, routing device and data forwarding equipment
CN108234320B (en) Message transmission method and switch
Attarha et al. A load balanced congestion aware routing mechanism for Software Defined Networks
Rowshanrad et al. Implementing NDN using SDN: a review on methods and applications
JP6055553B2 (en) Queue scheduling method, apparatus and system
KR20130099199A (en) Communication system, node, packet transfer method and program

Legal Events

Date Code Title Description
AS Assignment

Owner name: BROADCOM CORPORATION, CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:KALKUNTE, MOHAN;REEL/FRAME:034645/0152

Effective date: 20121217

AS Assignment

Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NORTH CAROLINA

Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:BROADCOM CORPORATION;REEL/FRAME:037806/0001

Effective date: 20160201

Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NORTH

Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:BROADCOM CORPORATION;REEL/FRAME:037806/0001

Effective date: 20160201

AS Assignment

Owner name: AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD., SINGAPORE

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:BROADCOM CORPORATION;REEL/FRAME:041706/0001

Effective date: 20170120

Owner name: AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:BROADCOM CORPORATION;REEL/FRAME:041706/0001

Effective date: 20170120

AS Assignment

Owner name: BROADCOM CORPORATION, CALIFORNIA

Free format text: TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS;ASSIGNOR:BANK OF AMERICA, N.A., AS COLLATERAL AGENT;REEL/FRAME:041712/0001

Effective date: 20170119

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION