The present teachings relate to systems and methods for configuring a probe server network using a reliability model, and more particularly, to platforms and techniques used to design and configure a network of probe servers to monitor a set of underlying name servers, based on an overall network reliability model.
In the field of network services, arrangements are known in which a company or other organization outsources the operation or maintenance of a domain name resolution platform. In those types of networks, the operator may engage a third-party provider which maintains or employs a set of domain name resolution servers (or name servers, for short) which operate to resolve requests to navigate to a domain name space. The name servers may be dedicated to supporting the domain name operations of that specific company or other organization, rather than a variety of domains at large. This arrangement can be referred to as managed domain name systems or services, or mDNS. The domain name service can in general receive a subject domain name, such as a domain name of the form “companyname.com,” and translate or resolve that name into a numerical Internet Protocol (IP) address or other value.
In known mDNS architectures, the third-party provider of the mDNS service may wish to monitor the performance and reliability of the overall network that includes the set of domain name servers in order to gauge the delivery of mDNS services, schedule maintenance of hardware or software, meter or bill those services, or perform other tasks. To perform those kinds of monitoring operations, the mDNS provider or other entity may deploy a set of “probe” servers which monitor the availability and performance of the name servers and their underlying resolution services. The set of probe servers can be operated from an external vantage point to the name servers, and can capture and record system uptime, downtime, response times, and a variety of other network operations and performance data.
However, no tools are available to assist an administrator or other user in assessing, setting up, and operating the necessary probe servers for these types of monitoring network. To deploy a monitoring network, the administrator or other user may, for instance, have to manually estimate the number of probe servers needed to effectively monitor a given mDNS network, allow for the expected or predicted frequency of network failures and associated downtime (including those of the probe servers themselves), and provide for the ability of the overall mDNS network to scale or reduce as the demands of the underlying customer domain infrastructure change.
In trying to carry out those estimates and implementations, if an administrator or other user creates a smaller than needed estimate of the total number of probe servers, that scenario can create result in name service failures and/or failures in the monitoring operations, themselves. Conversely, when an administrator or other user creates a larger than necessary number of probe servers, that outcome can unnecessarily increase the overall costs of the network, create an excessive flow of messages between the probe servers and name servers, and place excessive burdens on service logging and disk space.
It may be desirable to provide methods and systems for configuring a probe server network using a reliability model, in which a set of analytic tools and automated resources can allow an administrator or other user to configure mDNS networks, including the complement of probe servers, on a managed or rationalized basis.
The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate implementations of the present teachings and together with the description, serve to explain principles of the present teachings. In the figures:
Implementations of the present teachings relate to systems and methods for configuring a probe server network using a reliability model. More particularly, implementations relate to platforms and techniques for establishing an mDNS network, including underlying name servers, probe servers to monitor the name servers, and connections between all of those server nodes. In preparing the overall network for operation, the inventive platforms and techniques can use defined metrics and requirements for reliability, uptime, scalability and other network performance features, and generate a suggested number of probe servers necessary to achieve those metrics. The deployment of automatic network design and analysis tools can help to eliminate design guesswork and provide operational benefits including reduced cost, better bandwidth utilization, storage, and efficiency gains. In aspects, the inventive platform and techniques can employ a management engine that has at least two component parts: a mathematical network model or engine, and a simulation model or engine.
The mathematical network model or engine (at times, for brevity referred to as the network model) can analyze core information about the overall reliability of the service architecture reliability. The network model can derive reliability metrics in part by answering at least two basic worst case scenario questions for the network, namely:
The network model is based on knowledge of the overall network topology, including name server array size, probe server array size, and the configuration of a set of connections between those nodes or elements. The network model as noted also operates on a set of reliability data that can characterize each element of the overall service architecture, including probe servers, name servers, and again the network connections between those server nodes or clusters. The network model can be configured to compute an amount of time (measured in minutes, hours, or other units, for example) during which the name service or monitoring service will fail, or an unnecessary service switchover is initiated.
In each case the network model can impose a requirement that the name server out of service state must be detected by at least two probe servers, to ensure accuracy in assessing that state. The network model can further accommodate either service architecture growth or network reduction, and can adjust to having an architecture element (network connection or other) permanently out of service.
The monitoring platform can moreover apply a second layer of analysis and management used to configure and administer the overall network 100, using an additional simulation engine or model designed to carry out long-range simulations of the network model. The simulation engine comes into play when an administrator or other user has completed analytical work on the network using the network model, but wishes to perform further or more detailed analysis on one or more aspects of the overall network. The simulation engine can incorporate, or receive as a baseline input, the service architecture as generated or conditioned by the network model, and can further take into account two additional requirements. These requirements can be derived from service level agreements (SLAs) or other requirements of the customer deploying the name servers:
The simulation engine is computationally efficient, and can aggregate all network connection and probe server simulated failures and merge them with the simulated name server failures. In terms of the simulation techniques employed by the simulation engine, in implementations the simulation engine can be based on a Monte Carlo simulation engine. In implementations, other simulation engines or models can be used. After conducting a Monte Carlo random walk or other simulation operation, the simulation engine can use a branch-and-bound algorithm or other technique in order to determine whether a particular name server failure is visible to at least two probe servers, as stipulated by the network model, itself.
By applying these and other techniques and factors, the monitoring platform and techniques of the present teachings can adjust and scale a set of zero or more probe servers to efficiently service a set of zero or more name servers of a given size and performance characteristics. The monitoring platform and techniques can generate and identify a number of probe servers reflecting a minimum, maximum, highly-tuned, recommended, most practically efficient, and/or optimized number of probe servers, and/or arrangement for those probe servers. The number of probe servers can be arrived at, in part, by factoring in a thorough or complete analysis of failure modes in the overall network, including analysis to identify and quantify faults or failures in the name servers, in the probe servers themselves, and connections between those elements. The failure analysis can account for a variety of failure modes, including concurrent, sequential, and/or otherwise overlapping failures of the name servers, probe servers, and connections.
By incorporating these factors and others, the monitoring platform can reduce the occurrence of false positive detections, false negative detections, double fault detections, and other spurious or inaccurately detected failure events. Unnecessary transitions to other name or probe servers (failover events) can consequently be reduced or eliminated. It may be noted that in aspects, the occurrence of false detection of name server failures (false positives) can represent one factor that imposes burdens or inefficiencies on the overall monitoring network, since false positives can create the impression that the name service is failing at a greater rate than it actually is.
In that situation, an administrator or other user may deploy more name servers or other resources than necessary, to try to create an adequate reserve for failover purposes. By committing more name servers than necessary, the corresponding number of probe servers may also be needlessly increased, and the amount of monitoring traffic, storage, maintenance, and other costs may be increased. Systems and methods according to the present teachings can help to reduce or eliminate those effects, by explicitly taking into account the possibility of false positives and other spurious or unreliable detected events.
Reference will now be made in detail to exemplary implementations of the present teachings, which are illustrated in the accompanying drawings. Where possible the same reference numbers will be used throughout the drawings to refer to the same or like parts.
Within the overall network 100, a management engine 110 can operate to monitor and maintain the set of name servers 102, the set of probe servers 106, and/or the set of connections 104. The management engine 110 can communicate with those elements and others via one or more connections 128. In implementations, the management engine 110 can comprise one or more servers, which can be co-located with the set of probe servers 106 and/or name servers 102, and/or can be situated remotely from those nodes or elements. In implementations, the management engine 110 can be partly or wholly implemented as a network-based service, such as a service or application operating in a cloud-based network or other network.
The management engine 110 can host or comprise modules, services, software, and/or logic including a network model 112 and a simulation engine 114 to analyze, characterize, configure, maintain, and operate the set of name servers 102 and other elements of the overall network 100. The management engine 110 can also communicate with a local or remote data store 116 to access and maintain data related to the overall network 100. The management engine 110 can be or include a server with one or more connections 128 to the set of name servers 102, set of connections 104, and set of probe servers 106. The one or more connections 128 can be or include, for instance, the Internet and/or other public or private networks or connections.
The topology of the overall network 100 can be viewed to include one or more pyramids, meaning the connections between at least two probes in the set of probe servers 106 and a single name server in the set of name servers 102, with the name server at the apex of each pyramid 130, as represented by the dashed line in
In implementations, the monitoring platform may assume that every probe in the set of probe servers 106 can test the “sanity” or operational soundness of any of the name servers in the set of name servers 102. It platform may likewise assume, as an operating condition, that if at least two of the probes in the set of probe servers 106 determine that a particular name server is not in service, then it is established to be not in service. An entire pyramid 130 is considered out of service if no more than one probe connected to the subject name server at the apex of the pyramid 130 is in service, and that name server is also out of service. It may be noted that in implementations, the condition that every probe tests the sanity of all of the name servers in the set of name servers 102 can be replaced by a name server “heartbeat” mechanism, which can decrease the overall network 100 traffic, with little or no effect on the overall topology reliability. In implementations of those types, the set of probe servers 106 and/or the set of name servers 102 can produce or exchange periodic signals of predetermined frequency, whose order can be assembled using timestamp information to determine that each participating node is alive in a given interval. Other techniques can be used.
Regardless of the type of communication mechanism used by the set of probe servers 106 to perform monitoring activity, it will be appreciated that the inventive platforms and techniques can readily accommodate, and scale or reduce to, networks of name servers of a great variety of sizes. In implementations, for instance, the set of name servers 102 can comprise a relatively large number of servers, on the order of a thousand or multiple thousands, or more. Part of the benefit of platforms and techniques according to the present teachings is that the necessary set of probe servers 106, the set of connections 104, and other elements or resources deployed for failover monitoring purposes can be reliably estimated, regardless of overall network size or changes in the network.
It may be noted that permanent failure of a name server in the set of name servers 102 does not change the topology or the network, nor does permanent failure of a probe server change that topology. Both of these types of permanent failures instead change only the dimension of the topology. Only a permanent failure of a connection in the set of connections 104 might be seen as a topology change, in the sense that a single probe server might under those conditions be unable to probe all name servers in the set of name servers 102. In implementations, a more complete set of conditions or constraints on the overall network 100 topology shown in
The network model 112 operating or executing on the management engine 110, as noted, can include an operational model of the overall network 100, including its reliability, scalability, performance, and other characteristics. Those parameters can be encoded or reflected in a set of topology maps 120 that can be generated, accessed, and maintained by the management engine 110, and as shown for instance stored in data store 116. The set of topology maps 120 can include a variety of types of data and/or data produced by various sources, and can, in implementations, include both modeled or predicted data regarding the behavior of the overall network 100, as well as empirical data capturing the real world operation of the overall network 100. In establishing those factors or criteria, the following quantities can be used to characterize the overall network 100.
The component failure is defined by the failure perception moment, and by the time between failure and the failure repair. The assumption is that any single topology component (name server, probe server, network connection) failure is completely independent of failure of any other topology component. If some (i,j) connection is in the state of permanent failure, then wij=1. Further model assumptions can be restated as:
In order to construct the pyramid 130 reliability model, two cases can be considered. If all probe servers are failing or just one out of n of them is active, a given pyramid 130 is in a state of failure only if, at the same time, the name server is in a state of failure. The probability of this event can be computed this way:
c(pn+n pn-1(1−p)) Equation (1)
One can exclude one probe server from the other or remaining n and review all possible states of these n−1 servers along with the states of their network connections with the subject name server in the pyramid 130. If 2 of them are in service, they might be put out of service if 1 or 2 network connections are out of service; if 3 out of n are in service, these 3 might be put out of service if their 2 or 3 connections are out of service, etc. This produces the following formula about the probability that the rest of n−1 probe servers might be out of service:
Combining (1) and (2) together, various implementations can compute the probability of the single pyramid failure (F) according to the following:
At the end, this pyramid reliability calculation can be extended to the reliability of all m pyramids depicted or suggested in
Pr{one or more Fs}=1−(1−Pr{F})m Equation (4)
In implementations, false positives, i.e. the cases when name server is in service, but the network is down along the lines connecting the probe servers and the name servers, are measured as well. The cases when no more than one probe server is in service cannot generate false positives. Therefore, if 2 out of n probe servers are up and running, all 2 might be blocked by network failure to see that the customer is in service; if 3 are up, all 3 might be blocked by network failure, etc. In short,
In terms of computed throughput of the overall network 100, assume n=3, 4, 5, or 6 probes in the topology shown in
Pr{
In terms of interpreting results of the network model 112 shown in Table 1 above, for n=6 probe servers, the probability of failure of at least one pyramid 130 out of an overall n=2000 is 1.589e-10. If the year has 365*24*60=525600 minutes, then overall for m=2000 pyramids, the time during the whole year in which one might expect one or more pyramids failures shall be 525600*1.589e-10=9.771e-05 minutes; if n=3 and m=2000 then the overall time for 2000 pyramids in which one might expect one or more pyramid failures shall be on average 525600*4.903e-04=257.70 minutes. Other details are shown in Table 2 below.
Now consider the example where p=1/3650, i.e. allow the probe servers to be out of service no more than 2.4 hours during the whole year. All other probabilities will be the same as in the previous example.
p=1/3650, w=1/365, c=1/3650
In terms of treating false positives, based on Equation (5) and the same assumptions as those valid for the topology throughput, one derives the following Table 5 of false positive probabilities for n=2, 3, . . . , 6 probe servers and m=20, 40, . . . , 2000 name servers:
The same table where probabilities are mapped into minutes of expected false positive time when one might have one or more false positive failover switches is represented as shown in Tables 6-8:
p=1/3650, w=1/365, c=1/365
p=1/3650, w=1/365, c=1/3650
In implementations, the network model 112 can be constructed using different, relaxed assumptions as noted below.
w1≠w2≠ . . . ≠wn
i=1, m Nkn, any combination of k elements of N={1, 2, . . . , n}
Relaxing the assumptions further:
p1≠p2≠ . . . ≠pn j=1, 2, . . . , n and c1≠c2≠ . . . ≠cm, i=1, 2, . . . , m
Under the same assumptions as above, one has:
Therefore,
The network model 112 does not observe two cases when the same time-customer-network-probe failure is functionally irrelevant from both the probe and the customer (name server) point of view.
As shown in
One may further consider the case shown in
As noted, in addition to the network model 112, the management engine 110 can also employ, in addition to the network model 112, a simulation engine 114. In general terms, the simulation engine 114 can be used to refine the results produced by the network model 112 under additional constraints or operational data. In regards, the network model 112 can be viewed to operate under a worst-case scenario. In implementations, the parameters presumed in a worst-case scenario can be modified or adjusted, for instance based on operating data captured in the overall network 100. That operating data can be captured or recorded in a set of supplemental data 124 accessed by the management engine 110, and for instance stored in the data store 116 and/or other local or remote data store.
In terms of constructing the simulation engine 114 and its associated model or computation, any failure event outcome within a pyramid 130 will be presented by (fs, fl) pair where fs is a network component failure detection time and fl the component tbfr.
All failures of a pyramid single object (name server, customer-probe connection, probe server) within a single observation period can be presented as a hash table of the (fs, fl) pairs, where fs is a key and fl a value.
Within a single observation period, for instance one year, one can subdivide all pyramid failure events this way:
In the introduced annotation above,
To perform simulation activities, for a single simulation period, for instance one year, the following steps can be followed and/or logic applied:
As developed above in the case of the network model 112, the simulation engine 114 can process or analyze failure events having different overlapping timings. As shown in
Based on those failure configurations, one can compute a union value:
Considering the case of intersections, one can compute failure modes as follows.
The simulation engine 114 can discriminate two cases: namely where a name server failure is:
In implementations, the time intervals or periods used by the simulation engine 114 can be one year. The year is a time interval of 365*24*60=525 600 minutes. An assumption can be made that the finest human perception of the failure times is in minutes. In implementations, it can be assumed to be even more granular, i.e., one can use seconds. In this case; one year will be equal to 365*24*60*60=31 536 000 seconds. In the same fashion, failure durations can be measured in minutes and/or seconds. In implementations, it can be assumed that all the pyramid elements failures are distributed uniformly across the year and the failure interval lengths (tbfr) are uniformly distributed, too.
After appropriate intervals or periods are developed, the simulation engine 114 can apply a simulation model to the overall network 100 and its failure modes and rates. In implementations, the simulation engine used can be a Monte Carlo model or engine. In a Monte Carlo simulation, the error is roughly proportional to 1/√{square root over (n)} for a large number n, where n is number of years simulated inside the model. Therefore, to achieve the error proportional to 0.001, the number of years simulated shall be equal to at least about 1,000,000. Thus the following:
p=w=c=1/365 Number of years simulated for n=20, 40, 60-100 000 and for n=1980, 2000-10 000; Time granularity: minute
This can be compared to results generated via the network model 112:
The simulation engine 114 can likewise take into account the occurrence of false positives, using calculations as follows, using the following annotations:
Corollary 1.
If at least two out of j=1, 2, . . . , n failover probes can see the name server operable at the same time within a time interval (f,t)∈Fij
Corollary 2.
If Corollary 1 is valid for a selected i and j=1, 2, . . . , n, then at least two of the failover probes can see the name server operable within a (simulated) year.
The two corollaries above are the basis for the following processing used to compute summary false positives time within a simulated year. The goal of this approach is to calculate cumulative false positives time for a simulated year and for a topology that has m name servers and n probe servers.
The following Table 11 can be used to compare the results of simulation performed by the simulation engine 114, compared to results generated by the network model 112.
The simulation results in Table 11 above are based on a single 1,000,000 year long simulation for each pair of (customer, probe) numbers. For other numbers of probes (4, 5, 6), simulation was not carried out for practical reasons, since simulation would require at least two days on a quad-processor machine. The results produced in any of the foregoing operations or calculations of the simulation engine 114 can be stored in a set of simulation results 126, for instance, stored in the data store 116 and/or other local or remote data store.
It may be noted that according to implementations, network architectures or topologies other than that shown in
In 610, the management engine 110 can receive a set of supplemental data 124, which can be or include actual or empirical data captured during the operation of the overall network 100, including data regarding the reliability and performance of the set of name servers 102, set of connections 104, and/or set of probe servers 106, In 612, the simulation engine 114 can receive and/or set various parameters for the execution of one or more simulations of the overall network 100, including the run time of the simulation. In 614, the simulation engine 114 can generate a set of simulation results 126, using the set of supplemental data 124, any selected simulation parameters, and/or other information, as appropriate.
In 616, the network model 112, simulation engine 114, and/or management engine 110 can determine and/or recommend a number of probe servers and/or other network configuration parameters based on the set of network model results 122 and/or set of simulation results 126. In implementations, the identified number of probe servers and/or other configuration parameters can represent or reflect a minimum number of servers, nodes, and/or other elements. In implementations, the identified number of probe servers and/or other configuration parameters can represent or reflect a minimum number of servers, nodes, and/or other elements. In implementations, the identified number of probe servers and/or other configuration parameters can represent or reflect a balanced and/or optimized minimum number of servers, nodes, and/or other elements, all while taking the reliability, service level, and other variables into account. In 618, further empirical, captured, and/or observed data can be provided to the management engine 110, network model 112, and/or simulation engine 114, as appropriate. Empirical or operational data can be imported, for instance, after a predetermined period of operation of the set of name servers 102, set of connections 104, set of probe servers 106, and/or other elements, or the network as a whole.
In 620, the network model 112 can be updated or re-executed, and/or the simulation engine 114 can be updated or re-executed, based on any additional information feeds, or otherwise. In 622, the set of network model results 122, the set of simulation results 126, the network model 112, the simulation engine 114, and/or other models, engines, modules, topologies or network maps, and/or other components, parameters, or data described herein can be stored, for instance to data store 116, or other local or remote data storage resources. In 624, processing can repeat, return to a prior processing point, jump to a further processing point, or end.
The processor 708 can further communicate with a network interface 704, such as an Ethernet or other wired, optical, and/or wireless data connection, which in turn communicates with the one or more networks 710, such as the Internet or other public or private networks. The processor 708 can, in general, be programmed or configured to execute instruction or other control logic and to control various processing operations, including to execute the modeling, simulations, and/or other operations described herein. In aspects, the set of name servers 102, the set of probe servers 106, and other nodes or elements can be or include resources similar to those of the management engine 110, and/or can include additional or different hardware, software, and/or other resources. Other configurations of the overall network 100 including the set of name servers 102, set of connections 104, set of probe servers 106, additional network connections, and other hardware, software, and service resources are possible.
The foregoing description is illustrative, and variations in configuration and implementation may occur to persons skilled in the art. For example, while implementations have been described in which one set of probe servers 106 monitors one set of name servers 102, in implementations, the set of probe servers 106 can monitor and manage more than one separate set of name servers, such as those dedicated to or operated by multiple Web domain operators or other entities. Other resources described as singular or integrated can in implementations be plural or distributed, and resources described as multiple or distributed can in implementations be combined. The scope of the present teachings is accordingly intended to be limited only by the following claims.
This application is a continuation of the co-pending U.S. patent application titled, “SYSTEMS AND METHODS FOR CONFIGURING A PROBE SERVER NETWORK USING A RELIABILITY MODEL,” filed on Oct. 9, 2013 and having Ser. No. 14/050,275. The subject matter of this related application is hereby incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6810211 | Castanon | Oct 2004 | B1 |
6901445 | McCanne et al. | May 2005 | B2 |
7259666 | Hermsmeyer et al. | Aug 2007 | B1 |
7304959 | Swaroop | Dec 2007 | B1 |
7472314 | Bejerano | Dec 2008 | B2 |
7583604 | Couturier | Sep 2009 | B2 |
7907535 | Agrawal | Mar 2011 | B2 |
7912934 | Melton | Mar 2011 | B1 |
8031628 | Gu | Oct 2011 | B2 |
8295614 | Ishiyama | Oct 2012 | B2 |
8547834 | Reeves | Oct 2013 | B1 |
8547855 | Zingale | Oct 2013 | B1 |
8788462 | Roche | Jul 2014 | B1 |
8934352 | Pei | Jan 2015 | B2 |
9282020 | Bisdikian | Mar 2016 | B2 |
9622019 | Li | Apr 2017 | B2 |
20010056486 | Kosaka | Dec 2001 | A1 |
20040218548 | Kennedy | Nov 2004 | A1 |
20040261116 | Mckeown et al. | Dec 2004 | A1 |
20050081116 | Bejerano | Apr 2005 | A1 |
20060190602 | Canali et al. | Aug 2006 | A1 |
20060212568 | Morris | Sep 2006 | A1 |
20070117518 | Li | Aug 2007 | A1 |
20070177518 | Li | Aug 2007 | A1 |
20080304421 | Ramasubramanian | Dec 2008 | A1 |
20080320151 | McCanne et al. | Dec 2008 | A1 |
20090135727 | Agrawal | May 2009 | A1 |
20100202298 | Agarwal | Aug 2010 | A1 |
20100223364 | Wei | Sep 2010 | A1 |
20100228819 | Wei | Sep 2010 | A1 |
20100250739 | Murata | Sep 2010 | A1 |
20100325306 | Vimpari | Dec 2010 | A1 |
20110099420 | MacDonald McAlister et al. | Apr 2011 | A1 |
20110106757 | Pickney et al. | May 2011 | A1 |
20110145386 | Stolorz et al. | Jun 2011 | A1 |
20110178983 | Bernard et al. | Jul 2011 | A1 |
20120017110 | Omar | Jan 2012 | A1 |
20120116678 | Witmer | May 2012 | A1 |
20120215938 | Fletcher et al. | Aug 2012 | A1 |
20120246126 | Rodriquez et al. | Sep 2012 | A1 |
20120246273 | Bornstein et al. | Sep 2012 | A1 |
20120275311 | Ivershen | Nov 2012 | A1 |
20130097304 | Asthana | Apr 2013 | A1 |
20130148537 | Uchida | Jun 2013 | A1 |
20130268638 | Anderson | Oct 2013 | A1 |
20130322298 | Alexander, Jr. | Dec 2013 | A1 |
20140325279 | Suriyanarayanan | Oct 2014 | A1 |
Entry |
---|
Shubham C. Anjankar et al., “Fault Tolerant and Correction System Using Triple Modular Redundancy”, International Journal of Emerging Engineering Research and Technology, vol. 2, Issue 2, May 2014, pp. 187-191. |
T. Li et al., “Cisco Hot Standby Router Protocol (HSRP)”, The Internet Society, Mar. 1998, Retrieved from the Internet: hllps://www.ielf.org/rfc/rfc2281.lxt, pp. 1-17. |
Extended European Search Report dated Mar. 6, 2015, European Application No. 14188335.5 filed Oct. 9, 2014, pp. 1-13. |
Non-Final Office Action for U.S. Appl. No. 14/050,275, dated Sep. 30, 2015, 9 pages. |
Final Office Action for U.S. Appl. No. 14/050,275, dated May 9, 2016, 8 pages. |
Notice of Allowance for U.S. Appl. No. 14/050,275, dated Oct. 6, 2016, 7 pages. |
Number | Date | Country | |
---|---|---|---|
20170230254 A1 | Aug 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14050275 | Oct 2013 | US |
Child | 15437389 | US |