Embodiments relate to generating and managing a software application (“app”).
Network Function Virtualization (NFV) allows network services to be run as a software module on a general purpose server rather than specialized hardware equipment. An example of such a software module is a Virtual Network Function (VNF). Some network services, such as wireless, cannot be run from a general purpose server. Specialized hardware equipment is needed for multiple access wireless systems such as 5 G.
Example vendors of specialized hardware equipment are Nokia, Corporation of Espoo, Finland and Telefonaktiebolaget LM Ericsson of Stockholm, Sweden.
Specialized hardware equipment may be deployed, owned and operated by a traditional infrastructure equipment owner such as Verizon of New York, N.Y.
Examples of software modules are firewalls, load balancers and gateways.
Examples of cloud services accessed by software modules are network slices, backup equipment, network interfaces, processing resources and memory resources.
As used herein, an interface is a point of interaction between two network entities. The interface may be a software application programming interface (API). In some cases, an interface is a network protocol.
An app is a piece of software that utilizes underlying services to perform a function. The app may pass parameters in the form of arguments to an underlying service.
The specialized hardware equipment is difficult for an operator to use when a new problem arises. New software versions from a vendor of the specialized hardware equipment take a long time to deploy and are expensive. A solution is needed by which a new problem can be addressed with a patch to an operating software configuration of the specialized hardware equipment. Provided herein are smart libraries. The smart libraries store software modules, called apps, which can be deployed to specialized hardware equipment to solve a new problem.
Examples of new problems are a CPU of the specialized hardware equipment running hot (a utilization rate higher than recommended) or log files being required by an operator of the specialized hardware equipment or log files being required by an end-user of a wireless system.
Electrical energy consumption in wireless systems is very high. As part of operating a responsible network, reducing electrical energy consumption is needed.
Data flow in wireless networks is very high. Operators and end users are expected to require additional log files related to these data flows. Providing these log files is a network service.
Embodiments provided herein obtain an app from a software supplier and run the app on a host. The host is an example of a specialized hardware equipment. As a result of running the app, a network service is provided. In some embodiments, the network service includes improved network performance (such as reduction of electrical energy consumption by the host).
A server of a mobile network operator (MNO) executes network control logic for unbundling vertically integrated software on specialized hardware equipment, referred to here as a host. The server performs a handshake with the host, and establishes an encrypted channel. The server then negotiates with the host, and determines those interfaces, if any, that the host is willing to expose to third party software. The server, based on a current need of the MNO for a network service, compares the negotiation results with contents of a smart library. If the smart library does not have a registered and suitable app for the network service, the server obtains metadata corresponding to the app from a software supplier. The server then tests the metadata on a mockup of the host, under the control of the server. If the metadata is satisfactory, the server commands the smart library to obtain the app from the software supplier, and commands the host to install the app (obtained from the software supplier). The host then runs the app, providing the network service without requiring an entire software revision of the host. When the server determines that the app should be removed from the host, it sends a command to the host.
Provided herein is a method of managing a software application by a network control logic entity, the method comprising: obtaining an app; and running the app on a host server, wherein the host server is configured to provide services on a network, wherein the running the app provides a first network service, the host server is provided by an infrastructure vendor, the app is requested by the network control logic entity from a smart library server, and the smart library server is not under a control of the infrastructure vendor.
In some embodiments, the method includes requesting, by the network control logic entity from a software supplier, the app, wherein the app is to be configured to perform a first feature not available in the network.
In some embodiments, the method includes the network control logic entity commanding the host server to install the app in the host server.
In some embodiments, the app is configured to invoke cloud services via an application programming interface (API), wherein the cloud services and the API are supported by a cloud.
In some embodiments, a user makes use of the first network service provided by the host server executing the app.
In some embodiments, the first network service provides a log of phone calls made by the user.
In some embodiments, the first network service provides a reduction in electrical power consumption of the host server.
In some embodiments, the obtaining further comprises: testing, by the network control logic, metadata on a mock-up of the host server, wherein the metadata corresponds to the app and characterizes the app, at least in part, in terms of codelets.
In some embodiments, the obtaining further comprises: determining by the smart library server, that the app is present in a smart library database (DB); and notifying the network control logic entity that the app is available in the DB.
In some embodiments, a first image of the app occupies a first memory region of a first server controlled by a software supplier, a second image of the app occupies a second memory region of the DB of the smart library server, and a third image of the app occupies a third memory region of the host server.
In some embodiments, the network control logic entity commands the host server to de-install the app from the host server and to save an app state in a fourth memory region of the DB, whereby the host server no longer provides the first network service.
Also provided herein is an apparatus, the apparatus comprising: one or more processors; one or more memories; and computer code, wherein the computer code comprises: obtaining code configured to obtain an app; and executing code configured to cause the app to run on a host server, wherein: the host server is configured to provide services on a network, the app is configured to provide a first network service, the host server is provided by an infrastructure vendor, the app is requested by a network control logic entity from a smart library server, and the smart library server is not under a control of the infrastructure vendor.
In some embodiments of the apparatus, the obtaining further comprises: testing, by the network control logic, metadata on a mock-up of the host server, wherein the metadata corresponds to the app and characterizes the app, at least in part, in terms of codelets.
Also provided herein is a non-transitory computer readable medium storing instructions, wherein the instructions are configured to cause a computer to: obtain an app; and run the app on a host server, wherein the host server is configured to provide services on a network, wherein the app is configured to provide a first network service, the host server is provided by an infrastructure vendor, the app is requested by a network control logic entity from a smart library server, and the smart library server is not under a control of the infrastructure vendor.
Further, with respect to generating a software application provided herein is a method of generating an app by a network control logic entity, the method comprising: identifying requirements for operation of the app on a host server; sending the requirements to a software supplier; receiving the app at the network control logic entity; testing the app; and registering the app with a smart library server, wherein the host server is configured to provide services on a network, the app is configured to provide a first network service on the network, the host server is provided by an infrastructure vendor, and the smart library server is not under a control of the infrastructure vendor.
In some embodiments of the method the method includes negotiating by asking a host server what application programming interfaces (APIs) it is willing to expose; and identifying a network service which is needed and can be realized through one of the APIs.
In some embodiments, the testing the app includes testing the app for compatibility with the host server.
In some embodiments, the testing the app includes testing the app for achievement of a first feature, whereby a first service is provided by the host server on the network.
In some embodiments, the testing the app includes an application programming interface (API) for invocation of cloud services, wherein the cloud services and the API are supported by a cloud.
In some embodiments, the app is configured to permit a user to make use of the first network service provided by the host server executing the app.
In some embodiments, the first network service provides a log of phone calls made by the user.
In some embodiments, the first network service provides a reduction in electrical power consumption of the host server.
In some embodiments, a first image of the app occupies a first memory region of a first server controlled by the software supplier, a second image of the app occupies a second memory region of a database (DB) of the smart library server, and a third image of the app occupies a third memory region of the host server.
In some embodiments, the testing further comprises: testing, by the network control logic, metadata on a mock-up of the host server, wherein the metadata corresponds to the app and characterizes the app, at least in part, in terms of codelets.
In these ways, at
A technical effect is that software requirements of the host 1-5 are reduced at a time of deployment of host 1-5, and this permits more efficient generation of software as needed when new problems arise. More efficient generation of software leads to software occupying a smaller code space and requiring less run time. These are technical improvements to the functioning of a computer.
An example of a new feature 1-6 is an energy saving feature, a log feature, a firewall feature, a load balancer feature or a gateway feature. Corresponding examples of network service 1-11 are reduced electrical energy consumption in the network 1-4, improved provision of logs to the MNO 1-50 or end-user of the network 1-4, protection of the network 1-4 from malicious computer attack, improved load balancing for the host 1-5 and another specialized hardware equipment on the network 1-4 and access to devices with one or more new protocols in the stacks they support (gateway). Thus the network 1-4 is improved by the ability to get the feature 1-6 from the smart library 1-1.
For example, an energy saving feature may turn off cooling fans based on temperature constraints being satisfied. For example, if an internal temperature of the host is above a first threshold but below a second, higher, threshold, the energy saving feature may command that one of two cooling fans be turned off.
At 2-11, the smart library 1-1 identifies app 1-2 which provides feature 1-6.
At 2-12, the network control logic 1-3 commands installation of the app 1-2 in host 1-5.
The app 1-2 begins to function. At 2-13, app 1-2 invokes cloud services 1-10 of cloud 1-9 via an API 1-20. Examples of cloud service 1-10 are network slices, backup equipment, network interfaces, processing resources and memory resources.
At 2-14, based on the execution of app 1-2 on host 1-4, network control logic 1-3 has provided network 1-4 with feature 1-6 resulting in network service 1-11.
Generally, the verifier 1-13 is configured to perform the following functions. For further details, see
Perform a handshake 3-30 with the host 1-5 to prove the verifiers identity and to test the identity of the host for authenticity,
Establish an encrypted channel 3-32 with a host for confidentiality,
Perform a negotiation 2-6 with the host 1-5 to identify APIs 3-36 which the host 1-5 is willing to expose to 3rd party software,
Perform a test 9-13 of an app, or stipulate performance of tests 9-15 and 9-18 by the test service 9-1,
Maintain a table of specialized hardware equipment by vendor name and model number (the table including configuration information of the model, such as number of CPUs including CPUs running real-time kernels, air interfaces supported by the host, such as LTE, 5 G, NR, Wi-Fi and BlueTooth), code size, available free memory for new software, amount of memory, interface capability, number of cooling fans, log file capability, firewall features and load sharing capability, and
An internal interface with the network control logic 1-3, in order to recognize when a feature is needed to be performed by the host 1-5, and when the feature should be removed from the host 1-5.
The verifier 1-13 may be implemented in software running on a CPU in a server or in customized hardware such as FPGAs and/or ASICs.
After proving identities, a secure channel may be set up, referred to as an encrypted channel 3-32 in
Next, the network control logic 1-3 performs a negotiation 2-6 with the host 1-5. The purpose of the negotiation 2-6 is to learn aspects of the host 1-5 that the host 1-5 is willing to allow the network control logic 1-3 to control and/or to observe. Examples of aspects which might be exposed are energy control, energy saving, logging of events, a firewall or load balancing. This negotiation 2-6 illustrates presence of mutual trust or absence of mutual trust for various functions of the host 1-5. In an example, the host 1-5 informs the network control logic 1-3 of APIs 3-36 which the host 1-5 is willing to expose to interfacing with third party software.
At 3-10, the requirements 1-60, in view of the negotiation 2-6 and APIs 3-36, are sent from network control logic 1-3 to smart library 1-1. The requirements 1-60 may be considered a feature request. Also see
In some embodiments, smart library 1-1 obtains the app 1-2 from a software supplier 1-7 as shown by the arrow 3-13. In the case of obtaining from the software supplier 1-7, the software supplier 1-7 develops the app 1-2 as shown with item 3-14 and tests the app 1-2 as shown with item 3-16. The software supplier 1-7 then provides the app 1-2 as shown by item 3-17 at a time 3-2. The smart library 1-1 then communicates with the network control logic 1-3 (not shown).
At 3-18, the network control logic 1-3 issues an install command 2-12 to the host 1-5. In some embodiments, the host 1-5 performs a download operation from the smart library 1-1 (shown as item 3-20 and 3-22).
At time 3-3, the host 1-5 then installs the app 1-2.
At 3-26, the app 1-2 invokes cloud services 1-10 of cloud 1-9 via an API 1-20. In some embodiments, the API 1-20 is not used, and the cloud services 1-10 are invoked via a protocol, for example, with an end point of the protocol being a remote server available in cloud 1-9.
At 3-28, network 1-4 provides feature 1-6 resulting in network service 1-11. See the discussion of feature 1-6 and network service 1-11 above in the description of
Smart library processing entity 5-2 includes App DB 4-1, hardware 5-40 such as CPUs and memory and software 5-41 such as operating system, applications, vendor-specific software, protocol stacks and interface software. App DB 4-1 is in general composed of both software and hardware elements. Smart library processing entity 5-2 is configured to communicate over a communication network 5-5 using well known protocols such as TCP/IP, TLS, FTP, SSH, and IPsec, for example. Smart library processing entity 5-1 is an example of an instantiation of smart library 1-1, for example.
Software supplier processing entity 5-3 includes hardware 5-30 such as CPUs and memory and software 5-31 such as operating system, applications, vendor-specific software, protocol stacks and interface software. A database may also be deployed in 5-3 (not shown). Software supplier processing entity 5-3 is configured to communicate over a communication network 5-5 using well known protocols such as TCP/IP, TLS, FTP, SSH, and IPsec, for example. Software supplier processing entity 5-3 is an example a software development environment deployed by software supplier 1-7, for example.
Test paradigm 5-4 makes use of hardware 5-50 such as CPUs and memory and software 5-51 such as operating system, applications, vendor-specific software, protocol stacks and interface software. A database may also be deployed with 5-4 (not shown). The test paradigm 5-4 is configured to communicate over a communication network 5-5 using well known protocols such as TCP/IP, TLS, FTP, SSH, and IPsec, for example. Test paradigm 5-4 may be implemented by a vendor of specialized hardware equipment, a traditional infrastructure equipment owner, a third party testing laboratory, the software supplier 1-7 or the network control logic 1-3.
The test paradigm 5-4 may use benchmark tests for performance of the host 1-5 to see that app 1-2 does not affect other operations of host 1-5 in a negative way. For example, if app 1-2 arrives at a software state it cannot escape and occupies significant CPU time of host 1-5, this would be a failure of app 1-2. The test paradigm 5-4 also evaluates the performance of app 1-2 in delivering feature 1-6 in terms of, for example, execution time, electrical energy consumption (power in Watts), the aspects of feature 1-6 visible to the MNO 1-50 or to an end user (for example delivery of logs without errors in a readable form in a timely manner). Also see item 10-13 of
At state 2, the smart library 1-1 attempts to identify the app 1-2 satisfying the requirements 1-60 and performing the feature 1-6. If there is no existing app, a request is sent to the software supplier 1-7 (see
At state 2, if an app 1-2 is present with the desired feature, the state changes to state 3 (see 6-1 “yes”). At state 3, the app 1-2 is installed in the host 1-5 (also see
The state then changes from state 3 to state 4 and app 1-2 is used in the host 1-5 providing feature 1-6 and resulting in network service 1-11 (also see
At 8-10, the network control logic 1-3 identifies the requirements 1-60 for operation on host 1-5 to provide the feature 1-6.
At 8-11, the software supplier 1-7 develops the app 1-2. At 8-12, the network control logic 1-3 receives the app 1-2. At 8-13, the app 1-2 is tested for compatibility with the host 1-5 and for performance of feature 1-6. The delivery of network service 1-11 by the app 1-2 is also verified as providing improved network performance, in some embodiments. At 8-14, the smart library 1-1 registers the app 1-2 in the DB 4-1.
The test service 9-1 then tests the app 1-2 for achievement of feature 1-6 to provide network service 1-11. A status or result of the performance test is sent as message 9-20 to the network control logic 1-3.
The network logic 1-3 may reject the app 1-2 in view of status 9-16 and/or status 9-20 (rejection not shown in
Based on the status 9-16 and/or the status 9-20, the network control logic 1-3 may determine that the app 1-2 is acceptable (see 9-22). The network control logic 1-3 may then send a registration command 9-24 to the smart library 1-1 causing the smart library 1-1 to register the app 1-2 in DB 4-1.
Thus, as illustrated in
At 10-10 (time 3-1), requirements 1-60 are sent to the software supplier 1-7. At 10-12, the software supplier 1-7 develops the app 1-2. The software supplier then characterizes the app 1-2 using metadata 10-90.
The metadata 10-90 may include codelets. As one of skill in the art knows, the codelets may include remote procedure calls. A remote procedure call (RPC) is when a computer program causes a procedure to execute in a different address space (commonly on another computer on a shared network), which is coded as if it were a normal (local) procedure call, without the programmer explicitly coding the details for the remote interaction. That is, the programmer writes essentially the same code whether the subroutine is local to the executing program, or remote. This is a form of client—server interaction (caller is client, executor is server), typically implemented via a request—response message-passing system.
The metadata 10-90 includes information identifying the specialized hardware equipment on which app 1-2 is configured to run, and the functional area applicable to the app 1-2, for example, “radio.”
The network control logic determines, based on the metadata and the negotiation 2-6 whether one of the APIs 3-36 needed for the app 1-2 has been exposed by the host 1-5. If the metadata 10-90 has a conflict with the negotiation 2-6, the app 1-2 is rejected at 10-13 (see for example, 10-99 “rejected”).
If the negotiation 2-6 permits the function of the app 1-2, the network control logic 1-3 performs a test of the app 1-2 on a mock-up 10-21 of the host 1-5. Actual generic hardware is configured, based on the metadata 10-90 to perform as the underlying machine of the host 1-5. Also see
In some instances the mock-up 10-21 identifies a problem or potential problem and rejects the app 1-2 (again see 10-99).
In some instances, the mock-up 10-21 determines that the app 1-2 is satisfactory for the host 1-5, and the network control logic 1-3 accepts the app 1-2 (see 10-91). There is a mutual trust relationship between the network control logic 1-3 and the software supplier 1-7, and the integrity of the metadata 10-90 in characterizing the app 1-2 is relied on by the network control logic 1-3.
A message is sent to the software supplier 1-7 accepting the app 1-2 (see 10-92).
In some embodiments, the software supplier 1-7 then delivers the app 1-2 to the smart library 1-1.
In some embodiments, the network control logic 1-3 may then send the smart library 1-1 a registration command (see 10-94). The smart library 1-1 then registers the app 1-2 (see 10-95) in the DB 4-1.
Finally an install command 10-96 may be sent to the host 1-5, and the app 1-2 installed in the host 1-5 (see 10-97) at time 3-3. The host 1-5 may fetch the app 1-2 from the smart library as shown in
Number | Date | Country | |
---|---|---|---|
63173586 | Apr 2021 | US |