Systems associated with sites in a networked environment, such as electronic commerce systems, content delivery networks, search engines, or any other type of site, can generate large amounts of log data associated with requests for content from users via client devices. Log data can also be generated by other types of systems that might not be related to content requests, such as, but not limited to, inventory management systems, order processing systems, logistics systems, supply chain management systems, storage networks, or any other type of computing system or environment.
Many aspects of the present disclosure can be better understood with reference to the following drawings. The components in the drawings are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the disclosure. Moreover, in the drawings, like reference numerals designate corresponding parts throughout the several views.
Embodiments of the present disclosure are related to managing log data that can be generated by various systems in a networked environment. Systems associated with sites in a networked environment, such as electronic commerce systems, content delivery networks, search engines, or any other type of site, can generate large amounts of log data associated with requests for content from users via client devices. Large amounts of log data can also be generated by other types of systems that might not be related to content requests, such as, but not limited to, inventory management systems, order processing systems, logistics systems, supply chain management systems, storage networks, or any other type of computing system or environment. Accordingly, a logging service can be employed to warehouse log data generated by various types of systems that can be known as log producer systems or log producers.
Such a logging system can include a logging service executed on one or more computing devices that receives log data from a log, processes log data or transforms log data into a storage format specified by the logging service and subsequently stores the log data from the log producer in a data store or other storage system. Accordingly, as other systems, applications and services can retrieve warehoused log data from the logging service for various uses as will be described herein. If a log producer modifies or alters the format or contents of log data generated and warehoused by the logging services, this log data may become unusable or cause errors in the applications employed by log consumers that rely on the log data. In the following discussion, a general description of one embodiment of the disclosure and its components is provided, followed by a discussion of the operation of the same.
With reference to
The logging system 103 may comprise, for example, a computing device, a server computer or any other system providing computing capability. Alternatively, a plurality of logging systems 103 may be employed that are arranged, for example, in one or more server banks or computer banks or other arrangements. For example, a plurality of logging system 103 together may comprise a cloud computing resource, a grid computing resource, and/or any other distributed computing arrangement. Such logging systems 103 may be located in a single installation or may be distributed among many different geographical locations. For purposes of convenience, the logging system 103 is referred to herein in the singular. Even though the logging system 103 is referred to in the singular, it is understood that a plurality of logging systems 103 may be employed in the various arrangements as described above. Additionally, the log producer system 104 and the log consumer system 105 can also represent one or more computing devices and/or resources that are similar in nature to the logging system 103. Additionally, a log producer system 104 and a log consumer system 105 can also represent a single computing device. However, they are depicted separately herein for ease of depiction and discussion of the various embodiments of the disclosure.
Various applications and/or other functionality may be executed in the logging system 103 according to various embodiments. Also, various data is stored in a data store 116 that is accessible to the logging system 103. The data store 116 may be representative of a plurality of data stores as can be appreciated. The data stored in the data store 116, for example, is associated with the operation of the various applications and/or functional entities described below. In one embodiment, the data store 116 can be implemented in one computing device 103, and the other elements depicted can be implemented in other computing devices 103 as can be appreciated.
The components executed on the logging system 103, for example, include the logging service 121, and other applications, services, processes, systems, engines, or functionality not discussed in detail herein. The logging service 121 is executed to facilitate receiving and storage of log data from log producer systems 104. The logging service 121 also facilitates providing requested log data warehoused via the logging service 121 to log consumer systems 105. The logging service 121 also facilitates validation of proposed formats for event logs that represent changes to a previous log format as will be described herein.
The data stored in the data store 116 includes, for example, event logs 141, which can be indexed or sorted by a producer identifier 143. Event logs 141 can also include log data 145, which can represent logs generated by a log producer system 104 and transmitted to the logging service 121 for storage in the data store 116. The log data 145 can be provided in various formats, such as, but not limited to an extensible markup language (XML) based log format, a flat text based log format, or any other log format that is used in the art. The data store 116 can also include consumer validation rules 147 as well as example logs 149 corresponding to each log producer systems 104 and/or application or service that provides logs that represent an example of a log format employed by a log producer system 104 to house log data 145 in the data store 116 via logging service 121. An example log 149 can allow the format of a particular log provided by log producer systems 104 to be determined. In some embodiments, instead of or in addition to an example log 149 employed from which a log format can be ascertained, the data store 116 can include a log format specification that can define a log format for log data 145 transmitted to the logging service 121 by a log producer system 104. As contemplated herein, the data store 116 may be representative of many different data stores, a networked storage system, or any system in which log data can be housed. The data store 116 may comprise, for example, a cloud computing platform in which data is stored across various servers in redundant fashion.
The log producer system 104 represents any computing device or system in which event occur and in which logs are generated and transmitted to the logging service 121 for warehousing in the data store 116. In one embodiment, the log producer system 104 can represent a content delivery system that provides access to content that is served over the network. To this end, the content delivery system acts as a gateway through which requests are received and responses transmitted to clients. It is understood that other applications and components, such as an application implementing the hypertext transport protocol, may be executed on the log producer system 104 beyond those described herein. Accordingly, the log producer system 104 can execute logic that generates log data corresponding to an occurrence in the system. For example, each time a user on a client device initiates a request for content from the content delivery system, it may generate a log entry corresponding to a session of the user. Accordingly, various information about the content served to the client corresponding to the user in the session can be logged. For example, the identity of content shown to the user can be logged, which can include, but is not limited to the content pages requested by the user, advertisements shown to the user in the content pages served, data submitted by the user to the content delivery system (e.g., search terms, user identity information, or any other input data), the links followed by the user, and other data as can be appreciated.
The log producer system 104 may, in some embodiments, provide one or more applications that are involved, for example, in providing services offered by an online merchant or electronic commerce system. For example, the log producer system 104 may execute applications that facilitate the ordering of goods online by customers by manipulating a user interface on a client 106. Accordingly, in such an electronic commerce system, various events can occur which can be logged by the log producer system 104, which can include, but is not limited to, an identify of products displayed to the user, pricing information of products displayed to the user, shipping terms associated with products, whether the user submitted an order via the electronic commerce system, hyperlinks followed by the user, advertisements displayed to the user, or any other data related to an electronic commerce system that can be logged as can be appreciated. In the above examples, the log producer system 104 can also be any system that generates clickstream data corresponding to one or more users or clients, where the clickstream data is archived in the data store 116 via the logging service 121. The log producer system 104 can also generate user experience data that can be related performance of content delivery to a client device associated with a user, latency, or other performance data. In one example, the log producer system 104 can generate a content page rendered on a client device that includes client side code that reports user experience data to the log producer system 104. The log producer system 104 can in turn archive various user experience data via the logging service 121. As another specific example, a content page can include JavaScript code that reports browser performance data related to the rendering of pages in a client device to the log producer system 104, which can in turn generate logs 161 that are archived by the logging service 121 and made available to log consumer systems 105.
Accordingly, no matter the specific application implemented, the log producer system 104 is configured to generate logs 161 that are transmitted to the logging service 121 for archival in the data store 116 and/or retrieval via the logging service 121. The logging service 121 can then archive logs 161 received from a log producer system 104 as log data 145 associated with a producer identifier 143.
The log consumer system 105 can be any system that requests or retrieves log data 145 via the logging service 121 for any use. In one embodiment, a log consumer system 105 can execute one or more applications or services that receive log data 145 to execute a business rule. For example, a log consumer system 105 can include a pricing application that extracts log data 145 corresponding to one or more log producer systems 104 that are associated with an electronic commerce system. In this example, the pricing application can extract, from the log data 145, page views associated product detail pages, order history data, and other data in order to set pricing in real time for a particular product.
As is described herein, a log consumer system 105 can be associated with one or more consumer validation rules 147 housed in the data store 116. The consumer validation rules 147 can include one or more rules that can be validated against example logs 149 associated with a log consumer system 105. In other words, the validation rules 147 are associated with a log producer system 104 as well as a log consumer system 105 and describe constraints associated with a proposed log format that represents a change from a previous log format. In one embodiment, the validation rules 147 can identify fields in a proposed log format that should be present in order for an application or service executed by a log consumer system 105 to continue to be operable. A consumer validation rule 147 can also identify particular value constraints on various fields in an example log 149 associated with a log producer system 104. A consumer validation rule 147 can also specify a certain structure of a document representing log 161 associated with a log producer system 104. As another example, the consumer validation rule 147 can specify that certain data appear in certain locations within a log 161 associated with a log producer system 104.
A consumer validation rule 147 can also include one or more default validation rules that can be associated with the logging service 121, which can specify various requirements that are associated with the storage of any log data 145 in the data store 116. In this sense, the logging service 121 can also be thought of as a log consumer for which validation rules 147 can be specified as well as validated when an example log 149 corresponding to a change in a log format is provided that is associated with a log consumer system 104. For example, such a consumer validation rule 147 associated with the logging service 121 as a log consumer can specify basic validation data that can be required of any logs 161 provided by a log producer system 104 for archival in the data store 116. As one specific example, such a consumer validation rule 147 can specify that any log 161 provided by a log producer system 104 include a producer identifier 143 in a particular location and/or with a specific value range in a log 161. As another example, the consumer validation rule 147 can also specify that the log 161 include various other meta data with which the logging service 121 can categorize, sort, and/or index the log 161 in the data store 116. As some other examples, the validation rules 147 associated with a logging service 121 in this way can include rules that require the presence, a certain value range, or any other constraint associated with a merchant identifier, user identifier, or any other data within an example log 149 submitted to the logging service 121 for validation. Additional detail regarding validation of example logs 149 by the logging service 121 is provided below.
The client device 106 is representative of one or more client devices 106 that may be coupled to the network. The client device 106 may comprise, for example, a processor-based system, such as a computer system. Such a computer system may be embodied in the form of a desktop computer, a laptop computer, a personal digital assistant, a mobile device (e.g., cellular telephone, smart phone, etc.), tablet computing system, set-top box, music players, or other devices with like capability. The client device 106 can also include a display device upon which various content pages and other user interfaces may be rendered. The client device can also include one or more input devices with which a user can interact with a user interface rendered on the display device. For example, the client device 106 can include or be in communication with a mouse, touch input device (e.g., capacitive and/or resistive touchscreen), keyboard, or other input devices.
The client device 106 may be configured to execute various applications, such as a browser application and/or other applications. The browser application may be executed in a client device 106, for example, to access and render content pages, such as web pages, or other network content served up by the logging system 103 and/or other servers. The client device 106 may be configured to execute a special purpose application with which a user can interact with a user interface generated by a content delivery system or other type of system. In some embodiments, the example logs 149 and/or consumer validation rules 147 can be provided to the logging service 121 associated with a log producer system 104 or log consumer system 105 via a client 106 device.
Next, additional discussion of various embodiments of the disclosure is provided in connection with
Applications and/or services generating log data 145 that is related to an event or occurrence within a log producer system 104 may undergo changes that cause the formatting and/or data provided within a log 161 to change over time. For example, a developer may check in code associated with a log producer system 104 that causes the formatting of logs 161 generated by the system to change. Accordingly, such a change may cause parsing of log data 145 received by a log consumer system 105 from the logging service 121 to fail, thereby potentially causing an application or service relying on the log data 145 to malfunction in some way. Accordingly, the consumer validation rules 147 associated with the log data 145 relied upon by the log consumer system 105 can be validated by the logging service 121 so that it can be determined before the logging service 121 provides log data 145 to a log consumer system 105 whether the validation rules 147 associated with the log consumer system 105 pass.
The consumer validation rules 201 can be provided to the logging service 121 and stored in the data store 116 in various ways and in various formats. In one embodiment, the validation rules 201 can be provided using an expression language that identifies certain variables in the log data 145 by name or identifier as well as an expected value and/or range of the variable. Additionally, a validation rule can identify a variable as well as an expected location of the variable in the log data 145 provided by the logging service.
Reference is now made to
The logging service 121 can then determine whether any of the validation rules 147 against which the example log 149 is validated fail. If any of the validation rules 147 fail, then in one embodiment, the logging service 121 can generate an alert and/or report that is transmitted to the log producer system 104, log consumer system 105, or any client 106 or user associated with either so that appropriate action can be taken to address or prevent such a failure before the log producer system 104 generates logs 161 that follow a format specified by the example log 149. In some embodiments, the logging service 121 can receive one or more new or updated consumer validation rules 147 associated with a particular producer identifier 143 and then initiate validation of the new or updated validation rules 147 against a log format specified by one or more example logs 149 referenced by the consumer validation rules 147 and/or example logs 149 associated with a producer identifier 143 referenced by the validation rules 147.
Reference is now made to
For example, the logging service 121 can respond to an HTTP POST operation with a URI that includes a hostname and/or internet protocol (IP) address with a unique identifier concatenated thereto. Accordingly, a user can perform an HTTP GET operation via a browser or other application. In response to such a GET operation, the logging service can reply with a status report regarding the progress of the validation of the validation rules 147, passage or failure of the validation rules 147, and other status information. In the depicted example, a status request 421 can represent such a GET operation directed to a uniform resource identifier provided by the logging service upon receiving an example log 149. In response to such a GET operation, the logging service 121 can respond with a validation status 423. In some embodiments, the status request 421 can include a producer identifier 435 corresponding to an example log 149 as well as any other identifier that is assigned to the example log 149.
As an example log 149 may be associated with one or more validation rules 147 that are potentially associated with more than one log consumer system 105, the validation status 423 can include a status report that identifies the log consumer system 105 and corresponding validation rule 147 for which an example log 149 has caused a failure. Additionally, in some embodiments, the logging service 121 can, upon completion of validation rules 147, generate a report identifying the various validation rules 147 and corresponding log consumer systems 105 that either pass or fail validation of the example log 149. Such a status report can be transmitted to operators of a log producer system 104 and/or log consumer system 105. Accordingly, operators of a log producer system 104 and/or log consumer system 105 can address potential failures of validation rules 147, whether this involves modifying a format of log data 145 and/or modifying an application and/or service executed in a log consumer system 105.
Referring next to
Beginning with box 501, the logging service 121 can receive a proposed log format that can include an example log 149 (
In box 505, the logging service 121 can retrieve one or more validation rules associated with the proposed log format. The validation rules can be associated with a particular log producer system 104 and/or an application or service executed within one or more log producer systems 104. In box 507, the logging service 121 can initiate validation of the proposed log format against the validation rules. In box 509, the logging service can generate a status report that identifies passed and/or failed validation rules associated with the validation step of box 507.
With reference to
Stored in the memory 606 are both data and several components that are executable by the processor 603. In particular, stored in the memory 606 and executable by the processor 603 are the logging service 121 and potentially other applications. Also stored in the memory 606 may be a data store 116 and other data. In addition, an operating system may be stored in the memory 606 and executable by the processor 603.
It is understood that there may be other applications that are stored in the memory 606 and are executable by the processor 603 as can be appreciated. Where any component discussed herein is implemented in the form of software, any one of a number of programming languages may be employed such as, for example, C, C++, C #, Objective C, Java®, JavaScript®, Perl, PHP, Visual Basic®, Python®, Ruby, Delphi®, Flash®, or other programming languages.
A number of software components are stored in the memory 606 and are executable by the processor 603. In this respect, the term “executable” means a program file that is in a form that can ultimately be run by the processor 603. Examples of executable programs may be, for example, a compiled program that can be translated into machine code in a format that can be loaded into a random access portion of the memory 606 and run by the processor 603, source code that may be expressed in proper format such as object code that is capable of being loaded into a random access portion of the memory 606 and executed by the processor 603, or source code that may be interpreted by another executable program to generate instructions in a random access portion of the memory 606 to be executed by the processor 603, etc. An executable program may be stored in any portion or component of the memory 606 including, for example, random access memory (RAM), read-only memory (ROM), hard drive, solid-state drive, USB flash drive, memory card, optical disc such as compact disc (CD) or digital versatile disc (DVD), floppy disk, magnetic tape, or other memory components.
The memory 606 is defined herein as including both volatile and nonvolatile memory and data storage components. Volatile components are those that do not retain data values upon loss of power. Nonvolatile components are those that retain data upon a loss of power. Thus, the memory 606 may comprise, for example, random access memory (RAM), read-only memory (ROM), hard disk drives, solid-state drives, USB flash drives, memory cards accessed via a memory card reader, floppy disks accessed via an associated floppy disk drive, optical discs accessed via an optical disc drive, magnetic tapes accessed via an appropriate tape drive, and/or other memory components, or a combination of any two or more of these memory components. In addition, the RAM may comprise, for example, static random access memory (SRAM), dynamic random access memory (DRAM), or magnetic random access memory (MRAM) and other such devices. The ROM may comprise, for example, a programmable read-only memory (PROM), an erasable programmable read-only memory (EPROM), an electrically erasable programmable read-only memory (EEPROM), or other like memory device.
Also, the processor 603 may represent multiple processors 603 and the memory 606 may represent multiple memories 606 that operate in parallel processing circuits, respectively. In such a case, the local interface 609 may be an appropriate network (
Although the logging service 121 and other various systems described herein may be embodied in software or code executed by general purpose hardware as discussed above, as an alternative the same may also be embodied in dedicated hardware or a combination of software/general purpose hardware and dedicated hardware. If embodied in dedicated hardware, each can be implemented as a circuit or state machine that employs any one of or a combination of a number of technologies. These technologies may include, but are not limited to, discrete logic circuits having logic gates for implementing various logic functions upon an application of one or more data signals, application specific integrated circuits having appropriate logic gates, or other components, etc. Such technologies are generally well known by those skilled in the art and, consequently, are not described in detail herein.
The flowchart of
Although the flowchart of
Also, any logic or application described herein, including the logging service 121, that comprises software or code can be embodied in any non-transitory computer-readable medium for use by or in connection with an instruction execution system such as, for example, a processor 603 in a computer system or other system. In this sense, the logic may comprise, for example, statements including instructions and declarations that can be fetched from the computer-readable medium and executed by the instruction execution system. In the context of the present disclosure, a “computer-readable medium” can be any medium that can contain, store, or maintain the logic or application described herein for use by or in connection with the instruction execution system. The computer-readable medium can comprise any one of many physical media such as, for example, magnetic, optical, or semiconductor media. More specific examples of a suitable computer-readable medium would include, but are not limited to, magnetic tapes, magnetic floppy diskettes, magnetic hard drives, memory cards, solid-state drives, USB flash drives, or optical discs. Also, the computer-readable medium may be a random access memory (RAM) including, for example, static random access memory (SRAM) and dynamic random access memory (DRAM), or magnetic random access memory (MRAM). In addition, the computer-readable medium may be a read-only memory (ROM), a programmable read-only memory (PROM), an erasable programmable read-only memory (EPROM), an electrically erasable programmable read-only memory (EEPROM), or other type of memory device.
It should be emphasized that the above-described embodiments of the present disclosure are merely possible examples of implementations set forth for a clear understanding of the principles of the disclosure. Many variations and modifications may be made to the above-described embodiment(s) without departing substantially from the spirit and principles of the disclosure. All such modifications and variations are intended to be included herein within the scope of this disclosure and protected by the following claims.
This application is a continuation of U.S. patent Ser. No. 13/169,391, filed Jun. 27, 2011, now U.S. Pat. No. 8,930,330, which is hereby incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5280612 | Lorie et al. | Jan 1994 | A |
5471614 | Kakimoto | Nov 1995 | A |
5524205 | Lomet et al. | Jun 1996 | A |
5530850 | Ford et al. | Jun 1996 | A |
5870758 | Bamford et al. | Feb 1999 | A |
5907848 | Zaiken et al. | May 1999 | A |
6233585 | Gupta et al. | May 2001 | B1 |
6240413 | Learmont | May 2001 | B1 |
6615219 | Bruso et al. | Sep 2003 | B1 |
6631374 | Klein et al. | Oct 2003 | B1 |
6728879 | Atkinson | Apr 2004 | B1 |
6732171 | Hayden | May 2004 | B2 |
6832229 | Reed | Dec 2004 | B2 |
6976022 | Vemuri et al. | Dec 2005 | B2 |
7010645 | Hetzler et al. | Mar 2006 | B2 |
7089253 | Hinshaw et al. | Aug 2006 | B2 |
7146386 | Xiao | Dec 2006 | B2 |
7305386 | Hinshaw et al. | Dec 2007 | B2 |
7308456 | Friske et al. | Dec 2007 | B2 |
7415489 | Palapudi et al. | Aug 2008 | B2 |
7472138 | Adkins et al. | Dec 2008 | B2 |
7610329 | Bone et al. | Oct 2009 | B2 |
7716645 | Dolby et al. | May 2010 | B2 |
7747663 | Atkin et al. | Jun 2010 | B2 |
7769723 | Zheng et al. | Aug 2010 | B2 |
7809778 | Mitaru | Oct 2010 | B2 |
7885922 | Pareek et al. | Feb 2011 | B2 |
7930271 | Tarbell | Apr 2011 | B2 |
7937551 | Schott | May 2011 | B2 |
7979670 | Saliba et al. | Jul 2011 | B2 |
8131723 | Sim-Tang | Mar 2012 | B2 |
8209515 | Schott | Jun 2012 | B2 |
8255627 | Blinick et al. | Aug 2012 | B2 |
8266114 | Mace et al. | Sep 2012 | B2 |
8271830 | Erofeev | Sep 2012 | B2 |
8289801 | Smith et al. | Oct 2012 | B2 |
8301670 | Revah et al. | Oct 2012 | B2 |
8326897 | Butterworth et al. | Dec 2012 | B2 |
8341128 | Ruggiero | Dec 2012 | B1 |
8370715 | Hafner et al. | Feb 2013 | B2 |
8380670 | Kuber et al. | Feb 2013 | B2 |
8392479 | Pantin | Mar 2013 | B1 |
8396831 | Larson et al. | Mar 2013 | B2 |
8397032 | Elnozahy | Mar 2013 | B2 |
8412689 | Reid et al. | Apr 2013 | B2 |
8412752 | Dodge | Apr 2013 | B2 |
8429121 | Pareek et al. | Apr 2013 | B2 |
8930330 | Arguelles | Jan 2015 | B1 |
20020107835 | Coram et al. | Aug 2002 | A1 |
20020143733 | Mukkamalla et al. | Oct 2002 | A1 |
20020184527 | Chun | Dec 2002 | A1 |
20030046121 | Menninger et al. | Mar 2003 | A1 |
20040133622 | Clubb et al. | Jul 2004 | A1 |
20040189708 | Larcheveque | Sep 2004 | A1 |
20040249869 | Oksanen | Dec 2004 | A1 |
20050262161 | Holmes et al. | Nov 2005 | A1 |
20080168081 | Gaurav et al. | Jul 2008 | A1 |
20080183973 | Aguilera et al. | Jul 2008 | A1 |
20080208924 | Bradshaw et al. | Aug 2008 | A1 |
20090024551 | Agrawal et al. | Jan 2009 | A1 |
20090193393 | Baldwin et al. | Jul 2009 | A1 |
20100050172 | Ferris | Feb 2010 | A1 |
20100192131 | Dolby et al. | Jul 2010 | A1 |
20110035548 | Kimmel et al. | Feb 2011 | A1 |
20110066602 | Studer | Mar 2011 | A1 |
20110161496 | Nicklin | Jun 2011 | A1 |
20110295865 | Carroll | Dec 2011 | A1 |
20120041899 | Greene et al. | Feb 2012 | A1 |
20120054447 | Swart et al. | Mar 2012 | A1 |
20120096525 | Bolgert | Apr 2012 | A1 |
20120143825 | Boehm et al. | Jun 2012 | A1 |
20120174112 | Vaidya et al. | Jul 2012 | A1 |
20120191648 | Kuber et al. | Jul 2012 | A1 |
20120297073 | Glover et al. | Nov 2012 | A1 |
20120310904 | Hans | Dec 2012 | A1 |
20120310985 | Gale et al. | Dec 2012 | A1 |
20120310986 | Frantz et al. | Dec 2012 | A1 |
20120310991 | Frantz et al. | Dec 2012 | A1 |
20120317382 | Steed | Dec 2012 | A1 |
20130036281 | Revah et al. | Feb 2013 | A1 |
20130042156 | Srinivasan et al. | Feb 2013 | A1 |
20130066826 | McDonald | Mar 2013 | A1 |
20130080386 | Dwyer et al. | Mar 2013 | A1 |
20130080388 | Dwyer et al. | Mar 2013 | A1 |
20130086129 | Brown et al. | Apr 2013 | A1 |
Number | Date | Country |
---|---|---|
0675451 | Oct 1995 | EP |
1277115 | Jan 2003 | EP |
Entry |
---|
U.S. Appl. No. 14/070,359, filed Nov. 1, 2013, Samuel James Mckel Vie. |
U.S. Appl. No. 14/070,362, filed Nov. 1, Samuel James Mckelvie. |
U.S. Appl. No. 14/070,355, filed Nov. 1, Samuel James Mckelvie. |
U.S. Appl. No. 14/070,350, filed Nov. 1, Samuel James Mckelvie. |
U.S. Appl. No. 14/070,347, filed Nov. 1, Samuel James Mckelvie. |
Adrian Proctor “Non-Volatile Memory: Non Volatile Memory and its use in Enterprise Applications” 2012 whitepaper downloaded from http://www.vikingtechnology.com/sites/default/files/featuredvideos/NVDIMM_Technology.pdf, pp. 1-8. |
U.S. Appl. No. 13/872,530, filed Apr. 29, 2013; Samuel James Mckelvie. |
Yuan Xie “Emerging NVM Memory Technologies”, Penn State Department of Computer Science and Engineering, Downloaded from http://web.engr.oregonstate.edu/˜sllu/xie.pdf on Aug. 13, 2013, pp. 1-31. |
“NV-DIMM: Fastest Tier in Your Storage Strategy”, 2012 Whitepaper, Viking Technology, pp. 1-7. |
U.S. Appl. No. 13/967,185, filed Aug. 14, 2013, Anurag Windlass Gupta. |
IBM, “Storage Class Memory : Towards a Disruptively Low-Cost Solid-State Non-Volatile Memory”, Almaden Research Center; Jan. 2013, pp. 1-27. |
GitHub-Gist, “Latency Numbers Every Programmer Should Know”, pp. 1-6. |
Technology Lab/ Information Technology, Sean Gallagher, “Memory That Never Forgets: Non-Volatile DIMMS Hit the Market”, Apr. 4, 2013; pp. 1-3. |
U.S. Appl. No. 14/036,775, filed Sep. 25, 2013, Yan Valerie Leshinsky. |
“Amazon Web Services Blog” Downloaded Apr. 30, 2013 from http://aws.typepad .com/aws/201 0/1 0/amazon-rdsannouncing-read-replicas.html, Published Oct. 5, 2010, pp. 1-11. |
“Bloom Filter” Downloaded from http://en.wikipedia.org/wiki/Bioom_filteron May 15, 2013, pp. 1-12. |
John Clarke “SQL Result Set Cache in Oracle 11 gR2” published Nov. 16, 2011 downloaded May 15, 2013 from http://www.centroid.com/knowledgebase/blog/sql-result-set-cache-in-oracle-11 gr2, pp. 1-27. |
Jim Czuprynski “Oracle Database 11 g: SQL Query Result Set Caching” published Jul. 30, 2008, downloaded May 15, 2013 from http://www.databasejournal.com/features/oracle/article.php/3760761 /Oracle-Database-11 g-SQL -Query-Result-Set-Caching.htm, pp. 1-7. |
“Oracle Database JDBC Developers Guide and Reference: Chapter 20 Statement and Result Set Caching” downloaded from http://docs.oracle.com/cd/B28359 01 /java .1111 b31224/stmtcach.htm via the Wayback Machine Nov. 27, 2011, pp. 1-8. |
Adrian Billington “Query Result Cache in Oracle 11 g” downloaded from http:/lweb.archive.org/web/20080124161135/http://www.oracle-developer.net/display.php?id=503 via the Wayback Machine Jan. 4, 2008, pp. 1-20. |
Julian Dontcheff “Bloom Filters for DBAs” published Aug. 28, 2012, downloaded from http://juliandontcheff. word press. com/20 12/08/28/bloom-filters-for- db as/ on May 14, 2013, pp. 1-4. |
Julian Dyke “Result Cache Internals” Nov. 2007, pp. 1-38. |
Michele Cyran et al “Oracle Database Concepts 1 Og Release 2 (1 0.2)” Oct. 2005, pp. 1-542. |
Lance Ashdown et al “Oracle Database Concepts 11 g Release 2 (11 .2)” Sep. 2011, pp. 1-460. |
“Isolation (database systems)” downloaded from http://en.wikipedia.org/wiki/Isolation_(database_systems) on May 15, 2013, pp. 1-7. |
U.S. Appl. No. 14/303,549, filed Jun. 12, 2014, James Edward Kinney. |
Number | Date | Country | |
---|---|---|---|
20150120677 A1 | Apr 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13169391 | Jun 2011 | US |
Child | 14589894 | US |