This disclosure relates generally to cloud computing, and, more particularly, to methods and apparatus to improve computing resource utilization.
In recent years, cloud service providers (CSPs) have enabled entities (e.g., business developers, merchants, analysts, etc.) to develop and implement (e.g., launch) one or more computing applications without the need to invest capital in computing equipment. Example CSPs maintain computing equipment, such as server farms, that is accessible to one or more users for a fee. In some examples, the computing resources of the CSP equipment (e.g., or portions of the CSP equipment) is accessible to the one or more users and/or clients of the one or more users via one or more networked connections. The networked computing equipment is sometimes referred-to herein as the cloud. Fees charged by the CSP are sometimes based on usage (e.g., a number of processing cycles consumed by a user, memory storage usage, etc.) so that the entities can scale-up or scale-down as needed without spending substantial amounts of capital owning, maintaining and/or managing their own computing equipment.
Cloud service providers (CSPs) facilitate cloud computing by making computing equipment (e.g., in the cloud) available to users via one or more networked connections. In response to a user request to utilize and/or access computing resources (e.g., a merchant web site transaction processing application, cryptographic processing application(s), etc.), a proportionate amount of the CSPs computing resources (e.g., a portion of the CSPs hardware platform) is allocated to that user's application(s). As such, when user demand for the resource(s) increases, a corresponding consumption of computing resources (e.g., processor cycles and/or storage) also increases. The amount of resource usage (e.g., processor cycles, storage space, etc.) is sometimes a basis for how the CSP charges its clients (also referred to as users). In some examples, a first portion of computing resources is allocated to the user for a particular fee and, if that first portion of computing resources is fully consumed and/or otherwise causes a backlog, then a second (or more) portion of computing resources may be automatically allocated to that user to help maintain performance expectations of the user's application. Of course, the CSP may additionally or alternatively structure their fees according to how many portions of computing resources are available to the user (e.g., a number of processor cores, an amount of storage space, and/or a number of computing cycles consumed by the user's application(s)).
The relationship between the CSP and its clients includes a degree of uncertainty for both parties. Because the client may not initially know how much computing hardware might be needed, computing resources and/or services available via the CSP allows that client to reduce that financial risk and defer/prevent purchase of such computing resources. Similarly, the CSP does not necessarily know ahead of time the degree to which client and/or end-user applications and/or workloads will exhibit demands on their hardware platform (or portions thereof). Clients sometimes demand a certain amount (often guaranteed) of availability from a selected CSP so that performance expectations are met. Metrics associated with service level agreements (SLAs) include, but are not limited to, response time after application demands are initiated, available bandwidth, service availability (e.g., x % availability), time to repair, support response time, unit processing response time (e.g., 500 mSec. for a certain processing task), etc.
While CSPs typically allocate some or all of the time of general purpose computers/processors, general purpose servers and/or general purpose processing cores to respective ones of its clients, some tasks, applications and/or services demanded by the clients include specific and/or otherwise unique requirements. Despite clock speed improvements of general purpose central processing units (CPUs) over the years, the CPU still has a limited structure of inputs, outputs, instruction set, architecture and/or instruction fetch and data protocols. In other words, a general purpose CPU while flexible in programmability, exhibits a fixed hardware structure. On the other hand, field-programmable gate arrays (FPGAs) are integrated circuits that may be customized by a client (and/or an end-user of the client) in the field to perform a particular purpose/task. FPGAs may include any number of logic gates (e.g., AND gates, XOR gates, etc.), memory elements, inputs, outputs, comparators, analog to digital converters, digital to analog converters and/or bidirectional data buses. Additionally, the FPGA is programmatically re-configured at the hardware level (as opposed to a CPU that is programmable by software, but its underlying physical circuitry does not change). As such, FPGAs may be restructured in the field (i.e., by an end user after leaving a manufacturing facility) to exhibit hardware circuits specifically designed to perform specific tasks. In some examples, an FPGA may be configured to accommodate inputs that are relatively wider than what can be processed by a single clock cycle of a general purpose CPU (e.g., data flow is limited by the CPU bus width (e.g., 16-bit, 32-bit, 64-bit, etc.), thereby affording throughput advantages on a per-cycle basis that general purpose CPUs cannot achieve.
Example methods, apparatus, systems and/or articles of manufacture disclosed herein utilize reprogrammable hardware (e.g., FPGAs) in a cloud-based computing environment to increase the efficiency of a cloud computing environment. FPGAs are circuits (e.g., silicon based) that can be programmed in the field to function as a special purpose processor. While FPGAs may be similar to ASICs (Application Specific Integrated Circuits), they differ in important ways. For instance, FPGAs may be programmed after leaving the manufacturing facility (e.g., in the field by an end user) one or more times. In contrast, ASICs are specifically designed to include specific hardware circuitry to perform one or more functions and lack an ability for reconfiguration in the field. FPGAs are, by definition, more flexible and can be designed in the field to perform tasks of interest. Unlike general purpose CPUs (which may be programmed in the field by software or firmware), programming and/or otherwise configuring an FPGA involves creating physical hardware circuits in the FPGA. Hardware circuits are often faster than software routines designed to perform the same function as the corresponding circuitry. Thus, the FPGA can be field programmed to do specific functions with hardware circuits more efficiently than a CPU can perform the same function via software.
Examples disclosed herein facilitate programming of the FPGA hardware (e.g., configuring the FPGA to include a particular circuit layout) during execution of end-user applications in a dynamic manner. For example, third-party subscriptions are disclosed here to facilitate configuring FPGAs to facilitate the hardware-based acceleration during runtime. By dynamically distributing reprogrammable hardware such as FPGAs (e.g., to enable hardware-based acceleration capabilities), performance of cloud-based computing efforts may be improved by realizing software routines with hardware performing the same function, thereby reducing an amount of processor cycles of the CSPs computing resources consumed by the client's application(s). Examples disclosed herein are not limited to CSP computing resource optimization, but may also include localized optimization on a per-machine or per-platform basis. In some examples, an organization information technology (IT) group (e.g., Enterprise IT) is chartered with a responsibility to manage personnel devices (e.g., desktop computers, laptop computers, etc.). In the event these personnel devices include FPGA hardware capabilities (e.g., Intel® Xeon®), examples disclosed herein permit one or more configuration management options for the Enterprise IT group by using one or more physically reprogrammable bit streams. In some examples, the Enterprise IT group may distribute and/or otherwise cause managed devices to retrieve/receive particular physically reprogrammable bit streams to accomplish one or more tasks (e.g., security offload acceleration tasks, searching capabilities, etc.) to be performed by the reprogrammable hardware (e.g., FPGAs) of those devices.
In still other example methods, apparatus, systems and/or articles of manufacture disclosed herein, original equipment manufacturers (OEMs) (e.g., network router manufacturers, security appliance vendors, etc.) may change a persona of the devices based on particular physically reprogrammable bit streams applied thereto. For instance, the OEM may include and/or otherwise be associated with one or more keys (e.g., license keys) that permit access to the physically reprogrammable bit streams that cause the OEM devices to operate in a particular manner depending on which bit stream(s) are implemented at a given time. In some examples, the OEM devices may operate in an effort to search network traffic (e.g., deep packet inspection) for specific content and, in response to application of one or more alternate physically reprogrammable bit streams, operate in an effort to perform an alternate task(s). Some examples include default access to particular physically reprogrammable bit streams without additional fees, while other examples may require that users of the OEM devices must pay for other physically reprogrammable bit streams.
Further, in examples where the client utilizes cloud-based hardware services, by providing the client with the opportunity to substitute hardware for software execution (e.g., by providing an FPGA), the client enjoys a degree of control to reduce fees paid to the CSP for usage of computing resources as the client now substitutes specialized hardware for software, thereby operating at a greater efficiency. Similarly, the CSP benefits by having a relatively lower demand on shared general purpose computing resources available to its clients because some of the tasks the CSP supports are being processed by the reprogrammable hardware instead of software executing on a general purpose processor. Further, power demands of the CSP are reduced when relatively more efficient reprogrammable hardware resources (e.g., FPGAs) are used instead of software executing on a general purpose processor.
In some examples disclosed herein, the CSP allocates computing resources of one or more platforms to a client. In some examples, the allocated hardware includes (a) one or more general purpose processors and (b) one or more physically configurable hardware devices (e.g., one or more FPGAs). The example client may contract with the CSP in any number of ways, such as paying for a number of processor cycles consumed by the general purpose processors to perform end-user tasks and/or applications. Additionally, the example client may contract with the CSP to have one or more physically configurable hardware devices, such as one or more FPGAs, available for customized use. In some examples, the FPGAs are dedicated to the client (i.e., no other client can access that FPGA). In some examples, the client configures the physically configurable hardware via physically programmed bit stream that is developed by the client, developed by the CSP, or developed by a third-party. Any number of parties may develop physically programmed bit streams to program and/or otherwise configure the physically configurable hardware. As such, examples disclosed herein facilitate a market for which clients (either cloud-based services or localized platform targets) can take advantage of such development efforts by other parties (e.g., third parties) when utilizing CSP hardware platform resources and/or FPGA resources on individual devices. As used herein, a “physically programmed bit stream” is defined to be a source of one or more bits which are structured to cause a physically configurable hardware device (such as an FPGA) to change its circuit topology.
The example subscription database 110 of
The example CSP 102 of
The example HSV system 108 may be independent from the CSP 102 and operate as a third party service for the clients. In some examples, the HSV system 108 operates as a repository for developers of physically programmable bit streams (e.g., third party developers, CSP-based developers, etc.). These physically programmable bit streams can be purchased by the clients and executed to program FPGAs within the CSP 102 that have been allocated to those clients.
Physically programmed bit streams may be designed in any number of ways such that upon execution they customize an FPGA (e.g., configure the FPGA to form a specific circuit or circuit topology). Example applications that a customized FPGA may implement include security firewall applications, traffic inspection applications, signal processing applications, IP store applications, equipment manufacturer upgrade application, bug fix applications, and/or image processing applications. In some examples, a customer/client of the CSP may develop and/or distribute services to their clients. As described above, the client and/or end-user experience may include a particular suite of services provided by a client to cause the reprogrammable hardware to exhibit a particular persona. Such examples may be realized by one or more virtual machines (VMs) instantiated on the resources of the CSP. However, in the event the persona (e.g., suite of services) for the client (and their corresponding end-user(s)) is to be altered (e.g., different functionality is needed at different times of the day), then a download of alternate physically programmable bit stream(s) allows the VM to establish the alternate persona when such bit streams are used to configure one or more FPGAs. Some designers of physically programmable bit streams may have particular expertise for particular brands and/or types of FPGAs. As such, the example HSV system 108 facilitates a market repository for any type of physically programmable bit stream that may be distributed to an end-user as an executable instruction (e.g., a binary executable capable of configuring an FPGA to perform a specific function via a specific circuit topology).
In operation, the example CSP 102 of the cloud-computing environment 100 identifies one or more client applications that satisfy (e.g., exceed) threshold operating parameters, such as a utilization metric for a processor (and/or VM) on which the client application executes. In response to identifying a particular application that satisfies the threshold operating parameters, the example CSP 102 identifies candidate physically programmable bit streams of the example HSV system 108 that may be appropriate to relieve the inundated CPU and/or VM from the excessive processing demands of the application. If one of the candidate physically programmable bit streams is appropriate, a selected one of the candidate physically programmable bit streams is authorized to be used to configure an FPGA, and the example CSP 102 configures the FPGA with the selected bit stream. In some examples, the CSP 102 invokes a request to the HSV system 108 to forward, send and/or otherwise distribute the corresponding bit stream to the CSP 102 so that one or more FPGAs may be configured. In still other examples, the CSP 102 maintains the corresponding physically programmable bit stream in a memory, particularly in circumstances where the corresponding physically programmable bit stream is used on a regular basis.
Using the corresponding physically programmable bit stream, the example CSP 102 configures the FPGA so that it may execute the client's objectives. In some circumstances, the FPGA execution may accomplish one or more objectives of the client's application in a manner that is faster (e.g., less latency) and/or more efficient than can be achieved by executing software on a general purpose CPU (e.g., provided by the example CSP 102, provided by the general purpose CPU of an individual device). In other words, the hardware based FPGA execution allows the general purpose CPUs to offload operations that they would otherwise be executed via software to hardware specifically configured to perform that function more quickly and/or efficiently. In some examples, the physically programmable bit streams may be used to configure the FPGA prior to provisioning cloud computing resources (e.g., general purpose CPUs), while in other examples the physically programmable bit streams may be used to configure the FPGA(s) during run time of the client application(s) (e.g., in response to information pertaining to actual workload). As such, a number of consumed processor cycles of the general purpose CPU may be reduced (e.g., on the fly in response to changed network demands), thereby resulting in cost savings for the client in the event the client is charged based on CPU usage.
In the event one or more physically programmed bit streams are not utilized for a period of time, such as a threshold period of time and/or a threshold number of instances per unit of time, then the example CSP 102 may vacate (flush) that particular bit stream from memory so that other bit streams may be stored therein.
As described in further detail below, examples disclosed herein enable client network and/or client application services to at least partially execute on FPGA devices provisioned by the example CSP 102. Additionally, such capabilities enable a reprogrammable hardware-based subscription model for CSPs and developers (e.g., independent third party developers) to provide customized physically reprogrammable bit streams that optimize functionality to support the client applications. Example physically reprogrammable bit streams may configure the circuitry of the reprogrammable hardware software-as-a-service (SaaS) and/or infrastructure-as-a-service (IaaS) applications and/or network capabilities. In some examples, the HSV 108 establishes pay-as-you-go agreements with the clients to determine billing requirements, while in other examples the CSP 102 establishes agreements including hosting fees for the privilege of utilizing available reprogrammable hardware and/or transaction fees for such reprogrammable hardware utilization. As such, the example cloud computing environment 100 of
The illustrated example of
In operation, the example AS 202 monitors a client application (e.g., the example client network service 104, the example client application service 106) is executing or is to be executed. During a setup stage of operation, the example AS 202 may continue to monitor for such workloads, such as by employing a performance monitor facilitated by a platform operating system, such as PerfMon in the Windows® family of operating systems. Each workload detected by the example AS 202 may be configured or otherwise associated with a corresponding threshold performance value, such as a percent threshold of general purpose CPU utilization, a percent threshold of memory utilization, a bandwidth threshold value of traffic, etc. As described in further detail below, in the event a threshold value is satisfied (e.g., exceeded), then the example AS 202 may invoke reprogrammable hardware resources to better manage performance of the client application. One or more established threshold values for respective client applications may form a policy, such that satisfaction of one or more thresholds may result in the invocation (e.g., programming one or more FPGAs and load shifting to the newly configured devices) of a corresponding reprogrammable hardware resource. In other examples, a client application activity flag may be established instead of a threshold performance value. In such circumstances, the example AS 202 may invoke reprogrammable hardware resources as soon as the client application has begun execution. In still other examples, reprogrammable hardware resources may be configured at boot time to allow a basic input/output system (BIOS) to load a corresponding physically reprogrammable bit stream to one or more reprogrammable hardware devices to program the devices for the device functionality.
Other examples include dynamically adding new physically reprogrammable bit streams to facilitate hardware acceleration (e.g., programming reprogrammable hardware to perform different functions in hardware instead of software or a general purpose CPU to perform functions. In some examples, virtual machines (VMs) are spawned to offload CPU tasks to the reprogrammable hardware (e.g., FPGAs). For example, some virtual machine managers (VMMs) are capable of virtual device hot-plugging, in which a new physically reprogrammable bit stream may be hot-plugged via a QEMU bus. When an operating system kernel identifies an opportunity for acceleration, a VM can characterize and load corresponding acceleration driver(s) (e.g., bit streams) and notify a corresponding application (e.g., Linux signals, interrupts, etc.). In the event a driver is aware of acceleration options, then the corresponding application may switch to the acceleration physically reprogrammable bit stream. In still other examples, the AS 202 may be an optional component, particularly in circumstances where computing resources are provided by a cloud-based service. For example, the CSP 102 may require an additional fee charged to clients to perform one or more services of the AS 202. The example AS 202 may be initially set in a default state (e.g., initially disabled) and, in response to a toggle request for services provided by the AS 202, the AS 202 may be activated (e.g., after client consent to a fee).
Continuing with the example where the AS 202 has detected a client application that has satisfied one or more policy threshold values and/or activity flags, the example DDM 204 determines whether an existing subscription (e.g., an existing agreement to use one or more physically reprogrammable bit streams for reprogrammable hardware configuration purposes) has been established for the client application. If so, then the example DDM 204 determines whether an available physically reprogrammable bit stream is already stored in the example memory 212. If so, then the example DDM 204 configures the reprogrammable hardware resource(s) using the subscribed physically reprogrammable bit stream and initiates the reprogrammable hardware resource(s) to handle and/or otherwise execute the client application. However, in the event the example DDM 204 determines that an existing subscription has been established with the client application, but it is not stored in the example memory 212, then the example DDM 204 invokes the example HSV system 108 to retrieve the appropriate physically reprogrammable bit stream and then configures the reprogrammable hardware resource(s) using the same.
In circumstances where the client application does not have an existing or previously established subscription to an appropriate physically reprogrammable bit stream that is able to establish reprogrammable hardware to assist execution of the client application, the example DDM 204 manages candidate subscription options by invoking the example HSV system 108, as described in further detail below. In the event an appropriate physically reprogrammable bit stream is selected, paid for or compensated (e.g., no charge when hardware is updated to fix bugs, standard upgrade agreements at no charge, etc.) (e.g., via the example billing manager 226), and authorized (e.g., by the example authentication manager 224), then the retrieved and/or otherwise obtained physically reprogrammable bit stream is initiated by the example DDM 204. Of course, in the event the example HSV system 108 does not include an appropriate physically reprogrammable bit stream that is capable of executing the client application, then the example DDM 204 configures the example computing resources 208 to continue to employ general purpose processing resources (e.g., one or more general purpose CPUs) to execute the example HSEC 103. In the event that any developer later creates one or more physically reprogrammable bit streams that target the client application, such physically reprogrammable bit streams may be added to the example subscription database 110 to be offered as an optimization resource.
While the example AS 202 monitors workloads and/or client applications (e.g., one or more HSECs 103, such as the example client network service 104 and/or the example client application service 106), the example AS 202 also monitors for instances of inactivity of such client applications. In particular, if a physically reprogrammable bit stream stored in the example memory 212 has not been utilized and/or otherwise invoked after a threshold amount of time, then the AS 202 instructs the example DDM 204 to remove it from the memory 212 to conserve storage resources for one or more other physically reprogrammable bit streams that may be more frequently used and/or otherwise needed. In other words, the example AS 202 vacates (flushes) underutilized physically reprogrammable bit streams from the example memory 212 in a dynamic manner.
Returning to the example where an existing physically reprogrammable bit stream is known to be able to program reprogrammable hardware to improve the efficiency of a client application, but is not currently stored in the example memory 212, the example SO 218 retrieves and/or otherwise receives a request from the example DDM 204 for the identified subscribed physically reprogrammable bit stream. In particular, the example SO 218 identifies the appropriate physically reprogrammable bit stream from the example subscription database 110 based on an identifier of a workload (e.g., one or more end-user applications), and the example billing manager 226 verifies that all billing requirements have been satisfied. In some examples, the billing manager 226 verifies existing agreements between the client and the third party developer of the selected physically reprogrammable bit stream, such as billing account information and/or in circumstances where an OEM has an agreement for such bit stream access. Additionally, the example authentication manager 224 verifies that the physically reprogrammable bit stream is authorized to be distributed to the requestor, such as the client application currently executing via resources provided by the CSP 102 and/or resources of an individual device not necessarily associated with cloud-based resource utilization. Authorization may include analyzing the request from the DDM 204 for one or more identifiers, such as unique serial numbers, hash values, license keys, etc. that may have been created for a particular client at the time the corresponding physically reprogrammable bit stream was originally purchased. After such authorization is verified, the example SO 218 distributes and/or otherwise sends the requested physically reprogrammable bit stream to the example DDM 204 to be instantiated on the computing resources 208 of the CSP 102 (or stand-alone device(s)), such as one or more reprogrammable hardware devices allocated to the client (and/or the client's end-user(s)).
Returning to the example in which the client application does not have any pre-existing subscription to an appropriate physically reprogrammable bit stream that is capable of improving the performance of the client application, the example SO 218 retrieves and/or otherwise receives parameters associated with the client application. Example parameters may include any number of details related to the client application such as, but not limited to the target reprogrammable hardware type that is available to the end-user (e.g., based on FPGA types that the CSP 102 is able to allocate to their user base) and/or a target application type (e.g., packet inspection applications, security processing applications, low latency packet processing applications, switching applications, routing applications, cryptography (e.g., region and/or country-specific) applications, video/audio processing applications, etc.).
In operation, the example DDM 204 sends a query to the example SO 218 to determine whether the HSV system 108 contains one or more physically reprogrammable bit streams that might be relevant to a client's application. For example, the DDM 204 may send available details related to the client application to the SO 218. The SO 218 attempts to perform a match of candidate physically reprogrammable bit streams that are relevant to the received parameter information. For the sake of example, if the DDM 204 sends only an application parameter that identifies the type of FPGA device which is of interest, then the example SO 218 will return a portion (e.g., a subset) of the application parameters list 300 that is specific to the queried FPGA device type from the example target FPGA platform column 304. On the other hand, if the DDM 204 sends only an application parameter that identifies a type of desired application, then the example SO 218 will return a portion of the application parameters list 300 that is specific to the queried application type details. In some examples, the application store interface 220 includes a graphical user interface and/or web server to render queries and/or selections related to available bit streams stored in the example subscription database 110.
While an example manner of implementing the cloud-computing environment 100 of
Flowcharts representative of example machine readable instructions for implementing the cloud-computing environment 100 of
As mentioned above, the example processes of
The program 400 of
The program 500 of
In the event that the physically reprogrammable bit stream associated with the end-user subscription is not stored in the memory 212 of the CSP 102 (block 506), then the example DDM 204 queries the example HSV system 108 to manage the subscribed physically reprogrammable bit stream (block 510), as described further in connection with
Returning to block 504 of
Turning to
During runtime, in the event no workloads have satisfied threshold values and/or identified active flags associated with workloads (block 502), the example AS 202 determines whether existing subscription physically reprogrammable bit streams satisfy dormancy threshold values (block 520). If not, control returns to block 502 to continue monitoring the computing resources 208 for instances of workload threshold satisfaction. However, if one or more workloads satisfies threshold values indicative of dormancy (block 520), then the example DDM 204 vacates the associated physically reprogrammable bit stream from memory 212 to conserve memory resources for other, more current, physically reprogrammable bit streams (block 522).
The processor platform 800 of the illustrated example includes a processor 812. The processor 812 of the illustrated example is hardware. For example, the processor 812 can be implemented by one or more integrated circuits, logic circuits, microprocessors or controllers from any desired family or manufacturer. In the illustrated example of
The processor 812 of the illustrated example includes a local memory 813 (e.g., a cache). The processor 812 of the illustrated example is in communication with a main memory including a random access memory (RAM) 814 and a read only memory (ROM) (e.g., non-volatile memory) 816 via a bus 818. The RAM 814 may be implemented by Synchronous Dynamic Random Access Memory (SDRAM), Dynamic Random Access Memory (DRAM), RAMBUS Dynamic Random Access Memory (RDRAM) and/or any other type of random access memory device. The ROM 816 may be implemented by flash memory and/or any other desired type of memory device. Access to the main memory 814, 816 is controlled by a memory controller.
The processor platform 800 of the illustrated example also includes an interface circuit 820. The interface circuit 820 may be implemented by any type of interface standard, such as an Ethernet interface, a universal serial bus (USB), and/or a PCI express interface.
In the illustrated example, one or more input devices 822 are connected to the interface circuit 820. The input device(s) 822 permit(s) a user to enter data and commands into the processor 812. The input device(s) can be implemented by, for example, an audio sensor, a microphone, a camera (still or video), a keyboard, a button, a mouse, a touchscreen, a track-pad, a trackball, isopoint and/or a voice recognition system.
One or more output devices 824 are also connected to the interface circuit 820 of the illustrated example. The output devices 824 can be implemented, for example, by display devices (e.g., a light emitting diode (LED), an organic light emitting diode (OLED), a liquid crystal display, a cathode ray tube display (CRT), a touchscreen, a tactile output device, a printer and/or speakers). The interface circuit 820 of the illustrated example, thus, typically includes a graphics driver card, a graphics driver chip or a graphics driver processor.
The interface circuit 820 of the illustrated example also includes a communication device such as a transmitter, a receiver, a transceiver, a modem and/or network interface card to facilitate exchange of data with external machines (e.g., computing devices of any kind) via a network 826 (e.g., an Ethernet connection, a digital subscriber line (DSL) to facilitate exchange of data within a similar machine platform (e.g., a communication bus), a telephone line, coaxial cable, a cellular telephone system, etc.).
The processor platform 800 of the illustrated example also includes one or more mass storage devices 828 for storing software and/or data. Examples of such mass storage devices 828 include floppy disk drives, hard drive disks, compact disk drives, Blu-ray disk drives, RAID systems, solid-state-drives (SSDs) and digital versatile disk (DVD) drives. In some examples, the mass storage device 830 may implement the example subscription database 110.
The coded instructions 832 of
From the foregoing, it will be appreciated that methods, apparatus and articles of manufacture have been disclosed which reduce consumed resources of cloud service providers by allowing reprogrammable hardware devices an opportunity to perform one or more tasks in a more efficient manner than could otherwise be performed by general purpose CPUs. In particular, because reprogrammable hardware devices, such as FPGAs, can be programmed and/or otherwise configured for specific tasks, a reduction in processing time/process cycles, improvement related to a general purpose processor executing software is realized by the reprogrammable hardware, whether such hardware resides on cloud-based services or individual devices. Additionally, end-users that choose to utilize one or more reprogrammable hardware resources offered by the cloud service provider can potentially save money that would otherwise be spent using cycles performed by the general purpose CPUs. Furthermore, the cloud service provider permits an opportunity to (a) improve client workload execution and (b) conserve limited general purpose CPU resources that are shared among any number of other end-users of the cloud service provider.
Additional benefits of examples disclosed herein include enablement of hardware subscription business models for independent network or application service providers (e.g., AT&T, F5 Networks, Cisco, etc.) to execute their applications in a hardware-optimized manner (e.g., accelerated). Client applications may operate with hardware subscriptions (one or more physically reprogrammable bit streams) that can be executed on CSP infrastructures, which facilitates a business model for physically reprogrammable bit stream developers, increases feature capabilities to be offered by CSPs to their end-users, conserves processing resources, improves client application performance, and conserves limited platform resources of the CSPs. Additionally, telecom cloud providers (TCPs) such as AT&T, China Telecom, T-Mobile and Verizon may use standard servers with FPGAs rather than fix-function networking equipment and/or appliances, thereby reducing a corresponding total cost outlay for their services. In other words, such TCPs no longer need to rely on unique telecom appliances in their network infrastructure and may instead employ cloud-based reprogrammable hardware devices, such as FPGAs.
Examples disclosed herein enable TCPs to market their segments/customers by offering SLAs that improve the reliability of their computing, storage and/or networking infrastructure services. Typically, to maintain specific SLAs the TCPs need to enforce a relatively high degree of control over what computing resources and/or software are deployed so that they can satisfy uptime commitments (e.g., 24 hours per day, 7 days a week). Further, the TCPs may scale-up or scale-down and/or adapt to new/alternate standards as a number of subscribers grows/shrinks. Such scaling may be realized with examples disclosed herein to maintain SLAs that are more robust than traditional SLAs. This also encourages equipment standardization of different parts of the TCP infrastructure. Further, in the event TCP functionality is to evolve, dynamically configured hardware devices, such as example FPGAs, can be configured to meet such new and evolved functionality without truck-rolls to replace specialized hardware.
In the illustrated example of
In some examples, country-specific encryption and/or decryption may be needed, in which such activities are regulated and may change on a relatively frequent basis. In view of such regulatory flux and uncertainty, manufacturers of special-purpose hardware experience short life cycles of their special-purpose products and/or solutions. Accordingly, developers of solutions for such special-purpose functionality may be reluctant to engage in development efforts for fear that a relatively long-term life cycle of any developed special-purpose product will not be realized. On the other hand, examples disclosed herein facilitate an ability to develop such special-purpose functionality that is targeted to reprogrammable hardware (e.g., FPGAs). As such, manufacturing costs for special-purpose hardware are reduced, repeated hardware export/import compliance efforts are reduced, and in the event regulations change, the same reprogrammable hardware devices can be used for implementing the new/alternate regulations (e.g., alternate encryption/decryption requirements imposed by particular country jurisdictions). In other words, rather than developing a new special-purpose hardware product that must satisfy customs requirements when shipped to the jurisdiction of interest, the same reprogrammable hardware devices may continue to be used to implement the alternate/updated functionality requirements via transmission of an appropriate bit stream.
Example methods, apparatus, systems and articles of manufacture to improve computing resource utilization are disclosed herein. Further examples and combinations thereof include the following.
Example 1 is an apparatus including an application specific sensor (AS) to monitor a workload of at least one general purpose central processing unit (CPU) of a platform; and a dynamic deployment module (DDM) to: in response to a workload performance threshold being satisfied, identify a physically reprogrammable bit stream capable of configuring a reprogrammable hardware device to execute at least one function of the workload; and configure the reprogrammable hardware device via the physically reprogrammable bit stream to execute the at least one function of the workload.
Example 2 includes the apparatus as defined in example 1, wherein the DDM configures the reprogrammable hardware device to optimize a performance metric.
Example 3 includes the apparatus as defined in example 2, wherein the optimized performance metric is a latency of the workload, the latency reduced when the at least one function is executed by the reprogrammable hardware device and the at least one function is not executed by the general purpose CPU.
Example 4 includes the apparatus as defined in example 1, wherein the DDM is to query a subscription orchestrator when the physically reprogrammable bit stream capable of configuring the reprogrammable hardware device to execute the at least one function of the workload is not stored within a memory of the platform.
Example 5 includes the apparatus as defined in example 4, wherein the DDM is to retrieve the physically reprogrammable bit stream from the subscription orchestrator in response to verifying that an identifier of the workload is authorized to receive the bit stream.
Example 6 includes the apparatus as defined in example 1, wherein the AS is to determine if the bit stream has been dormant for a threshold period of time.
Example 7 includes the apparatus as defined in example 6, wherein the DDM is to vacate the bit stream from a memory in response to receiving an indication that the bit stream has been dormant for at least the threshold period of time.
Example 8 includes the apparatus as defined in example 1, wherein the DDM is to instruct the general purpose CPU to discontinue executing the workload in response to the reprogrammable hardware device executing the workload.
Example 9 includes the apparatus as defined in example 1, wherein the platform is located on at least one of a cloud-based computing resource or a stand-alone computing device.
Example 10 includes the apparatus as defined in example 1, wherein the DDM is to obtain the physically reprogrammable bit stream for stand-alone computing devices associated with an Enterprise information technology network.
Example 11 includes the apparatus as defined in example 10, wherein the DDM is to configure the reprogrammable hardware device with an alternate physically reprogrammable bit stream to facilitate an alternate workload of the platform.
Example 12 is a method, comprising monitoring a workload of at least one general purpose central processing unit (CPU) of a platform, in response to a workload performance threshold being satisfied, identifying a physically reprogrammable bit stream capable of configuring a reprogrammable hardware device to execute at least one function of the workload, and configuring the reprogrammable hardware device via the physically reprogrammable bit stream to execute the at least one function of the workload.
Example 13 includes the method as defined in example 12, further including configuring the reprogrammable hardware device to optimize a performance metric.
Example 14 includes the method as defined in example 13, wherein the optimized performance metric is a latency of the workload, the latency reduced when the at least one function is executed by the reprogrammable hardware device and the at least one function is not executed by the general purpose CPU.
Example 15 includes the method as defined in claim 12, further including querying a subscription orchestrator when the physically reprogrammable bit stream capable of configuring the reprogrammable hardware device to execute the at least one function of the workload is not stored within a memory of the platform.
Example 16 includes the method as defined in example 15, further including retrieving the physically reprogrammable bit stream from the subscription orchestrator in response to verifying that an identifier of the workload is authorized to receive the bit stream.
Example 17 includes the method as defined in example 12, further including determining if the bit stream has been dormant for a threshold period of time.
Example 18 includes the method as defined in example 17, further including vacating the bit stream from a memory in response to receiving an indication that the bit stream has been dormant for at least the threshold period of time.
Example 19 includes the method as defined in example 12, further including instructing the general purpose CPU to discontinue executing the workload in response to the reprogrammable hardware device executing the workload.
Example 20 includes the method as defined in example 12, wherein the platform is located on at least one of a cloud-based computing resource or a stand-alone computing device.
Example 21 includes the method as defined in example 12, further including obtaining the physically reprogrammable bit stream for stand-alone computing devices associated with an Enterprise information technology network.
Example 22 includes the method as defined in example 21, further including configuring the reprogrammable hardware device with an alternate physically reprogrammable bit stream to facilitate an alternate workload of the platform.
Example 23 is a tangible computer-readable storage disk or storage device comprising instructions which, when executed, cause a processor to at least: monitor a workload of at least one general purpose central processing unit (CPU) of a platform, in response to a workload performance threshold being satisfied, identify a physically reprogrammable bit stream capable of configuring a reprogrammable hardware device to execute at least one function of the workload, and configure the reprogrammable hardware device via the physically reprogrammable bit stream to execute the at least one function of the workload.
Example 24 includes the tangible computer-readable storage disk or storage device as defined in example 23, wherein the instructions, when executed, further cause the processor to configure the reprogrammable hardware device to optimize a performance metric.
Example 25 includes the tangible computer-readable storage disk or storage device as defined in example 24, wherein the instructions, when executed, further cause the processor to reduce a latency of the workload when the at least one function is executed by the reprogrammable hardware device and the at least one function is not executed by the general purpose CPU.
Example 26 includes the tangible computer-readable storage disk or storage device as defined in example 23, wherein the instructions, when executed, further cause the processor to query a subscription orchestrator when the physically reprogrammable bit stream capable of configuring the reprogrammable hardware device to execute the at least one function of the workload is not stored within a memory of the platform.
Example 27 includes the tangible computer-readable storage disk or storage device as defined in example 26, wherein the instructions, when executed, further cause the processor to retrieve the physically reprogrammable bit stream from the subscription orchestrator in response to verifying that an identifier of the workload is authorized to receive the bit stream.
Example 28 includes the tangible computer-readable storage disk or storage device as defined in example 23, wherein the instructions, when executed, further cause the processor to determine if the bit stream has been dormant for a threshold period of time.
Example 29 includes the tangible computer-readable storage disk or storage device as defined in example 28, wherein the instructions, when executed, further cause the processor to vacate the bit stream from a memory in response to receiving an indication that the bit stream has been dormant for at least the threshold period of time.
Example 30 includes the tangible computer-readable storage disk or storage device as defined in example 23, wherein the instructions, when executed, further cause the processor to instruct the general purpose CPU to discontinue executing the workload in response to the reprogrammable hardware device executing the workload.
Example 31 includes the tangible computer-readable storage disk or storage device as defined in example 23, wherein the instructions, when executed, further cause the processor to obtain the physically reprogrammable bit stream for stand-alone computing devices associated with an Enterprise information technology network.
Example 32 includes the tangible computer-readable storage disk or storage device as defined in example 31, wherein the instructions, when executed, further cause the processor to configure the reprogrammable hardware device with an alternate physically reprogrammable bit stream to facilitate an alternate workload of the platform.
Example 33 is a system including means for monitoring a workload of at least one general purpose central processing unit (CPU) of a platform, in response to a workload performance threshold being satisfied, means for identifying a physically reprogrammable bit stream capable of configuring a reprogrammable hardware device to execute at least one function of the workload, and means for configuring the reprogrammable hardware device via the physically reprogrammable bit stream to execute the at least one function of the workload.
Example 34 includes the system as defined in example 33, further including means for configuring the reprogrammable hardware device to optimize a performance metric.
Example 35 includes the system as defined in example 34, wherein the optimized performance metric is a latency of the workload, the latency reduced when the at least one function is executed by the reprogrammable hardware device and the at least one function is not executed by the general purpose CPU.
Example 36 includes the system as defined in example 33, further including means for querying a subscription orchestrator when the physically reprogrammable bit stream capable of configuring the reprogrammable hardware device to execute the at least one function of the workload is not stored within a memory of the platform.
Example 37 includes the system as defined in example 36, further including means for retrieving the physically reprogrammable bit stream from the subscription orchestrator in response to verifying that an identifier of the workload is authorized to receive the bit stream.
Example 38 includes the system as defined in example 33, further including means for determining if the bit stream has been dormant for a threshold period of time.
Example 39 includes the system as defined in example 38, further including means for vacating the bit stream from a memory in response to receiving an indication that the bit stream has been dormant for at least the threshold period of time.
Example 40 includes the system as defined in example 33, further including means for instructing the general purpose CPU to discontinue executing the workload in response to the reprogrammable hardware device executing the workload.
Example 41 includes the system as defined in example 33, wherein the platform is located on at least one of a cloud-based computing resource or a stand-alone computing device.
Example 42 includes the system as defined in example 33, further including means for obtaining the physically reprogrammable bit stream for stand-alone computing devices associated with an Enterprise information technology network.
Example 43 includes the system as defined in example 42, further including means for configuring the reprogrammable hardware device with an alternate physically reprogrammable bit stream to facilitate an alternate workload of the platform.
Example 44 includes any of the examples above, further including optimizing at least one of cloud computing resources or localized machine resources.
Example 45 includes example 44, further including an information technology (IT) group to manage personnel devices having FPGA hardware capabilities.
Example 46 includes example 44, wherein optimization is realized by way of distributed physically reprogrammable bit streams to accomplish one or more tasks.
Example 47 includes example 46, wherein the one or more tasks include at least one of security offloading acceleration or searching tasks.
Example 48 includes example 44, further including an original equipment manufacturer (OEM) to change a persona of a device based on at least one physically reprogrammable bit stream.
Example 49 includes example 48, further including one or more keys to authorize bit stream access by the OEM.
Example 50 includes example 44, further including a toggle setting to at least one of enable or disable application specific sensor monitoring of platform applications.
Although certain example methods, apparatus and articles of manufacture have been disclosed herein, the scope of coverage of this patent is not limited thereto. On the contrary, this patent covers all methods, apparatus and articles of manufacture fairly falling within the scope of the claims of this patent.
This patent claims the benefit of, and priority to, U.S. Provisional Application Ser. No. 62/306,048, entitled “Methods and Apparatus to Improve Cloud Computing Resource Utilization” and filed on Mar. 9, 2016, which is hereby incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
62306048 | Mar 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15087287 | Mar 2016 | US |
Child | 17017060 | US |