The present invention relates to the field of communications networks in general and, in particular, to selection of sources of timing information in communications networks.
A number of communications networks in use today rely on the exchange of accurate timing information, e.g. to enable the communication of data synchronised to a particular timing reference. Typically in such a network, timing information will be passed from one node to the next along with the data signal, so creating a synchronisation path through communicating nodes. It is desirable in such a system to ensure that each node uses the best available source of timing information. Certain networks provide an indication of the quality of timing information in a status message that is carried as part of the timing information. A node can use this status message to assist in the task of deciding which of a number of potential sources of timing information should be selected.
A conventional synchronous communications network comprises a number of interconnected nodes or network elements arranged to exchange data, timing and control signalling according to a synchronous hierarchy, as set out for example in synchronous digital hierarchy (SDH) standards published by the International Telecommunications Union (ITU), see “Network Node Interface for the Synchronous Digital Hierarchy (SDH)” ITU-T Recommendation G.707/Y.1322. The corresponding SONET system defined by the American National Standards Institute (ANSI) can be considered as a sub-set of SDH and reference to SDH hereafter includes SONET. Typically, in such networks, timing information will be passed from one node to the next, along with the data signal, so creating a synchronisation path through communicating nodes.
ITU-T Recommendation G.803 “Architecture of transport networks based on the synchronous digital hierarchy (SDH)” March 2000 describes SDH timing (also referred to as “clock”) distribution rules.
ITU-T Recommendation G.807/Y.1302 “Requirements for automatic switched transport networks (ASTN)” July 2001 describes network level requirements for the control plane of automatically switched transport networks. The control plane supports the establishment, teardown and maintenance of end-to-end connections and routeing to select the most appropriate path through the network.
A hierarchy of synchronisations sources is defined in SDH. The Primary Reference Clock (PRC) occupies the top level of the SDH synchronisation source hierarchy. Nodes or network elements (NE) with no PRC need to derive their timing information directly or indirectly from a PRC located at another node. The intermediate level source is represented by the Synchronisation Supply Unit (SSU) for filtering the received timing information and providing a holdover capability in case of loss of signal. To provide holdover, the SSU has the ability to “free run”, i.e. to maintain an accurate timing information output and keep the output frequency, obtained from an internal oscillator, within the allowed limits for at least 24 hours in the absence of a suitable reference input. An important parameter of the SSU is the quality of the timing information. The lowest level in the synchronisation source hierarchy is the SDH Equipment Clock (SEC). Each SDH node contains a SEC. The holdover capability of a SEC will provide the required synchronisation for at least 15 seconds.
If more than one link terminates at the same node (such as node A in
A significant feature of synchronous systems is the ability of networks to automatically recover from synchronisation failures, i.e. the failure of a link or a node supplying timing information. To support this feature each node conventionally requires a pre-configured synchronisation source priority table. A priority value is assigned in the table to each of the synchronisation sources available to a node and the node can use the priority table to identify the source with the highest priority. The node autonomously selects the available source with the highest quality based on the SSM values. The node can also use the pre-configured priority table in the selection of a source to use to synchronise data signals sent out from that node.
If a link selected to supply timing information fails, it is necessary to switch to get timing information from another link. This has to be done very quickly in order to maintain synchronisation. Controlling the switching locally reduces the delay associated with changing the source of timing information. In switching to a new source, it is important to ensure that a suitable link is chosen.
In the example of
A timing loop occurs when timing information transmitted by a node is returned (i.e. looped-backed) to the same node that then selects that looped-backed timing information as its source—thus “closing the loop”. Such a loop leads to degradation of the timing information. In the above example, selection of connection 1 from node B would result in a timing loop from node A to node B and back again. Similarly, selection of connection 3 from node C would result in a timing loop from node A via nodes B and C and back to node A. Conventionally, connections 2, 3 and 5 on node A may be identified as valid alternative sources. In order to avoid creating a timing loop in the conventional system, connection 3 must be manually marked as unusable.
In British Patent Number 2355898 issued to Marconi Communications Limited a synchronous digital communications system is described in which timing information is exchanged between nodes and a port identification message is associated with the timing information to avoid timing information received at any port at a node being retransmitted from the same port.
In British Patent Number 2301991 issued to Marconi Communications Limited each node attaches a status message to timing information passing through the node that identifies that node. In addition each node contains an arrangement to check received timing information and to reject it if it contains the identity of that node.
Modern networks are increasing inhomogeneous in nature with synchronous networks such as those based on SDH interconnecting with non-synchronous networks such as those based on IP, MPLS and ATM These factors make static planning of timing distribution networks more difficult. Protection switching can lead to sudden changes in the topology of a timing distribution network that the static timing source selection is unable to adapt to.
Furthermore, SDH links using an optical layer may suffer a decrease in the quality of the timing information so that DWDM/OTN cannot be used for the distribution of timing information. In networks with a dynamic DWDM layer the situation is complicated by the fact that SDH links can be dynamically established and deleted. Static planning of SDH synchronisation may not be suitable in such networks. In order to address these problems, the present invention provides a communications network comprising a plurality of nodes in which each node comprises means for communicating timing information with at least one other node and in which each node is associated with a timing status, the network comprising topology means for detecting the topology of the network and for detecting the timing status of each node and selection means for using the detected information in a process of selecting a source of timing information for at least one selected node.
According to a preferred embodiment of the present invention, the network may comprise means for detecting the flow of timing information between the nodes and for providing information on the timing flow to the selected node.
According to a further preferred embodiment of the present invention, the network comprises means for detecting those nodes that would result in a timing loop if chosen as the source of timing information.
According to a further preferred embodiment of the present invention, the topology means is distributed among the plurality of nodes.
According to a further preferred embodiment of the present invention, the topology means comprises a routing protocol.
According to a further preferred embodiment of the present invention, the selection process comprises a spanning-tree algorithm.
The present invention also provides a method of selecting a source of timing information in a communications network comprising a plurality of nodes, the method including the steps of detecting information concerning the topology of the communications network, detecting information concerning the timing status of the nodes, and selecting a source of timing for a selected node using the information provided.
According to a preferred embodiment of the present invention, the method includes the steps of detecting the flow of timing information between the nodes and providing the timing flow information to the selected node.
According to a further preferred embodiment of the present invention, the method includes the steps of detecting those ones of the plurality of nodes that would result in a timing loop if chosen as a source of timing information Embodiments of the invention will now be described by way of example with reference the drawings in which
According to a preferred embodiment, the present invention uses a distributed routing protocol such as GMPLS or PNNI to provide information to the nodes on the topology of the network to improve the ability of the nodes to select the best source of timing information.
GMPLS is described in the following requests for comment (RFC) published by the Internet Engineering Task Force:
PNNI (Private Network-to-Network Interface) is used for distributing topology information between switches and clusters of switches. This information is used to compute paths through the network. PNNI is described in “Private Network-Network Interface Specification Version 1.1” (PNNI 1.1), The ATM Forum, af-pnni-0055.002, March 2002.
Routing protocols such as GMPLS and PNNI work by establishing a self-routing network. In order to achieve this, the routing protocols obtain information on the topology of the network. According to the present embodiment of the invention, topology information, obtained by a routing protocol and information on the timing status of each of the nodes is provided to the nodes of a network and is used by them to allow improved selection of a source of timing information by those nodes. The information provided effectively gives each node a map of the network showing the timing status of the other nodes. Use of the map advantageously provides comprehensive, dynamically updatable information on the derivation of the timing information available in the neighbouring nodes. Each node refers to the timing information map established for that node and selects a neighbouring node as a source of timing information on the basis of the map.
ASTN, described in G.807, provides a control plane consisting of interconnected entities for the setting up and release of connections across a transport network. According to a preferred embodiment of the present invention as detailed below, extensions are proposed to GMPLS so that timing status information may be distributed using the ASTN control plane based on the GMPLS protocol suite described in the above GMPLS RFCs. These extensions allow:
The ASTN implementation enables distribution of node identification data and synchronisation properties (e.g. “PRC”, “SSU”, or “SEC”). This information allows the node priority table entries to be enhanced and eases the selection of synchronisation sources.
An example of how suitable extensions may be implemented is now given by way of example. According to this embodiment, each node stores data, some manually, pre-configured and static; some obtained dynamically via the routing protocol. The manually, pre-configured status information comprises:
Note that the PRC does not need to distribute the primary source vector information. For the PRC and SSUs with high timing information quality no secondary source should be given.
The status information obtained dynamically via the chosen routing protocol comprises:
According to a preferred embodiment, each node sends to all other nodes in the network by means of routing protocols its own status information comprising:
Status information can be transported by any routing protocol, e.g. OSPF, IS-IS or PNNI. OSPF transports this information in Link State Advertisements (LSAs) grouped in OSPF PDUs, as described in RFC 2370. Internet Engineering Task Force RFC 2370, “The OSPF Opaque LSA Option” R. Coltun, FORE Systems, July 1998 specifies the area flooding scope of the Traffic Engineering (TE) link-state advertisements (LSA), in particular of opaque LSAs. According to the intermediate system-intermediate system (IS-IS) protocol, these packets are called Link State PDUs. When using OSPF, GMPLS TE links can be advertised using Opaque LSAs of Type 10. The Traffic Engineering (TE) LSA (whose area flooding scope is specified in RFC 2370), has one top-level Type/Length/Value (TLV) triplet and one or more nested sub-TLV triplet for extensibility. The top-level triplet can take one of two values: (1) Router Address (referred to as the Node TLV) or (2) TE-Link TLV.
The Node TLV is extended using sub-TLVs to carry the timing_information_type and timing_information_derivation data objects. In this way status information about the timing properties of nodes as well as the information about how a node derives its timing are distributed to all other nodes in the network. Using this information each node builds the timing information node table that can be used to determine a timing distribution tree, as shown by way of example in
From the distributed information each node derives its local synchronisation source priority table. This table is used to decide from which interface to obtain timing information after a failure.
According to a preferred embodiment, with the local synchronisation source priority table established, checks are carried out for timing loops on the primary path, i.e. the path with the highest quality/priority attributes. Advantageously, each node can calculate whether the remote node connected at each interface derives its timing information from the local node: an arrangement that could result in the formation of a loop in the timing path.
The network of
To determine the status of a remote node, the timing distribution is traced back from the remote node using the information contained in the synchronisation source priority table. The remote node is designated as independent if a PRC is reached without traversing the local node. If the local node is traversed before finding a PRC, the remote node is designated as dependent from the local node. In this case the interface should not be used to source the timing information.
If the local node is not traversed before finding a PRC, the remote node is independent from the local node. The local node may use the timing information derived from an interface associated with an independent remote node if the relevant SDH timing distribution rules are met (see below). If the remote node is dependent, the variable loop_primary is set to “true”, otherwise to “false”. If only one independent interface can be found it will not be possible to derive the SDH timing from another interface.
Checks are also carried out for timing loops on secondary paths, where available. In principle, the check for secondary paths works as described for the primary path. It is necessary to check all possible secondary paths. If one of the secondary paths is dependent, the variable loop_secondary for the corresponding interface is set to “true”, otherwise to “false”.
For each interface from which the timing may potentially be derived, it is necessary to check whether the SDH timing information distribution rules are fulfilled. These are set out in G.803, section 8 where the maximum length of the synchronisation reference chain is limited, as follows:
The timing information distribution rules need to be checked on the primary path and all possible secondary paths independently. If the rules are met on the primary path the variable timing_information_rules_ok_primary is set to “true”, otherwise to “false”. If the rules are met on all secondary paths, the variable timing_information_rules_ok_secondary is set to “true”, otherwise to “false”.
The available links that fulfil the SDH timing information distribution rules (on the primary and secondary paths) and which are independent are given a link priority so that the link with the best timing information quality is always chosen. The link priority can be determined by sorting all links according to the following criteria:
This sorting algorithm results in each interface being given a unique priority, as illustrated by the networks of
In
The behaviour of the system in the case of a single fault will now be described with reference to
As shown in
The behaviour of the system in the case of multiple faults will now be described. As the secondary paths have been checked, it is ensured that a new timing source may be selected that will work properly in the presence of a single fault. However, it cannot be guaranteed that the secondary paths will work in the presence of additional faults. It is, however, possible to check the new configuration. To achieve this, according to a preferred embodiment, the node that has detected the fault and has switched sends a message to all other nodes and notifies them of the failure status and that it has switched to a secondary path. The other nodes then re-check their timing sources. If any of their secondary paths no longer meets the criteria for timing derivation, an alarm will be raised.
After the occurrence of multiple failures, some nodes might no longer be able to derive their timing: i.e. there might be no suitable source accessible. These nodes will detect this problem, e.g. by reference to their priority tables. A partial reconfiguration of the network in the form of a spanning tree may be necessary to resolve the problem. The reconfiguration should be done in a harmonised way for the whole spanning tree (see below) or closed parts thereof.
The Spanning-Tree Protocol is a link management protocol that provides path redundancy while preventing multiple active paths between stations. Multiple active paths are a problem in Ethernet networks, as they introduce the risk of creating loops. Infinite looping of frames and the duplication of messages may result. Spanning-Tree Protocol provides path redundancy, by defining a tree that spans all switches in an extended network. Spanning-Tree Protocol forces certain redundant data paths into a standby state. Then, if one segment in the Spanning-Tree Protocol becomes unreachable, or if Spanning-Tree Protocol costs change, the spanning-tree algorithm reconfigures the spanning-tree topology and re-establishes a link to the segment by activating the standby path. The Spanning Tree is standardized in IEEE 802.1D-1998, “Part 3: Media Access Control (MAC) Bridges”, see especially chapter 8. The Spanning tree protocol is also explained in Radia Perlman: “Interconnections”, Second Edition, 1999, Addison-Wesley, ISBN: 0201634481.
Instead of manually configuring the timing information at each node, it is advantageously possible, according to the present invention, to automatically configure the network by means of a spanning tree algorithm. A node indicates whether it allows automatic configuration by setting an automatic_configuration bit and distributing this bit to all other nodes in the network. Hence it is possible to decide whether to manually configure the complete network or to let the complete network (or parts of it) be automatically configured.
A further variable is required:
The topology of the network (the arrangement of SDH links) is known due to the routing protocols and the GMPLS extensions described above. Further extensions may be used to indicate which SDH links are suitable for SDH timing distribution. For example, SDH links that are established over IP or MPLS links or ODU connections where the ODU connection itself needs regeneration may not be suitable for timing distribution.
Each node can decide locally from which neighbouring node and from which interface to derive the SDH timing. This is may be done using the spanning tree algorithm to avoid loops. In building the spanning tree algorithm, all nodes derive the same spanning tree beginning at the PRC. Each node must follow independently the appropriate rules (as defined above). Nodes that have not set their automatic_configuration bit to “true” provide a fixed connection in the spanning tree.
The present invention advantageously provides a mechanism for providing better information to a node to enable it to correctly decide on the best source of timing information. According to a preferred embodiment, the present invention advantageously allows timing loops to be avoided. Advantageously, the present invention provides a network better able to cope with topology changes and to distribute timing information in hybrid networks based on synchronous and non-synchronous technologies.
The present invention is described above by way of example only and is not limited to the specific embodiments described. In particular, the invention may be implemented with any suitable protocol that obtains and distributes network topology information. The present invention also may be applied to any communication system in which quality-sensitive timing information is exchanged between nodes and in which the quality of the timing information may vary.
Number | Date | Country | Kind |
---|---|---|---|
0428032.7 | Dec 2004 | GB | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP05/55945 | 11/14/2005 | WO | 00 | 12/24/2007 |