The present disclosure generally relates to computers and, in example embodiments, to computer-implemented networks.
Cloud computing and various distributed networks are becoming more prevalent to provide reliability and capacity to handle multiples of requests at the same time. Different versions of software packages may be installed on each server in the server pool/cloud. Software packages are generally installed from a local repository with instructions for the server to install from the local repository. Accordingly different software versions may be installed.
When new server machines are brought up, software packages are continuously being installed. However, there may be variations in the versions of each individual software package that is being installed. Typically, “the latest version” of an application/software package is installed but it is not always possible to determine which particular version is installed. Accordingly, different versions of applications may be installed on different servers in a server pool.
The present disclosure is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings in which:
Although the present disclosure has been described with reference to specific example embodiments, it will be evident that various modifications and changes may be made to these embodiments without departing from the broader spirit and scope of the disclosure. Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense.
An RPM (RPM Package Manager) verifier module is described. The verifier module may also be referred to as a software package management verifier module. The RPM is a package management system used by system administrator to perform software installation and maintenance on multiple machines. The name RPM variously refers to the .rpm file format, files in this format, software packaged in such files, and the package manager itself. The use of RPM rather than manual building and installation of software has advantages such as simplicity, consistency and the ability for these processes to be automated and non-interactive.
The RPM verifier loads a master configuration file and a list of host servers. The master configuration file defines rules for approved versions of software packages installed on each host server in the list. The RPM verifier queries each host server in the list for a version identifier of one or more software packages installed on each host server. The rules are applied to the version identifier to identify one or more mis-configured software packages on each host server.
In one embodiment, the RPM verifier is configured to identify one or more software packages missing from a host server, one or more software packages installed on a host server having a newer version compared to the approved version of the corresponding software package for the host server as defined in the rules, or one or more software packages installed on a host server having an older version compared to the approved version of the corresponding software package for the host server as defined in the rules.
In another embodiment, the RPM verifier module has a querying module, a parsing module, and an analysis module. The querying module queries each host server in the list for the version identifier of one or more installed software packages in each host server. The parsing module parses information received from each host server in response to the query for a host server name, a software package installed on each host server, and a version of the installed software package. The analysis module applies the rules to the parsed information to identify one or more software packages missing from each host server, and one or more software packages installed on each host server having a newer or older version compared to the approved version of the corresponding software package for each host server as defined in the rules.
In one embodiment, the analysis module generates a report based on software packages. The report identifies a number of host servers having a version of an installed software package matching the version of the corresponding software package approved in the rules, a number of host servers having the version of the installed software package ahead of the version of the corresponding software package approved in the rules, a number of host servers having the version of the installed software package behind the version of the corresponding software package approved in the rules, and a number of host servers missing the installed software package specified in the rules.
In another embodiment, the analysis module generates a report based on each host server. The report identifies a number of installed software packages having a version matching the version of the corresponding software packages approved in the rules for each host server, a number of installed software packages having a version ahead of the version of the corresponding software packages approved in the rules for each host server, a number of installed software packages having a version behind the version of the corresponding software packages approved in the rules for each host server, and a number of software packages missing from each host server.
In one embodiment, the rules are based on a name of the software package, a version of the software package, and the name of host servers where the software package is to be installed. The rules may also define an approved version of a first software package for a first set of host servers, and an approved version of the first software package for a second set of host servers.
In another embodiment, the rules comprises a first set of rules applicable to a first set of host servers identified based on host server names, and a second set of rules applicable to a second set of host servers identified based on host server names.
In another embodiment, the rules comprises a first set of rules applicable to a first set of host servers of a first server pool, and a second set of rules applicable to a second set of host servers of a second server pool.
The components of system 100 can be connected to each other in any suitable configuration, using any suitable type of connection. The components may be connected directly or over network 104, which may be any suitable network. For example, one or more portions of network 104 may be an ad hoc network, an intranet, an extranet, a virtual private network (VPN), a local area network (LAN), a wireless LAN (WLAN), a wide area network (WAN), a wireless WAN (WWAN), a metropolitan area network (MAN), a portion of the Internet, a portion of the Public Switched Telephone Network (PSTN), a cellular telephone network, another type of network, or a combination of two or more such networks.
Each host server may be identified with its host server name or IP address.
Each host server may include one or more installed software packages. For example, version 1.0 of software package A 112, version 2.0 of software package B 114, and version 1.3 of software package C 116 may be installed on host server 106. Version 1.0 of software package A 112 and version 1.1 of software package C 122 may be installed on host server 108. Version 1.2 of software package A 124, version 3.2 of software package D 126, and version 2.4 of software package E 128 may be installed on host server 110.
The server 102 may include an RPM verifier module that is used to determine the versions of installed software packages on each host server and compare it to a master configuration file to determine mis-configured installed or missing software packages on each host server. The RPM verifier module is discussed in more detail with respect to
The master configuration file 204 includes rules for checking the software packages in the host servers. For example, the rules may define the approved versions of a corresponding software package for a host server or host servers from a pool of servers.
For example, the rule may require the software package A installed on every host servers 106, 108, 110 to be version 1.0.
In another example, the rule may require the software package A installed on every host servers 106, 108, 110 to be at least version 1.0.
In another example, the rule may require the software package A installed on host servers 106 and 108 of server pool 130 to be version 1.0 and the software package A installed on host server 110 of server pool 132 to be at least version 1.0.
In another example, the rule may require the software package B installed on every host server 106 and 108 of server pool 130 to be version 2.0.
In another example, the rule may require the software package C installed on every host server 106 and 108 of server pool 130 to be at least version 1.1 and the software package D and E installed on host server 110 of server pool 132 to be versions 3.2 and 2.4 respectively.
In another example, the rule may require the software package A installed on every server regardless of its version.
In an alternative embodiment, business logic may be applied on the results to determine which software packages are missing, has a newer or older version installed compared to the approved version. The server 102 may easily manipulate the master configuration file 204 that controls the rules for the business logic. As previously illustrated, different rule sets may be applied on a per hostname basis or on a web pool basis.
The parsing module 304 parses information received from each host server in response to the query. The information may include a list of software packages saved or installed on a host server. In another embodiment, the information may include a name of the host server, the IP address of the host server, the corresponding server pool associated with the host server, the name of software packages installed on each host server, and the version of the software packages installed on each server.
The analysis module 306 compares the parsed information against the master configuration file. In one embodiment, the analysis module 306 applies the rules from the master configuration file 204 to the parsed information to identify one or more software packages missing from each host server. In another embodiment, the analysis module 306 identifies one or more software packages installed on each host server having a newer (ahead) or older (behind) version compared to the approved version of the corresponding software package for each host server as defined in the rules.
In one embodiment, the analysis module 306 generates a report based on software packages. For example, the report may identify the number of host servers having a version of installed software packages matching the version of the corresponding software packages approved in the rules, a number of host servers having the version of the installed software package ahead of the version of the corresponding software package approved in the rules, a number of host servers having the version of the installed software package behind the version of the corresponding software package approved in the rules, and a number of host servers missing the installed software package specified in the rules.
In another embodiment, the analysis module 206 generates a report based on each host server. For example, the report identifies a number of installed software packages having a version matching the version of the corresponding software packages approved in the rules for each host server, a number of installed software packages having a version ahead of the version of the corresponding software packages approved in the rules for each host server, a number of installed software packages having a version behind the version of the corresponding software packages approved in the rules for each host server, and a number of software packages missing from each host server.
For example, the analysis module 306 may identify the following summary results after running the process on each host server:
In another example, the analysis module 206 may group the results by software packages:
In another example, the analysis module 206 may group the results by specific hosts:
In one embodiment, the rules may be based on a name of the software package, a version of the software package, and the name of host servers where the software package is to be installed.
In another embodiment, the rules defines an approved version of a first software package for a first set of host servers, and an approved version of the first software package for a second set of host servers.
In another embodiment, the rules comprises a first set of rules applicable to a first set of host servers identified based on a first set of host server names or a first pool of servers, and a second set of rules applicable to a second set of host servers identified based on a second set of host server names or a second pool of servers.
At 404, the RPM verifier module queries each host server in the list for a version identifier of one or more software packages installed on each host server. The version identifier includes, for example, a version number of the corresponding software package (e.g. version 1.6).
At 406, the RPM verifier module receives a list of installed software packages on each queried host server. For example, the list may include the name and version of the installed software package on the corresponding queried host server.
At 408, the RPM verifier module parses and analyzes the list of installed software packages on each queried server to identify one or more mis-configured software packages on each host server based on the master configuration file.
In one embodiment, the RPM verifier module repeats the process (querying, receiving, parsing, and analyzing) for each destination server. In another embodiment, the RPM verifier module may process on all destination servers in parallel.
At 504, the RPM verifier module compares the data from the master configuration file with the information receives from each host server. In other words, the RPM verifier module compares the version number of the installed software package with the approved version number from the master configuration file.
At 506, the RPM verifier module identifies version differences organized or grouped by software packages or by host servers.
For example, a report is generated based on software packages. The report identifies:
In another example, the report is generated based on each host server. The report identifies:
Network cloud 660 generally represents one or more interconnected networks, over which the systems and hosts described herein can communicate. Network cloud 660 may include packet-based wide area networks (such as the Internet), private networks, wireless networks, satellite networks, cellular networks, paging networks, and the like. As
Social networking system 620a is a network-addressable computing system that can host one or more social graphs. Social networking system 620a can generate, store, receive, and transmit social networking data. Social networking system 620a can be accessed by the other components of network environment 600 either directly or via network cloud 660. Game networking system 620b is a network-addressable computing system that can host one or more online games. Game networking system 620b can generate, store, receive, and transmit game-related data, such as, for example, game account data, game input, game state data, and game displays.
Networking system 620 is a network addressable system that, in various example embodiments, comprises one or more physical servers 622 and data stores 624. The one or more physical servers 622 are operably connected to network cloud 660 via, by way of example, a set of routers and/or networking switches 626. In an example embodiment, the functionality hosted by the one or more physical servers 622 may include web or HTTP servers, FTP servers, as well as, without limitation, webpages and applications implemented using Common Gateway Interface (CGI) script, PHP Hyper-text Preprocessor (PHP), Active Server Pages (ASP), HTML, XML, Java, JavaScript, Asynchronous JavaScript and XML (AJAX), Flash, ActionScript, and the like.
Physical servers 622 may host functionality directed to the operations of networking system 620. Hereinafter, servers 622 may be referred to as server 622, although server 622 may include numerous servers hosting, for example, networking system 620, as well as other content distribution servers, data stores, and databases. Data store 624 may store content and data relating to, and enabling, operation of networking system 620 as digital data objects. A data object, in particular embodiments, is an item of digital information typically stored or embodied in a data file, database, or record. Content objects may take many forms, including: text (e.g., ASCII. SGML, HTML), images (e.g., jpeg, tif and gif), graphics (vector-based or bitmap), audio, video (e.g., mpeg), or other multimedia, and combinations thereof. Content object data may also include executable code objects (e.g., games executable within a browser window or frame), podcasts, and the like. Logically, data store 624 corresponds to one or more of a variety of separate and integrated databases, such as relational databases and object-oriented databases, that maintain information as an integrated collection of logically related records or files stored on one or more physical systems. Structurally, data store 624 may generally include one or more of a large class of data storage and management systems. In particular embodiments, data store 624 may be implemented by any suitable physical system(s) including components such as one or more database servers, mass storage media, media library systems, storage area networks, data storage clouds, and the like. In one example embodiment, data store 624 includes one or more servers, databases (e.g., MySQL), and/or data warehouses. Data store 624 may include data associated with different networking system 620 users and/or client systems 630.
Client system 630 is generally a computer or computing device including functionality for communicating (e.g., remotely) over a computer network. Client system 630 may be a desktop computer, laptop computer, personal digital assistant (PDA), in- or out-of-car navigation system, smart phone or other cellular or mobile phone, or mobile gaming device, among other suitable computing devices. Client system 630 may execute one or more client applications, such as a web browser (e.g., Microsoft Internet Explorer, Mozilla Firefox, Apple Safari, Google Chrome, and Opera), to access and view content over a computer network. In particular embodiments, the client applications allow a user of client system 630 to enter addresses of specific network resources to be retrieved, such as resources hosted by networking system 620. These addresses can be Uniform Resource Locators (URLs) and the like. In addition, once a page or other resource has been retrieved, the client applications may provide access to other pages or records when the user “clicks” on hyperlinks to other resources. By way of example, such hyperlinks may be located within the webpages and provide an automated way for the user to enter the URL of another page and to retrieve that page.
A webpage or resource embedded within a webpage, which may itself include multiple embedded resources, may include data records, such as plain textual information, or more complex digitally encoded multimedia content, such as software programs or other code objects, graphics, images, audio signals, videos, and so forth. One prevalent markup language for creating webpages is HTML. Other common web browser-supported languages and technologies include XML, the Extensible Hypertext Markup Language (XHTML), JavaScript, Flash, ActionScript, Cascading Style Sheet (CSS), and, frequently, Java. By way of example, HTML enables a page developer to create a structured document by denoting structural semantics for text and links, as well as images, web applications, and other objects that can be embedded within the page. Generally, a webpage may be delivered to a client as a static document; however, through the use of web elements embedded in the page, an interactive experience may be achieved with the page or a sequence of pages. During a user session at the client, the web browser interprets and displays the pages and associated resources received or retrieved from the website hosting the page, as well as, potentially, resources from other websites.
When a user at a client system 630 desires to view a particular webpage (hereinafter also referred to as target structured document) hosted by networking system 620, the user's web browser, or other document rendering engine or suitable client application, formulates and transmits a request to networking system 620. The request generally includes a URL or other document identifier as well as metadata or other information. By way of example, the request may include information identifying the user, such as a user ID, as well as information identifying or characterizing the web browser or operating system running on the user's client system 630. The request may also include location information identifying a geographic location of the user's client system 630 or a logical network location of the user's client system 630. The request may also include a timestamp identifying when the request was transmitted.
Although the example network environment 600 described above and illustrated in
The elements of hardware system 700 are described in greater detail below. In particular, network interface 716 provides communication between hardware system 700 and any of a wide range of networks, such as an Ethernet (e.g., IEEE 802.3) network, a backplane, and the like. Mass storage 718 provides permanent storage for the data and programming instructions to perform the above-described functions implemented in servers 622, whereas system memory 714 (e.g., DRAM) provides temporary storage for the data and programming instructions when executed by processor 702. I/O ports 720 are one or more serial and/or parallel communication ports that provide communication between additional peripheral devices, which may be coupled to hardware system 700.
Hardware system 700 may include a variety of system architectures, and various components of hardware system 700 may be rearranged. For example, cache 704 may be on-chip with processor 702. Alternatively, cache 704 and processor 702 may be packed together as a “processor module,” with processor 702 being referred to as the “processor core.” Furthermore, certain embodiments of the present disclosure may not require nor include all of the above components. For example, the peripheral devices shown coupled to standard I/O bus 708 may couple to high performance I/O bus 706. In addition, in some embodiments, only a single bus may exist, with the components of hardware system 700 being coupled to the single bus. Furthermore, hardware system 700 may include additional components, such as additional processors, storage devices, or memories.
An operating system manages and controls the operation of hardware system 700, including the input and output of data to and from software applications (not shown). The operating system provides an interface between the software applications being executed on the hardware system 700 and the hardware components of the hardware system 700. Any suitable operating system may be used, such as the LINUX Operating System, the Apple Macintosh Operating System, available from Apple Computer Inc. of Cupertino, Calif., UNIX operating systems, Microsoft® Windows® operating systems, BSD operating systems, and the like. Of course, other embodiments are possible. For example, the functions described herein may be implemented in firmware or on an application-specific integrated circuit.
Furthermore, the above-described elements and operations can be comprised of instructions that are stored on non-transitory storage media. The instructions can be retrieved and executed by a processing system. Some examples of instructions are software, program code, and firmware. Some examples of non-transitory storage media are memory devices, tape, disks, integrated circuits, and servers. The instructions are operational when executed by the processing system to direct the processing system to operate in accord with the disclosure. The term “processing system” refers to a single processing device or a group of inter-operational processing devices. Some examples of processing devices are integrated circuits and logic circuitry. Those skilled in the art are familiar with instructions, computers, and storage media.
Certain embodiments described herein may be implemented as logic or a number of modules, engines, components, or mechanisms. A module, engine, logic, component, or mechanism (collectively referred to as a “module”) may be a tangible unit capable of performing certain operations and configured or arranged in a certain manner. In certain example embodiments, one or more computer systems (e.g., a standalone, client, or server computer system) or one or more components of a computer system (e.g., a processor or a group of processors) may be configured by software (e.g., an application or application portion) or firmware (note that software and firmware can generally be used interchangeably herein as is known by a skilled artisan) as a module that operates to perform certain operations described herein.
In various embodiments, a module may be implemented mechanically or electronically. For example, a module may comprise dedicated circuitry or logic that is permanently configured (e.g., within a special-purpose processor, application specific integrated circuit (ASIC), or array) to perform certain operations. A module may also comprise programmable logic or circuitry (e.g., as encompassed within a general-purpose processor or other programmable processor) that is temporarily configured by software or firmware to perform certain operations. It will be appreciated that a decision to implement a module mechanically, in dedicated and permanently configured circuitry, or in temporarily configured circuitry (e.g., configured by software) may be driven by, for example, cost, time, energy-usage, and package size considerations.
Accordingly, the term “module” should be understood to encompass a tangible entity, be that an entity that is physically constructed, permanently configured (e.g., hardwired), or temporarily configured (e.g., programmed) to operate in a certain manner or to perform certain operations described herein. Considering embodiments in which modules or components are temporarily configured (e.g., programmed), each of the modules or components need not be configured or instantiated at any one instance in time. For example, where the modules or components comprise a general-purpose processor configured using software, the general-purpose processor may be configured as respective different modules at different times. Software may accordingly configure the processor to constitute a particular module at one instance of time and to constitute a different module at a different instance of time.
Modules can provide information to, and receive information from, other modules. Accordingly, the described modules may be regarded as being communicatively coupled. Where multiples of such modules exist contemporaneously, communications may be achieved through signal transmission (e.g., over appropriate circuits and buses) that connect the modules. In embodiments in which multiple modules are configured or instantiated at different times, communications between such modules may be achieved, for example, through the storage and retrieval of information in memory structures to which the multiple modules have access. For example, one module may perform an operation and store the output of that operation in a memory device to which it is communicatively coupled. A further module may then, at a later time, access the memory device to retrieve and process the stored output. Modules may also initiate communications with input or output devices and can operate on a resource (e.g., a collection of information).
One or more features from any embodiment may be combined with one or more features of any other embodiment without departing from the scope of the disclosure.
A recitation of“a,” “an.” or “the” is intended to mean “one or more” unless specifically indicated to the contrary. In addition, it is to be understood that functional operations, such as “awarding,” “locating,” “permitting” and the like, are executed by game application logic that accesses, and/or causes changes to, various data attribute values maintained in a database or other memory.
The present disclosure encompasses all changes, substitutions, variations, alterations, and modifications to the example embodiments herein that a person having ordinary skill in the art would comprehend. Similarly, where appropriate, the appended claims encompass all changes, substitutions, variations, alterations, and modifications to the example embodiments herein that a person having ordinary skill in the art would comprehend.
For example, the methods, game features and game mechanics described herein may be implemented using hardware components, software components, and/or any combination thereof. By way of example, while embodiments of the present disclosure have been described as operating in connection with a networking website, various embodiments of the present disclosure can be used in connection with any communications facility that supports web applications. Furthermore, in some embodiments the term “web service” and “website” may be used interchangeably and additionally may refer to a custom or generalized API on a device, such as a mobile device (e.g., cellular phone, smart phone, personal GPS, PDA, personal gaming device, etc.), that makes API calls directly to a server. Still further, while the embodiments described above operate with business-related virtual objects (such as stores and restaurants), the disclosure can be applied to any in-game asset around which a harvest mechanic is implemented, such as a virtual stove, a plot of land, and the like. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. It will, however, be evident that various modifications and changes may be made thereunto without departing from the broader spirit and scope of the disclosure as set forth in the claims and that the disclosure is intended to cover all modifications and equivalents within the scope of the following claims.
The Abstract of the Disclosure is provided to comply with 37 C.F.R. §1.72(b), requiring an abstract that will allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separate embodiment.
Number | Name | Date | Kind |
---|---|---|---|
7203745 | Sheehy | Apr 2007 | B2 |
7536687 | Myers | May 2009 | B1 |
7636780 | Lavin | Dec 2009 | B2 |
7953744 | Gharat | May 2011 | B2 |
8185889 | Kinder | May 2012 | B2 |
8250570 | Suorsa | Aug 2012 | B2 |
8612398 | Jarrett | Dec 2013 | B2 |
8762931 | Vidal | Jun 2014 | B2 |
20040181790 | Herrick | Sep 2004 | A1 |
20050198099 | Motsinger | Sep 2005 | A1 |
20060075001 | Canning | Apr 2006 | A1 |
20060161895 | Speeter | Jul 2006 | A1 |
20060184932 | Burnley | Aug 2006 | A1 |
20070140131 | Malloy | Jun 2007 | A1 |
20070271552 | Pulley | Nov 2007 | A1 |
20090007096 | Chavez | Jan 2009 | A1 |
20100058320 | Milligan | Mar 2010 | A1 |
20110107299 | Dehaan | May 2011 | A1 |
20120117234 | Miryanov | May 2012 | A1 |
20130268915 | Gu | Oct 2013 | A1 |
Entry |
---|
Maximum RPM: Taking the Red Hat Package Manager to the Limit, Chapter 6. Using RPM to Verify Installed Packages. Nov. 2011. Located at: http://www.rpm.org/max-rpm/s1-rpm-verify-what-to-verify.html. |
Puppet—“Puppet CookBook”—located at http://www.puppetcookbook.com/ Captured on Dec. 2, 2011. |
Maximum RPM-2011, Chapter 6. Using RPM to Verify Installed packages, captured in 2011 located at http://www.rpm.org/max-rpm/s1-rpm-verify-what-to-verify.html. |