CA2347487A1 - Processing platform - Google Patents
Processing platform Download PDFInfo
- Publication number
- CA2347487A1 CA2347487A1 CA002347487A CA2347487A CA2347487A1 CA 2347487 A1 CA2347487 A1 CA 2347487A1 CA 002347487 A CA002347487 A CA 002347487A CA 2347487 A CA2347487 A CA 2347487A CA 2347487 A1 CA2347487 A1 CA 2347487A1
- Authority
- CA
- Canada
- Prior art keywords
- subsystems
- resource
- data
- subsystem
- broker
- 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
Links
- 238000012545 processing Methods 0.000 title claims description 23
- 238000004891 communication Methods 0.000 claims abstract description 50
- 230000001404 mediated effect Effects 0.000 claims abstract description 4
- 230000011664 signaling Effects 0.000 claims description 13
- 238000000034 method Methods 0.000 claims description 11
- 230000004044 response Effects 0.000 claims description 6
- SYJGKVOENHZYMQ-UHFFFAOYSA-N Penoxsulam Chemical compound N1=C2C(OC)=CN=C(OC)N2N=C1NS(=O)(=O)C1=C(OCC(F)F)C=CC=C1C(F)(F)F SYJGKVOENHZYMQ-UHFFFAOYSA-N 0.000 description 68
- 241000271897 Viperidae Species 0.000 description 68
- 238000010586 diagram Methods 0.000 description 10
- 238000001514 detection method Methods 0.000 description 3
- 238000013519 translation Methods 0.000 description 3
- 230000002452 interceptive effect Effects 0.000 description 2
- 230000007246 mechanism Effects 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 102100027668 Carboxy-terminal domain RNA polymerase II polypeptide A small phosphatase 1 Human genes 0.000 description 1
- 101710134395 Carboxy-terminal domain RNA polymerase II polypeptide A small phosphatase 1 Proteins 0.000 description 1
- 241000220317 Rosa Species 0.000 description 1
- ATJFFYVFTNAWJD-UHFFFAOYSA-N Tin Chemical compound [Sn] ATJFFYVFTNAWJD-UHFFFAOYSA-N 0.000 description 1
- 230000009471 action Effects 0.000 description 1
- 244000309466 calf Species 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- PUPNJSIFIXXJCH-UHFFFAOYSA-N n-(4-hydroxyphenyl)-2-(1,1,3-trioxo-1,2-benzothiazol-2-yl)acetamide Chemical compound C1=CC(O)=CC=C1NC(=O)CN1S(=O)(=O)C2=CC=CC=C2C1=O PUPNJSIFIXXJCH-UHFFFAOYSA-N 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q3/00—Selecting arrangements
- H04Q3/0016—Arrangements providing connection between exchanges
- H04Q3/0029—Provisions for intelligent networking
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
- Telephonic Communication Services (AREA)
Abstract
A platform used, for example, to implement advanced services in a communications network employing an IN (intelligent network) architecture, is formed from a number of loosely coupled subsystems. Each subsystem includes a resource locator which advertises the subsystem's own resources, and listens to data identifying the resources available in other subsystems. Communication between the subsystems may be mediated by a resource broker which registers data from the different subsystems.
Description
2 PCT/GB99/0334'7 PROCESSING PLATFORM
The present invention relates to a processing platform and particularly to telecommunications service platform using a number of loosely coupled 5 subsystems.
Platforms used, for example, to implement advanced services in a telecommunications network having an IN (intelligent network) architecture, may comprise a number of loosely coupled subsystems linked by a high speed network.
This structure enhances the capacity and the resilience of the platform. The 10 resources of the platform are managed by a centralised management system that is responsible for allocating particular resources to given call and for reconfiguring the system, for example, in the event of one of the system components failing.
As conventionally implemented, such a platform suffers the disadvantages of having a high management overhead and having poor scalability, that is, the platform is not 15 readily adaptable to provide increased capacity.
According to a first aspect of the present invention, there is provided a communications service platform comprising a multiplicity of loosely coupled subsystems, each of the subsystems including respective service processing resources and a respective resource locator, each resource locator including 20 means for communicating to others of the resource locators its identity and the availability of the resources in the respective subsystem, and means for receiving identity data and resource availability data for resource locators in others of the subsystems.
This aspect of the invention provides a service platform which maintains 25 the resilience and capacity of a distributed processing architecture while reducing the management overheads and providing greatly improved scalability. This is achieved by providing each subsystem with a resource locator which advertises the resources of the relevant subsystem and also listens to information from other subsystem. In this way the task of resource management and allocation is 30 distributed between the subsystems, and the system as a whole is provided with a mechanism for recognising and responding to the addition of new subsystems.
The resource locators may be arranged to communicate directly by peer-to-peer signalling. Preferably, however, the platform includes a resource broker and communication between the resource locators is mediated by the resource broker. The resource broker may be located in one of the service processing subsystems, or may be located in a dedicated platform. The resource broker may include a data interface arranged to receive capability data and interface data from respective resource locators, and a registry arranged to store the said capability data and interface data. Preferably a resource locator in a subsystem is arranged initially to read capability data and interface data for another subsystem from the resource broker, and subsequently communicates further data directly with the other subsystem using the interface of the subsystem identified in the said interface data.
The system developed by the present inventors is not limited to use in communications systems but may also be used in a general computing environment.
According to a second aspect of the present invention there is provided a computing platform comprising a multiplicity of loosely coupled computing subsystems, each of the said subsystems including respective data processing resources and a respective resource locator arranged to advertise its identity and the loading of the respective resources and to receive resource signalling from others of the resource locators .
According to a third aspect of the present invention, there is provided a method of operating a communications system, the system including a multiplicity of processing subsystems and a network interconnecting the multiplicity of subsystems, the method comprising;
a) communicating from a resource locator in a respective one of the multiplicity of subsystems to resource locators in others of the multiplicity of subsystems data indicating the identity of the said one subsystem and the availability of resources in the said one subsystem b) repeating step (a) for each other of the multiplicity of subsystems:
c) when one of the multiplicity of subsystems, in the course of processing a call, requires resources not present locally in the said subsystem:
i) identifying from the said data communicated to the resource locator of the said one subsystem another subsystem having the said resources;
ii) accessing the said subsystem via the network.
According to a fourth aspect of the present invention, there is provided a communications system comprising:
The present invention relates to a processing platform and particularly to telecommunications service platform using a number of loosely coupled 5 subsystems.
Platforms used, for example, to implement advanced services in a telecommunications network having an IN (intelligent network) architecture, may comprise a number of loosely coupled subsystems linked by a high speed network.
This structure enhances the capacity and the resilience of the platform. The 10 resources of the platform are managed by a centralised management system that is responsible for allocating particular resources to given call and for reconfiguring the system, for example, in the event of one of the system components failing.
As conventionally implemented, such a platform suffers the disadvantages of having a high management overhead and having poor scalability, that is, the platform is not 15 readily adaptable to provide increased capacity.
According to a first aspect of the present invention, there is provided a communications service platform comprising a multiplicity of loosely coupled subsystems, each of the subsystems including respective service processing resources and a respective resource locator, each resource locator including 20 means for communicating to others of the resource locators its identity and the availability of the resources in the respective subsystem, and means for receiving identity data and resource availability data for resource locators in others of the subsystems.
This aspect of the invention provides a service platform which maintains 25 the resilience and capacity of a distributed processing architecture while reducing the management overheads and providing greatly improved scalability. This is achieved by providing each subsystem with a resource locator which advertises the resources of the relevant subsystem and also listens to information from other subsystem. In this way the task of resource management and allocation is 30 distributed between the subsystems, and the system as a whole is provided with a mechanism for recognising and responding to the addition of new subsystems.
The resource locators may be arranged to communicate directly by peer-to-peer signalling. Preferably, however, the platform includes a resource broker and communication between the resource locators is mediated by the resource broker. The resource broker may be located in one of the service processing subsystems, or may be located in a dedicated platform. The resource broker may include a data interface arranged to receive capability data and interface data from respective resource locators, and a registry arranged to store the said capability data and interface data. Preferably a resource locator in a subsystem is arranged initially to read capability data and interface data for another subsystem from the resource broker, and subsequently communicates further data directly with the other subsystem using the interface of the subsystem identified in the said interface data.
The system developed by the present inventors is not limited to use in communications systems but may also be used in a general computing environment.
According to a second aspect of the present invention there is provided a computing platform comprising a multiplicity of loosely coupled computing subsystems, each of the said subsystems including respective data processing resources and a respective resource locator arranged to advertise its identity and the loading of the respective resources and to receive resource signalling from others of the resource locators .
According to a third aspect of the present invention, there is provided a method of operating a communications system, the system including a multiplicity of processing subsystems and a network interconnecting the multiplicity of subsystems, the method comprising;
a) communicating from a resource locator in a respective one of the multiplicity of subsystems to resource locators in others of the multiplicity of subsystems data indicating the identity of the said one subsystem and the availability of resources in the said one subsystem b) repeating step (a) for each other of the multiplicity of subsystems:
c) when one of the multiplicity of subsystems, in the course of processing a call, requires resources not present locally in the said subsystem:
i) identifying from the said data communicated to the resource locator of the said one subsystem another subsystem having the said resources;
ii) accessing the said subsystem via the network.
According to a fourth aspect of the present invention, there is provided a communications system comprising:
a plurality of call processing subsystems;
a network interconnecting the plurality of call processing subsystems;
a resource broker connected to the network, the resource broker including a data interface arranged to receive capability data and interface data from respective call processing subsystems, and a registry arranged to store the said capability data and interface data.
The term "call processing subsystem" is used here broadly to encompass systems ancillary to the processing of a call, such as, e.g., an Email server, a mobility application platform or an interactive voice response (IVR) platform, as well as systems, such as a communications server, which are directly involved in the handling of a call.
Systems embodying the present invention will now be described in further detail, by way of example only, with reference to the accompanying drawings in which;
Figure 1 is a schematic of network embodying the invention;
Figure 2 is a diagram showing the structure of a service control point in Figure 1;
Figure 3 is a schematic of a network employing peer-to-peer signalling:
Figure 4 is a schematic of a network employing a broker;
Figure 5 is a diagram showing interactions between a broker and components;
Figure 6 is a schematic showing an architecture implementing the invention;
Figure 7 is a class diagram for an implementation of the architecture of Figure 6;
Figure 8 is a message flow diagram showing a first scenario;
Figure 9 is a message flow diagram showing a second scenario;
Figure 10 is a schematic of an implementation of the architecture of Figure 6 across different networks;
Figure 11 is a diagram illustrating different interface types in a system embodying the invention;
a network interconnecting the plurality of call processing subsystems;
a resource broker connected to the network, the resource broker including a data interface arranged to receive capability data and interface data from respective call processing subsystems, and a registry arranged to store the said capability data and interface data.
The term "call processing subsystem" is used here broadly to encompass systems ancillary to the processing of a call, such as, e.g., an Email server, a mobility application platform or an interactive voice response (IVR) platform, as well as systems, such as a communications server, which are directly involved in the handling of a call.
Systems embodying the present invention will now be described in further detail, by way of example only, with reference to the accompanying drawings in which;
Figure 1 is a schematic of network embodying the invention;
Figure 2 is a diagram showing the structure of a service control point in Figure 1;
Figure 3 is a schematic of a network employing peer-to-peer signalling:
Figure 4 is a schematic of a network employing a broker;
Figure 5 is a diagram showing interactions between a broker and components;
Figure 6 is a schematic showing an architecture implementing the invention;
Figure 7 is a class diagram for an implementation of the architecture of Figure 6;
Figure 8 is a message flow diagram showing a first scenario;
Figure 9 is a message flow diagram showing a second scenario;
Figure 10 is a schematic of an implementation of the architecture of Figure 6 across different networks;
Figure 11 is a diagram illustrating different interface types in a system embodying the invention;
Figure 12 is a diagram showing the structure of a resource broker;
Figure 13 shows a system in which components incorporate both type 1.0 and type 2.0 interfaces Figure 14 shows a personal mobility service implemented using the architecture of Figure 6.
A telecommunications network which uses an IN (Intelligent Network) architecture includes a service control point 1, which is also termed herein the Network Intelligence Platform (NIP). The service control point 1 is connected to trunk digital main switching units (DMSU's) 2 ,3 and to digital local exchanges (DLE's) 4,5. Both the DMSU's and the DLE's function as service switching points (SSP's). At certain points during the progress of a call, the SSP's transfer control of the call to the service control point. The service control point 1 carries out functions such as number translation and provides a gateway to additional resources such as a voice messaging platform. The network also includes a second service control point 6, which in this example runs customer mobility applications. The two service control points are connected to each other and to the other components via a broadband signalling network 7.
Figure 2 shows the structure of the service control point 1. A service management server is connected via an FDDI optical fibre LAN 21 to an overload control server (OCS) and to transaction servers (TS). The overload control server monitors call rates and initiates action to protect the SCP and other elements of the network from overload. For example the OCS may send a call-gapping instruction to an originating exchange. Additionally or alternatively, a call-gapping instruction may be sent to the broker, so that the broker rations the availability, e.g., of switching resources at the originating exchange so as to protect other resources downstream of the originating exchange. The transaction servers implement advanced service control functions such as, for example number translation and call plans. The OCS and transaction servers are connected via a second FDDI LAN 22 to communications servers ICS) which are connected to an SS7 (ITU Signalling System no. 7) signalling network. A global data server (GDS) is also connected to this second LAN. The GDS records call statistics and may also be used in the operation of overload control functions.
Figure 3 is a simplified schematic of the network of Figure 1, illustrating a first implementation of the present invention. The Figure shows a first SCP
31, a second SCP 32 and a DMSU 33. These components constitute loosely coupled subsystems of a platform which runs one or more IN services. The subsystems are 5 connected by a broadband signalling network 34, for example an FDDI LAN. As indicated by the key to the Figure, each subsystem includes call processing resources of different types and also a resource locator 35. The first SCP
includes resource types 1 and 2 which might correspond, for example, to a VPN
/virtual private networkl control function and to a number translation function respectively. The second SCP includes type 1 resources, and the DMSU includes resource type 3, for example a call switching function. Each locator advertises to all other locators, the identity and location of the subsystem, the resources available at that location and, for example, the loading of the resources. For example the locator in the first SCP 31, when the SCP is initiated, broadcasts to the other resource locators, a message in the form (SCP1; address 1; type 1, 50%;
type 2, 90%) where the first field is the identity, the second field is the address, and the subsequent fields are resource types and include a measure of resource loading. This message is received and stored by the resource locators in the other subsystems, and they in turn broadcast resource messages which are received by the resource locator in the SCP 31. The step of broadcasting resource messages is repeated periodically, with a frequency chosen to balance the need of the system to re-balance resources after a subsystem failure, or after incremental changes in the proportion of free resources in a subsystem, against the need to minimise signalling overheads. In the present example, resource locators re-transmit a resource message every 10 seconds. Then, for example, if a call originating at the DMSU is making use of VPN resources in the first SCP, and the first SCP fails, the failure will become apparent within, at most 10 seconds, and the DMSU resource locator may identify alternative resources in the second SCP.
The absence of an expected update is interpreted by the resource locators as an indication that the corresponding resources have become unavailable. In addition, subsystems may update the resource locators in response to events within that subsystem. For example, a subsystem may be programmed to update the resource locators whenever its loading changes by more than a predetermined threshold, e.g. 20%.
WO 00/22$42 PCT/GB99/03347 Figure 4 is a schematic illustrating a second implementation of the invention. In this example, in addition to the first and second SCP's and the DMSU described above with reference to Figure 3, the system also includes a resource broker 40. The resource broker includes, in addition to its own resource locator 41, a data store 42 which holds a registry of data communicated by other subsystems, and an authentication processor 43 which authenticates data received from the subsystems prior to entering the data in the registry. The broker may be implemented on a commercially available system such as that available from Visigenics as the Visigenics ORB (object request broker) running, for example, on a Digital SPARC Ultra (trademark) workstation. As shown in Figure 5, a subsystem, here termed a "component", must first authenticate itself with the broker, for example using a password or a digital signature, and agree a security mechanism for further exchanges. The component then registers its interfaces with the broker. For example, a communications server might register an INAP
communications channel at a specified network address. From this point, the component can discover the interfaces of other components within the system by reference to the registry in the broker. Once the component understands the interfaces of other components it can communicate freely with the other components without further reference to the broker.
Figure 12 shows in further detail the structure of the resource broker 40.
It comprises a resource registry, a service registry, and modules for authentication, registration and discovery. Tables 1 and 2 below show examples of the contents of the resource registry and service registry respectively. Each resource in the resource registry may have linked with it a number of entries in the service registry.
Name: Athena Processor: Digital SPARC Ultra Address: 132.14.32.71 Function: Call Control Server Calf ControI:INAP
Figure 13 shows a system in which components incorporate both type 1.0 and type 2.0 interfaces Figure 14 shows a personal mobility service implemented using the architecture of Figure 6.
A telecommunications network which uses an IN (Intelligent Network) architecture includes a service control point 1, which is also termed herein the Network Intelligence Platform (NIP). The service control point 1 is connected to trunk digital main switching units (DMSU's) 2 ,3 and to digital local exchanges (DLE's) 4,5. Both the DMSU's and the DLE's function as service switching points (SSP's). At certain points during the progress of a call, the SSP's transfer control of the call to the service control point. The service control point 1 carries out functions such as number translation and provides a gateway to additional resources such as a voice messaging platform. The network also includes a second service control point 6, which in this example runs customer mobility applications. The two service control points are connected to each other and to the other components via a broadband signalling network 7.
Figure 2 shows the structure of the service control point 1. A service management server is connected via an FDDI optical fibre LAN 21 to an overload control server (OCS) and to transaction servers (TS). The overload control server monitors call rates and initiates action to protect the SCP and other elements of the network from overload. For example the OCS may send a call-gapping instruction to an originating exchange. Additionally or alternatively, a call-gapping instruction may be sent to the broker, so that the broker rations the availability, e.g., of switching resources at the originating exchange so as to protect other resources downstream of the originating exchange. The transaction servers implement advanced service control functions such as, for example number translation and call plans. The OCS and transaction servers are connected via a second FDDI LAN 22 to communications servers ICS) which are connected to an SS7 (ITU Signalling System no. 7) signalling network. A global data server (GDS) is also connected to this second LAN. The GDS records call statistics and may also be used in the operation of overload control functions.
Figure 3 is a simplified schematic of the network of Figure 1, illustrating a first implementation of the present invention. The Figure shows a first SCP
31, a second SCP 32 and a DMSU 33. These components constitute loosely coupled subsystems of a platform which runs one or more IN services. The subsystems are 5 connected by a broadband signalling network 34, for example an FDDI LAN. As indicated by the key to the Figure, each subsystem includes call processing resources of different types and also a resource locator 35. The first SCP
includes resource types 1 and 2 which might correspond, for example, to a VPN
/virtual private networkl control function and to a number translation function respectively. The second SCP includes type 1 resources, and the DMSU includes resource type 3, for example a call switching function. Each locator advertises to all other locators, the identity and location of the subsystem, the resources available at that location and, for example, the loading of the resources. For example the locator in the first SCP 31, when the SCP is initiated, broadcasts to the other resource locators, a message in the form (SCP1; address 1; type 1, 50%;
type 2, 90%) where the first field is the identity, the second field is the address, and the subsequent fields are resource types and include a measure of resource loading. This message is received and stored by the resource locators in the other subsystems, and they in turn broadcast resource messages which are received by the resource locator in the SCP 31. The step of broadcasting resource messages is repeated periodically, with a frequency chosen to balance the need of the system to re-balance resources after a subsystem failure, or after incremental changes in the proportion of free resources in a subsystem, against the need to minimise signalling overheads. In the present example, resource locators re-transmit a resource message every 10 seconds. Then, for example, if a call originating at the DMSU is making use of VPN resources in the first SCP, and the first SCP fails, the failure will become apparent within, at most 10 seconds, and the DMSU resource locator may identify alternative resources in the second SCP.
The absence of an expected update is interpreted by the resource locators as an indication that the corresponding resources have become unavailable. In addition, subsystems may update the resource locators in response to events within that subsystem. For example, a subsystem may be programmed to update the resource locators whenever its loading changes by more than a predetermined threshold, e.g. 20%.
WO 00/22$42 PCT/GB99/03347 Figure 4 is a schematic illustrating a second implementation of the invention. In this example, in addition to the first and second SCP's and the DMSU described above with reference to Figure 3, the system also includes a resource broker 40. The resource broker includes, in addition to its own resource locator 41, a data store 42 which holds a registry of data communicated by other subsystems, and an authentication processor 43 which authenticates data received from the subsystems prior to entering the data in the registry. The broker may be implemented on a commercially available system such as that available from Visigenics as the Visigenics ORB (object request broker) running, for example, on a Digital SPARC Ultra (trademark) workstation. As shown in Figure 5, a subsystem, here termed a "component", must first authenticate itself with the broker, for example using a password or a digital signature, and agree a security mechanism for further exchanges. The component then registers its interfaces with the broker. For example, a communications server might register an INAP
communications channel at a specified network address. From this point, the component can discover the interfaces of other components within the system by reference to the registry in the broker. Once the component understands the interfaces of other components it can communicate freely with the other components without further reference to the broker.
Figure 12 shows in further detail the structure of the resource broker 40.
It comprises a resource registry, a service registry, and modules for authentication, registration and discovery. Tables 1 and 2 below show examples of the contents of the resource registry and service registry respectively. Each resource in the resource registry may have linked with it a number of entries in the service registry.
Name: Athena Processor: Digital SPARC Ultra Address: 132.14.32.71 Function: Call Control Server Calf ControI:INAP
no. RANGE 64XXXX-67XXXX
Network Operator: BT
Capacity: 100 cps Security parameters:
authentication level signature Interface: VIPER 1.0 Figure 6 shows an overview of an architecture that is implemented using a resource broker as described above with reference to Figures 4 and 5. The broker and the network used by the subsystems to communicate with the broker together provide a brokered environment 60. In this example, the subsystems connected to the brokered environment 60 include a PSTN network 61, a gatekeeper 62 for voice over IP (internet protocoll services, fax resources 63, an Email server 64 and a voice mail server 65 . A number of applications use the resources of the subsystems 61-65. These applications locate the appropriate resources using the resource broker contained within the brokered environment 60. This implementation is termed by the inventors the "VIPER" architecture. The architecture provides for two types of interfaces, termed by the inventors VIPER
1.0 and VIPER 2Ø As illustrated in Figure 1 1, VIPER 2.0 interfaces provide for communication between subsystems via an object bus 110. Subsystems using VIPER 2 interfaces request resources from a resource broker on a per call basis and communicate using, e.g., the CORBA protocol. VIPER 1 interfaces bypass the object bus and use specific protocols such as INAP to communicate with other systems. Subsystems with VIPER 1 interfaces register and discover resources and interface details with the resource broker when the subsystem is initialised, but do not communicate with the resource broker for subsequent calls. Such subsystems using VIPER 1 interfaces then communicate with other subsystem using protocols specific to the subsystem, for example INAP in the case of a communications server communicating with a transaction server.
In operation, a subsystem such as a communications server may initially download copies of service and resource registry data from the resource broker to form a locally cached copy of the resource broker. For example, in Figure 11, the communications server CS may optionally include a locally cached broker (LCB), as shown in dashed lines in the Figure. Then discovery operations may be carried out using the locally cached copy of the resource broker. In this case, even where a VIPER 2.0 interface is used, it is not necessary for signalling to pass between the communications server and the remote broker on every call. Instead, data passes between the remote broker and the communications server only intermittently when it is necessary to refresh the locally cached resource broker. Although the communications server, if it employs a VIPER 2.0 interface, still interrogates the resource broker for each new call, it is in general the locally cached broker that is used for this purpose.
Figure 7 is a class diagram showing an implementation of the architecture of Figure 6. This diagram is generated using the Rational ROSE software engineering tool and provides a basis, using that tool, for generating, e.g., Java code implementing the invention. Rational ROSE is available commercially from Rational Software Corporation. In this implementation, the subsystems that interact using the broker are termed "plugins".
Figure 8 shows a network operator bringing a VIPER broker, a VIPER
Cambridge Transaction Server and a VIPER Cambridge Communications Server into service. "Cambridge" is the name given to the SCP illustrated in Figure 2.
After registration and discovery is complete, an incoming call triggers an INAP
(Intelligent Network Application Protocol) IDP (initial detection point) at a DLE.
The DLE is referenced GPT SSP in the diagram. The call is cut-through the VIPER
middleware. Since the communications server CS and transaction server TS have both registered VIPER 1.0 interfaces with the resource broker, the CS does not have to ask the broker each time a call is received for the address of a suitable service resource or "plugin". Instead the CS and TS communicate directly using an INAP interface and bypassing the object bus. After location lookup is performed, an INAP connect is also cut-through the VIPER middleware back to the SSP. The following events and messages are shown in Figure 8:
1: Network operator brings the VIPER broker into service.
2: VIPER broker registers it services with itself if necessary.
3: Network operator brings the VIPER Cambridge Transaction Server into service.
4: VIPER Cambridge Transaction Server registers itself as a PIugIN with the VIPER
broker.
5: VIPER Cambridge Transaction Server registers the services it supports with the VIPER broker.
6: Network operator brings the VIPER Cambridge Communications Server into service.
7: VIPER Cambridge Communications Server registers itself as a PIugIN with the VIPER broker.
Network Operator: BT
Capacity: 100 cps Security parameters:
authentication level signature Interface: VIPER 1.0 Figure 6 shows an overview of an architecture that is implemented using a resource broker as described above with reference to Figures 4 and 5. The broker and the network used by the subsystems to communicate with the broker together provide a brokered environment 60. In this example, the subsystems connected to the brokered environment 60 include a PSTN network 61, a gatekeeper 62 for voice over IP (internet protocoll services, fax resources 63, an Email server 64 and a voice mail server 65 . A number of applications use the resources of the subsystems 61-65. These applications locate the appropriate resources using the resource broker contained within the brokered environment 60. This implementation is termed by the inventors the "VIPER" architecture. The architecture provides for two types of interfaces, termed by the inventors VIPER
1.0 and VIPER 2Ø As illustrated in Figure 1 1, VIPER 2.0 interfaces provide for communication between subsystems via an object bus 110. Subsystems using VIPER 2 interfaces request resources from a resource broker on a per call basis and communicate using, e.g., the CORBA protocol. VIPER 1 interfaces bypass the object bus and use specific protocols such as INAP to communicate with other systems. Subsystems with VIPER 1 interfaces register and discover resources and interface details with the resource broker when the subsystem is initialised, but do not communicate with the resource broker for subsequent calls. Such subsystems using VIPER 1 interfaces then communicate with other subsystem using protocols specific to the subsystem, for example INAP in the case of a communications server communicating with a transaction server.
In operation, a subsystem such as a communications server may initially download copies of service and resource registry data from the resource broker to form a locally cached copy of the resource broker. For example, in Figure 11, the communications server CS may optionally include a locally cached broker (LCB), as shown in dashed lines in the Figure. Then discovery operations may be carried out using the locally cached copy of the resource broker. In this case, even where a VIPER 2.0 interface is used, it is not necessary for signalling to pass between the communications server and the remote broker on every call. Instead, data passes between the remote broker and the communications server only intermittently when it is necessary to refresh the locally cached resource broker. Although the communications server, if it employs a VIPER 2.0 interface, still interrogates the resource broker for each new call, it is in general the locally cached broker that is used for this purpose.
Figure 7 is a class diagram showing an implementation of the architecture of Figure 6. This diagram is generated using the Rational ROSE software engineering tool and provides a basis, using that tool, for generating, e.g., Java code implementing the invention. Rational ROSE is available commercially from Rational Software Corporation. In this implementation, the subsystems that interact using the broker are termed "plugins".
Figure 8 shows a network operator bringing a VIPER broker, a VIPER
Cambridge Transaction Server and a VIPER Cambridge Communications Server into service. "Cambridge" is the name given to the SCP illustrated in Figure 2.
After registration and discovery is complete, an incoming call triggers an INAP
(Intelligent Network Application Protocol) IDP (initial detection point) at a DLE.
The DLE is referenced GPT SSP in the diagram. The call is cut-through the VIPER
middleware. Since the communications server CS and transaction server TS have both registered VIPER 1.0 interfaces with the resource broker, the CS does not have to ask the broker each time a call is received for the address of a suitable service resource or "plugin". Instead the CS and TS communicate directly using an INAP interface and bypassing the object bus. After location lookup is performed, an INAP connect is also cut-through the VIPER middleware back to the SSP. The following events and messages are shown in Figure 8:
1: Network operator brings the VIPER broker into service.
2: VIPER broker registers it services with itself if necessary.
3: Network operator brings the VIPER Cambridge Transaction Server into service.
4: VIPER Cambridge Transaction Server registers itself as a PIugIN with the VIPER
broker.
5: VIPER Cambridge Transaction Server registers the services it supports with the VIPER broker.
6: Network operator brings the VIPER Cambridge Communications Server into service.
7: VIPER Cambridge Communications Server registers itself as a PIugIN with the VIPER broker.
8: VIPER Cambridge Communications Server registers the services it supports with the VIPER broker.
9. VIPER Cambridge Transaction Server requests the address of the PIugIN
associated with 'name' (in this case, VIPER Cambridge Communications Server).
associated with 'name' (in this case, VIPER Cambridge Communications Server).
10. VIPER Cambridge Communications Server requests the address of the PIugIN
associated with 'name' (in this case, VIPER Cambridge Transaction Server).
associated with 'name' (in this case, VIPER Cambridge Transaction Server).
11. GPT SSP sends an INAP Initial Detection Point IIDP) to the VIPER Cambridge Communications Server.
12. VIPER Cambridge Communications Server sends a INAP IDP to the VIPER
Cambridge Transaction Server.
Cambridge Transaction Server.
13. VIPER Cambridge Transaction Server does an internal location lookup, then sends an INAP connect to the VIPER Cambridge Communications Server.
14. VIPER Cambridge Communications Server sends an INAP connect to the GPT
SSP.
Figure 9 shows the message flows involved in a second scenario, with a network operator bringing a VIPER broker, a VIPER Mobility Server and a VIPER
Cambridge Communications Server into service. The VIPER mobility server may be, 5 for example, the SCP 6 running a mobility application illustrated in Figure 1. Once registration is complete, an incoming call triggers an INAP IDP into the VIPER
middleware. A communications server CS creates a call model tlabelled "INAP
call"
in Figure 9) and passes control of the service to that call model. The call model communicates with the resource broker to identify an application that is capable 10 and ready to provide the resources required by the service. That application, if not already running, is created. The call model then request the application, in relation to this call; to perform a location look-up for the called party. On completion of the look-up, a mobile address returned by the look-up is passed to the communications server and the VIPER middleware send an INAP connect to the 15 SSP.
1: Network operator brings the VIPER broker into service.
2: VIPER broker registers it services with itself if necessary.
3: Network operator brings the VIPER Mobility Server into service.
4: VIPER Mobility Server registers itself as a PIugIN with the VIPER broker.
25 5: VIPER Mobility Server registers the services it supports with the VIPER
broker.
6: Network operator brings the VIPER Cambridge Communications Server into service.
30 7: VIPER Cambridge Communications Server registers itself as a PIugIN with the VIPER broker.
$: VIPER Cambridge Communications Server registers the services it supports with the VIPER broker.
9. GPT SSP sends an INAP Initial Detection Point (IDP) to the VIPER Cambridge Communications Server.
5 10 & 11. The VIPER Cambridge Communications Server creates a new call model to handle this service and then initiates the Call Model's constructor.
12. The Call Model requests from the VIPER broker the address of the PIugIN
tin this case, the VIPER Mobility Server) capable of providing the service described 10 within the service descriptor.
13, 14 & 15. The Call Model requests from the VIPER Mobility Server the address of the application capable of servicing the request. This causes the VIPER
Mobility Server to create a Roaming Application and then initiate the Roaming Application's 15 constructor. Flow 14 is optional depending on whether the Roaming Application is active or not.
SSP.
Figure 9 shows the message flows involved in a second scenario, with a network operator bringing a VIPER broker, a VIPER Mobility Server and a VIPER
Cambridge Communications Server into service. The VIPER mobility server may be, 5 for example, the SCP 6 running a mobility application illustrated in Figure 1. Once registration is complete, an incoming call triggers an INAP IDP into the VIPER
middleware. A communications server CS creates a call model tlabelled "INAP
call"
in Figure 9) and passes control of the service to that call model. The call model communicates with the resource broker to identify an application that is capable 10 and ready to provide the resources required by the service. That application, if not already running, is created. The call model then request the application, in relation to this call; to perform a location look-up for the called party. On completion of the look-up, a mobile address returned by the look-up is passed to the communications server and the VIPER middleware send an INAP connect to the 15 SSP.
1: Network operator brings the VIPER broker into service.
2: VIPER broker registers it services with itself if necessary.
3: Network operator brings the VIPER Mobility Server into service.
4: VIPER Mobility Server registers itself as a PIugIN with the VIPER broker.
25 5: VIPER Mobility Server registers the services it supports with the VIPER
broker.
6: Network operator brings the VIPER Cambridge Communications Server into service.
30 7: VIPER Cambridge Communications Server registers itself as a PIugIN with the VIPER broker.
$: VIPER Cambridge Communications Server registers the services it supports with the VIPER broker.
9. GPT SSP sends an INAP Initial Detection Point (IDP) to the VIPER Cambridge Communications Server.
5 10 & 11. The VIPER Cambridge Communications Server creates a new call model to handle this service and then initiates the Call Model's constructor.
12. The Call Model requests from the VIPER broker the address of the PIugIN
tin this case, the VIPER Mobility Server) capable of providing the service described 10 within the service descriptor.
13, 14 & 15. The Call Model requests from the VIPER Mobility Server the address of the application capable of servicing the request. This causes the VIPER
Mobility Server to create a Roaming Application and then initiate the Roaming Application's 15 constructor. Flow 14 is optional depending on whether the Roaming Application is active or not.
16. The Call Model sends a VIPER 2.0 equivalent of an lNAP IDP to the Roaming Application.
17. The Roaming Application performs a location lookup.
18. The Roaming Application sends a VIPER 2.0 Connect to the Call Model.
25 19. The Call Model sends an internal PIugIN connect to the VIPER Cambridge Communications Server.
20. The VIPER Cambridge Communications Server send an INAP connect to the GPT SSP.
Figure 10 illustrates an implementation of the VIPER architecture which provides a service platform which is distributed over different networks that may be located in different continents. In this example a customer at a customer terminal 100 is registered with a mobility application resident on a first application server connected to a first broadband signalling network e.g. in the UK. The customer terminal is connected via a digital local exchange DLE to a second broadband signalling network, e.g., in the US. The first and second national networks are interconnected via a jointly operated international network 103.
Resource brokers (referenced B) are connected to the networks and the resources available on each network are registered with the resource brokers. The resource brokers communicate data to each other via a global broker GB, so that, for example, the broker B connected to network 102 has in its registry details of resources on both network 101 and network 102. The communication between brokers may be implemented, e.g., using CORBA or IIOP over IP.
In operation, the customer at terminal 100 registers their current location with the mobility application on the first application server. To do this, they dial the number associated with the service. This triggers an IDP at the SSP. The SSP
requests from a local broker B the address of the application required to service the call. The local broker B communicates with the global broker GB connected to network 103 to obtain interface and address data to allow the SCP to communicate with application server 1. The mobility application may, for example, require the use of an interactive voice response (IVR) system to accept data from the customer. This resource is provided within network 101 by a first intelligent peripheral IP1. However, the second network includes its own IVR resources provided by a second intelligent peripheral IP2. The mobility application requests discovery of IVR resources from the broker B. After communication with the global broker GB, the broker returns detail of the IP2 that is local to the customer at the current customer location. The application server 1 uses this information to return an INAP connect message to the SSP to set up a connection between the customer terminal and IP2.
25 19. The Call Model sends an internal PIugIN connect to the VIPER Cambridge Communications Server.
20. The VIPER Cambridge Communications Server send an INAP connect to the GPT SSP.
Figure 10 illustrates an implementation of the VIPER architecture which provides a service platform which is distributed over different networks that may be located in different continents. In this example a customer at a customer terminal 100 is registered with a mobility application resident on a first application server connected to a first broadband signalling network e.g. in the UK. The customer terminal is connected via a digital local exchange DLE to a second broadband signalling network, e.g., in the US. The first and second national networks are interconnected via a jointly operated international network 103.
Resource brokers (referenced B) are connected to the networks and the resources available on each network are registered with the resource brokers. The resource brokers communicate data to each other via a global broker GB, so that, for example, the broker B connected to network 102 has in its registry details of resources on both network 101 and network 102. The communication between brokers may be implemented, e.g., using CORBA or IIOP over IP.
In operation, the customer at terminal 100 registers their current location with the mobility application on the first application server. To do this, they dial the number associated with the service. This triggers an IDP at the SSP. The SSP
requests from a local broker B the address of the application required to service the call. The local broker B communicates with the global broker GB connected to network 103 to obtain interface and address data to allow the SCP to communicate with application server 1. The mobility application may, for example, require the use of an interactive voice response (IVR) system to accept data from the customer. This resource is provided within network 101 by a first intelligent peripheral IP1. However, the second network includes its own IVR resources provided by a second intelligent peripheral IP2. The mobility application requests discovery of IVR resources from the broker B. After communication with the global broker GB, the broker returns detail of the IP2 that is local to the customer at the current customer location. The application server 1 uses this information to return an INAP connect message to the SSP to set up a connection between the customer terminal and IP2.
Claims (21)
1. A communications service platform comprising:
a multiplicity of loosely coupled subsystems, each of the subsystems including respective service processing resources; and a respective resource locator, each resource locator including means for communicating to others of the resource locators data indicating the subsystem identity and data indicating the availability of resources in the respective subsystem, and means for receiving identity data and resource availability data for resource locators in others of the subsystems.
a multiplicity of loosely coupled subsystems, each of the subsystems including respective service processing resources; and a respective resource locator, each resource locator including means for communicating to others of the resource locators data indicating the subsystem identity and data indicating the availability of resources in the respective subsystem, and means for receiving identity data and resource availability data for resource locators in others of the subsystems.
2. A platform according to claim 1, in which the resource locators are arranged to communicate directly with each other by peer-to-peer signalling.
3. A platform according to claim 1 or 2, further comprising a resource broker and in which at least some communication between the resource locators is mediated by the resource broker.
4. A platform according to claim 3, in which the resource broker is located in one of the said subsystems.
5. A platform according to claim 3 or 4, in which the resource broker includes:
a data interface arranged to receive capability data and interface data from respective resource locators, and a registry arranged to store the said capability data and interface data
a data interface arranged to receive capability data and interface data from respective resource locators, and a registry arranged to store the said capability data and interface data
6. A platform according to any one of claims 3 to 5, in which a resource locator in a subsystem is arranged initially to read capability data and interface data for another subsystem from the resource broker, and subsequently communicates further data directly with the other subsystem using the interface of the subsystem identified in the said interface data.
7. A platform according to any one of claims 3 to 6, in which at least one of the subsystems is arranged to communicate directly with a selected other subsystem via a respective specific data interface and in which others of the subsystems are arranged to communicate with a selected other subsystem via an object bus.
8, A platform according to claim 7 in which the or each said subsystem arranged to communicate directly via a respective specific data interface is arranged, on initialisation of the said subsystem, to read data for the selected other subsystem from the resource broker, and in response to calls subsequent to the initialisation of the subsystem, communicates directly with the selected other subsystem without reference to the resource broker.
9. A platform according to claim 7 or 8, in which the said subsystems arranged to communicate via an object bus are arranged, in response to each new call, to read resource data from the resource broker.
10. A communications system comprising:
a plurality of call processing subsystems;
a network interconnecting the plurality of call processing subsystems;
a resource broker connected to the network, the resource broker including a data interface arranged to receive capability data and interface data from respective call processing subsystems, and a registry arranged to store the said capability data and interface data.
a plurality of call processing subsystems;
a network interconnecting the plurality of call processing subsystems;
a resource broker connected to the network, the resource broker including a data interface arranged to receive capability data and interface data from respective call processing subsystems, and a registry arranged to store the said capability data and interface data.
11. A communications system according to claim 10, further comprising an object bus interconnecting at least some of the call processing subsystems.
12. A communications system according to claim 11, in which communication paths between others of the subsystems bypass the object bus.
13. A computing platform comprising a multiplicity of loosely coupled computing subsystems, each of the said subsystems including respective data processing resources and a respective resource locator arranged (to advertise its identity and the loading of the respective resources and to receive resource signalling from others of the resource locators.
14. A method of operating a communications system, the system including a multiplicity of processing subsystems and a network interconnecting the multiplicity of subsystems, the method comprising;
a) communicating from a resource locator in a respective one of the multiplicity of subsystems to resource locators in others of the multiplicity of subsystems data indicating the identity of the said one subsystem and the availability of resources in the said one subsystem b) repeating step (a) for each other of the multiplicity of subsystems:
c) when one of the multiplicity of subsystems, in the course of processing a call, requires resources not present locally in the said subsystem:
i) identifying from the said data communicated to the resource locator of the said one subsystem another subsystem having the said resources;
ii) accessing the said subsystem via the network.
a) communicating from a resource locator in a respective one of the multiplicity of subsystems to resource locators in others of the multiplicity of subsystems data indicating the identity of the said one subsystem and the availability of resources in the said one subsystem b) repeating step (a) for each other of the multiplicity of subsystems:
c) when one of the multiplicity of subsystems, in the course of processing a call, requires resources not present locally in the said subsystem:
i) identifying from the said data communicated to the resource locator of the said one subsystem another subsystem having the said resources;
ii) accessing the said subsystem via the network.
15. A method according to claim 14, in which, for each of the multiplicity of subsystems, step (a) is repeated regularly.
16. A method according to claim 15, in which the period of repetition for step (a) is small compared to the mean duration of a call processed by the communications system.
17. A method according to any one of claims 14 to 16, in which, for at least one of the multiplicity of subsystems, step fa) is repeated in response to an event in the respective subsystem.
18. A method according to claim 17, in which the said event is a change in resource availability in the subsystem exceeding a predetermined threshold.
19. A method according to any one of the preceding claims in which the communication of resource data between subsystems is mediated by a resource broker.
20. A method according to claim 19, in which data is communicated between at least some of the subsystems and the resource broker via an object bus.
21. A method according to claim 20 in which data is communicated between others of the subsystems directly, bypassing the object bus.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP98308384 | 1998-10-14 | ||
EP98308384.1 | 1998-10-14 | ||
PCT/GB1999/003347 WO2000022842A1 (en) | 1998-10-14 | 1999-10-08 | Processing platform |
Publications (1)
Publication Number | Publication Date |
---|---|
CA2347487A1 true CA2347487A1 (en) | 2000-04-20 |
Family
ID=8235103
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CA002347487A Abandoned CA2347487A1 (en) | 1998-10-14 | 1999-10-08 | Processing platform |
Country Status (5)
Country | Link |
---|---|
EP (1) | EP1121813A1 (en) |
JP (1) | JP2002528010A (en) |
AU (1) | AU759043B2 (en) |
CA (1) | CA2347487A1 (en) |
WO (1) | WO2000022842A1 (en) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1422949B1 (en) * | 2002-11-20 | 2004-10-20 | Alcatel | Method and system for providing services |
FR2851870A1 (en) * | 2003-02-28 | 2004-09-03 | France Telecom | MULTI-DOMAIN MULTI-PROVIDER MEDIATION BODY BETWEEN APPLICATION SERVICE PROVIDER AND RESOURCE PROVIDER IN A TELECOMMUNICATIONS NETWORK |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4800488A (en) * | 1985-11-12 | 1989-01-24 | American Telephone And Telegraph Company, At&T Bell Laboratories | Method of propagating resource information in a computer network |
WO1996020448A1 (en) * | 1994-12-23 | 1996-07-04 | Southwestern Bell Technology Resources, Inc. | Flexible network platform and call processing system |
KR19990022278A (en) * | 1995-06-09 | 1999-03-25 | 세모스 로버트 어니스트 빅커스 | Telecommunication network |
-
1999
- 1999-10-08 CA CA002347487A patent/CA2347487A1/en not_active Abandoned
- 1999-10-08 AU AU62172/99A patent/AU759043B2/en not_active Ceased
- 1999-10-08 WO PCT/GB1999/003347 patent/WO2000022842A1/en active IP Right Grant
- 1999-10-08 JP JP2000576635A patent/JP2002528010A/en active Pending
- 1999-10-08 EP EP99949192A patent/EP1121813A1/en not_active Withdrawn
Also Published As
Publication number | Publication date |
---|---|
AU759043B2 (en) | 2003-04-03 |
JP2002528010A (en) | 2002-08-27 |
AU6217299A (en) | 2000-05-01 |
EP1121813A1 (en) | 2001-08-08 |
WO2000022842A1 (en) | 2000-04-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
RU2144271C1 (en) | System for control over telecommunication maintenance | |
USH1837H (en) | Generic telecommunications system and associated call processing architecture | |
USH1921H (en) | Generic wireless telecommunications system | |
EP0873025B1 (en) | Method for providing at least one service to users of a telecommunication network | |
JP5726991B2 (en) | Communication network | |
EP1741277B1 (en) | Event processing system | |
EP0873026B1 (en) | Method for providing a service for users of a telecommunication network | |
JPH1146375A (en) | Service switching exchange for communication network and inter-service control facility communication method | |
US6341162B1 (en) | Telecommunications intelligent network | |
AU759043B2 (en) | Processing platform | |
US7007063B2 (en) | Server side program interface to service logic execution environment | |
US6954523B2 (en) | Method for providing a service in a telecommunication network and a corresponding infrastructure manager | |
US6600751B1 (en) | Gateway between a data network and a service network | |
US6570977B1 (en) | Connection setup method, service control point, and communications network | |
US6744855B1 (en) | Service control platform | |
KR100372724B1 (en) | Message Trace Method for Call Progress in Intelligent Network | |
WO2001086968A1 (en) | Initiating service logic | |
CA2357440C (en) | Load shared architecture for an ss7 node | |
JP2000092198A (en) | Service control platform | |
Choi et al. | A Service Switching Point for Intelligent Networks | |
GB2413030A (en) | Event processing system | |
Kubota et al. | Distributed processing platform for telecommunication networks | |
Bhadana | Advanced Intelligent Network for Wireless Communications | |
KR20000056811A (en) | Phone -Voting service method on Local Exchange |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
EEER | Examination request | ||
FZDE | Discontinued |