Benefit is claimed under 35 U.S.C. 119(a)-(d) to Foreign Application Serial No. 202241040594 filed in India entitled “SYSTEM AND METHOD FOR GENERATING SERVICE TOPOLOGY GRAPH FOR MICROSERVICES USING DISTRIBUTED TRACING”, on Jul. 15, 2022, by VMware, Inc., which is herein incorporated in its entirety by reference for all purposes.
In recent years, there has been significant interest in adopting microservices instead of standalone monolithic architecture, which allows a single monolithic service to be split into multiple granular services. This interest in microservices is due to the fact that microservice architecture provides is popular benefits, such as modularity, scalability, cross-functional and independent services based on business needs.
However, microservice architecture does come with some challenges. Monitoring, managing and troubleshooting in microservices is a challenging task as there are now many services for what used to be a single monolithic service. Application logging is one approach used to help in debugging individual microservices. However, the main disadvantage with application logging is that analyzing application paths can be challenging because the application paths may follow numerous microservices. In addition, this analysis does not help in understanding the holistic view of applications.
Distributed tracing is another approach that can be used in microservices, which provides program flow/data progression across the microservices using traces. However, with increase in the number of microservices, the traces that need to be analyzed increases as well, which makes trace analysis difficult to execute.
A system and method for generating a service topology graph for microservices in a computing environment uses traces collected from the microservices to generate the service topology graph. The traces are processed to create nodes and edges of the service topology graph. A new node is created when a current trace being processed is a trace being processed for a first time and an edge is created between a node that is associated with a parent span of a current span being processed when the current span is a first span being processed for the current trace and the current span includes a parent span identification.
A computer-implemented method for generating a service topology graph for microservices in a computing environment in accordance with an embodiment of the invention comprises collecting traces from the microservices, wherein each of the traces includes at least one span, and processing the traces to create nodes and edges of the service topology graph, wherein the nodes represent the microservices and the edges are connections between the nodes, wherein the processing of the traces includes, for each of the traces, creating a new node in the service topology graph when a current trace being processed is a trace being processed for a first time, and processing the at least one span of the current trace, including creating an edge between a node that is associated with a parent span of a current span being processed and the new node when the current span is a first span being processed for the current trace and the current span includes a parent span identification. In some embodiments, the steps of this method are performed when program instructions contained in a non-transitory computer-readable storage medium are executed by at least one or more processors.
A system in accordance with an embodiment of the invention comprises memory and at least one processor configured to collect traces from microservices in a computing environment, wherein each of the traces includes at least one span, and process the traces to create nodes and edges of a service topology graph for the microservices, wherein the nodes represent the microservices and the edges are connections between the nodes, wherein the at least one process is configured to, for each of the traces, create a new node in the service topology graph when a current trace being processed is a trace being processed for a first time, and process the at least one span of the current trace, including creating an edge between a node that is associated with a parent span of a current span being processed and the new node when the current span is a first span being processed for the current trace and the current span includes a parent span identification.
Other aspects and advantages of embodiments of the present invention will become apparent from the following detailed description, taken in conjunction with the accompanying drawings, illustrated by way of example of the principles of the invention.
Throughout the description, similar reference numbers may be used to identify similar elements.
It will be readily understood that the components of the embodiments as generally described herein and illustrated in the appended figures could be arranged and designed in a wide variety of different configurations. Thus, the following more detailed description of various embodiments, as represented in the figures, is not intended to limit the scope of the present disclosure, but is merely representative of various embodiments. While the various aspects of the embodiments are presented in drawings, the drawings are not necessarily drawn to scale unless specifically indicated.
The present invention may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is, therefore, indicated by the appended claims rather than by this detailed description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.
Reference throughout this specification to features, advantages, or similar language does not imply that all of the features and advantages that may be realized with the present invention should be or are in any single embodiment of the invention. Rather, language referring to the features and advantages is understood to mean that a specific feature, advantage, or characteristic described in connection with an embodiment is included in at least one embodiment of the present invention. Thus, discussions of the features and advantages, and similar language, throughout this specification may, but do not necessarily, refer to the same embodiment.
Furthermore, the described features, advantages, and characteristics of the invention may be combined in any suitable manner in one or more embodiments. One skilled in the relevant art will recognize, in light of the description herein, that the invention can be practiced without one or more of the specific features or advantages of a particular embodiment. In other instances, additional features and advantages may be recognized in certain embodiments that may not be present in all embodiments of the invention.
Reference throughout this specification to “one embodiment,” “an embodiment,” or similar language means that a particular feature, structure, or characteristic described in connection with the indicated embodiment is included in at least one embodiment of the present invention. Thus, the phrases “in one embodiment,” “in an embodiment,” and similar language throughout this specification may, but do not necessarily, all refer to the same embodiment.
Turning now to
Distributed tracing helps in tracking each and every data path across an application stack, which may pass through many microservices. Distributed tracing may be achieved using well-known available libraries or any proprietary trace generation solution, to generate traces or multiple trace data. Some of the parameters that may be included in traces are (1) function calls, (2) time taken to complete a request, (3) connection details (e.g., in case of database connection), and (4) request statistics, such as success or failure.
Once tracing is enabled, traces for each set of actions triggered inside the microservices are generated. A trace is similar to a log, which is obtained from application logging. Whereas logs provide state of an application, traces provide details on a request, which spans across multiple microservices. Each trace can act as a point of view for analyzing the data path of an application and detecting failures. Multiple traces can be grouped into one single cluster of traces, which represents a unique data path for an application workflow. There can be many such groups or clusters of traces, which signifies corresponding business logic implemented in microservices. Traces will be described in more detail below.
In the illustrated embodiment, the tracing service 102 operates with a trace collector 108, which collects trace data from the data centers 104 and transmits the collected trace data to the tracing service 102. The trace collector 108 may work with components in the data centers 104 to receive the trace data. The tracing service 102 performs various operations to manage the collected trace data. Some of the operations performed by the tracing service 102 may include formatting the trace data and sending the traced data to a data store 110. The tracing service 102 and the trace collector 108 may be implemented as software running on an appropriate computing environment, such as on a public cloud or on one or more private clouds. In some embodiments, the trace collector 108 may be integrated into the tracing service 102.
The data store 110 is a repository to persistently store the trace data and any information related to the trace data. The data store 110 may utilize any database search solutions, such as, but not limited to, Structured Query Language (SQL), Apache Solr and Elasticsearch. As an example, the data store 110 will be described as using Apache Solr.
Debugging/troubleshooting the microservices 106 running in any computer environment, such as one of the data centers 104, is a tough task with increase in microservices deployed in a cluster. A program path can be defined as business workflow which might span across many microservices, for example, in e-commerce domain order management life cycle, user creation workflow, product search domain, etc. Let's take order management service (OMS) program path as an example. When a customer tries to buy a product, the backend system goes through a set of microservices, such as (1) order service (create and persist an invoice), (2) inventory service (check if there is inventory available for the order), (3) payment service (check for account balance and initiate payment process), and (4) delivery service (start the delivery process).
Traces help in bringing connections between the set of microservices for each of the program paths. A trace holds data about the existing code path and additional details, such as, request time, connection details, memory limits, etc. As previously mentioned, a trace can be thought of as a log in application logging. Each trace will usually have multiple spans, where each span holds details of each program path. Each span points to the next span using a pointer variable which explains the program path. A trace can have N number of spans, which typically involve different microservices. Hence, looking at a trace can hold some high level details of all the microservices involved in one single place.
Examples of traces or trace data that may be collected are shown below in Table 1, which include a trace from an inventory service and a trace from a payment service.
As shown in Table 1, each microservice emits a trace or trace data that contains a list of spans. Some of the properties of a span may include (1) span identification (ID) or spanId (uniquely identifies a span), (2) trace ID or traceld (uniquely identifies a trace) and (3) parent ID or parentId (spanld of the previous span, which helps in connecting two spans), which may also be called parent span ID. In the above table, the trace data from the payment service has a span “114” (spanId) and parentId “112”, which is same as the spanId of a span “112” in the trace data from the inventory service. Thus, there is a connection from the span “112”, which is associated with the inventory service, to the span “114”, which is associated with the payment service. This is how a connection is made from two different microservices and forms a single unit of trace. Thus, traces may be used for troubleshooting processes.
However, a disadvantage with using trace data for troubleshooting processes is that there can be many program paths, which will increase the number of traces. Looking at each trace might require similar effort as looking at each log in each microservice, even though spans in the traces are connected over a set of microservices. Hence, an increase in the number of traces to review is directly proportional to the increase in the troubleshooting process.
In order to address this disadvantage, the distributed system 100 includes a service topology engine 112, which provides an efficient way to troubleshoot the microservices running in the data centers 104 using traces by bringing a holistic view of application workflows in the form of a directed graph that represent a service topology for connected microservices. This directed graph will be referred to herein as a service topology graph, which can act as one stop or the first step process in troubleshooting the microservices.
A service topology graph generated by the service topology engine 112 includes nodes, which represent microservices, and edges, which represent connections between the microservices. The service topology graph provides an easy-to-consume visual to analyze the microservices 106 running in each data center 104, which execute various operations for one or more applications. The service topology graph may also visually indicate which microservices has detected failures. As an example, a microservice with a failure may be illustrated as a node with a particular color, e.g., red, which is different than the other nodes without any detected failures. The service topology graph may also visually provide network latency measures on the edges so that network performance can be readily analyzed. In addition, the service topology graph may indicate deprecated nodes (i.e., nodes without connections to other nodes via edges) and/or network bottlenecks.
An example of a service topology graph 200 generated by the service topology engine 112 in accordance with an embodiment of the invention is shown in
The service topology engine 112 may use data structures to generate service topology graphs. The data structure for a service topology graph includes data structures for nodes and edges, which are the main components of the service topology graph.
Examples of a node data structure and an edge data structure used by the service topology engine 112 in accordance with an embodiment of the invention are shown in a table 300 in
A request for a service topology graph for the microservices running in the data center may be made to the service topology engine 112 by a user, such as an administrator, using a user interface 114, which can be any user interface running on any system, such as a web-based user interface. In an embodiment, a request is made with a specified time range, which can be defined using a start time and an end time. The specified time range instructs the service topology engine 112 to use only trace data found during the specified time range. In response to the request, a service topology will be generated by the service topology engine 112 and the resulting data of the service topology graph or graph data is transmitted to the user interface 114, where the service topology graph is rendered by the user interface 114. The displayed service topology graph can then be used by the user to analyze the microservices, e.g., for troubleshooting.
Turning now to
Next, at step 404, a graph data structure is initialized by the service topology engine 112 for the new service topology graph being generated. This graph data structure will be used to define nodes and edges that will be created for the requested service topology graph. Next, at step 406, traces within the specified time range are fetched from the data store 110 by the service topology engine 112. In an embodiment, distinct trace IDs for the specified time range are first fetched from the data store 110. Then, for each trace ID, all traces with the trace ID within the specified time range are fetched from the data store 110.
Next, at step 408, an iteration of the traces for the specified time range is started by the service topology engine 112 to process all of the traces. For each trace, a determination is made whether the current trace is the last trace by the service topology engine 112, at step 410. If the current trace is not the last trace, the process proceeds to step 412, where a new node of the service topology graph is created by the service topology engine 112 if a node corresponding to the current trace is not present in the service topology graph being generated. This is illustrated in
Next, at step 414, an iteration of the spans from the current trace is started by the service topology engine 112. Next, at step 416, if failure is found in the current span, the node corresponding to the current trace is updated as having a detected failure by the service topology engine 112. This is illustrated in
Next, at step 418, a determination is made whether the current span is the last span in the iteration by the service topology engine 112. If yes, then the last span details for connecting nodes are stored by the service topology engine 112, at step 420. The last span details are needed for connecting nodes. Then, at step 422, the iteration of the spans for the current trace is terminated or stopped by the service topology engine 112. The process then proceeds to process the next trace for the iteration of the traces. Thus, the process proceeds back to step 410 for the next trace being processed. However, if the current span is not the last span, then the process proceeds to step 424.
At step 424, a determination is made whether the current span is the first span of the current trace and the current span includes a parent ID by the service topology engine 112. If no, then the process proceeds to step 422, where the iteration of the spans for the current trace is terminated by the service topology engine 112, and the next trace is processed. However, if the current span is the first span of the current trace and the current span includes a parent ID, then the process proceeds to step 426, where the two nodes corresponding to the last span and the current span are connected and an edge is created between the nodes by the service topology engine 112. The process then proceeds to process the next span for the iteration of the spans. The connecting of two nodes is illustrated in
Turning back to step 410, if the current trace is the last trace in the iteration, the process proceeds to step 428, where the iteration of traces is stopped by the service topology engine 112. At this point, after iterating through all the traces and their spans, all the nodes and edges in the service topology graph have been created. This is illustrated in
Next, at step 430, any deprecated nodes in the service topology graph are detected using the service topology graph by the service topology engine 112. In an embodiment, the deprecated nodes that have been detected are visually indicated in the service topology graph. This is illustrated in
Next, at step 432, any network bottlenecks in the service topology graph are detected by the service topology engine. In an embodiment, the network bottlenecks that have been detected are indicated in the service topology graph. As illustrated in
Next, at step 434, the data of the service topology graph is sent to the user interface 114 by the service topology engine 112 as a response to the received request for the service topology graph. Then, at step 436, the service topology graph is rendered on the user interface 114. As an example, the rendered service topology graph may be similar to the service topology graph shown in
In an embodiment, the following algorithm may be used to generate a service topology graph for the data centers.
The above algorithm uses the data structures defined in the table 300 shown in
For each of the trace IDs obtained, parameters last_span and last_node are initialized in step 3(a), and complete trace data are fetched from the data store in step 3(b). As each microservice emits its own trace data, a list of traces which belongs to unique trace ID is obtained (see Table 1 for examples).
In step 3(c), each of the traces or trace data is processed iteratively until all the traces are processed. In this step, the parameters host_name, has_failure and Node are initialized. Based on the hostname of each trace data, a new node is created in the graph in step 3(c)(1) or an existing node (already created) in the graph is updated in step 3(c)(2). Each trace will have N spans which depends on the program path. In step 3(c)(3), each of the spans is processed iteratively until all the spans of the trace are processed.
In step 3(c)(3), three operations are performed for each span of the trace. In In step 3(c)(3)(a), a determination is made whether the current node has failures. Every span has status which represents if there is any failure in the current program path. Thus, if there are any failures, then the has_failure global property is updated in step 3(c)(3)(a). In step 3(c)(3)(b), the current node is connected with all the other nodes in the graph only when the parent ID of the first span is not null and a directed edge is created between two nodes. In step 3(c)(3)(c), the last span is tracked, which is needed in the above step for creating edges between two nodes. Once the span iteration is done for a trace data, the node status is updated to failure accordingly based on has_failure property in step 3(c)(4). The complete service topology derived from the traces of the application can be stored in the graph hash table.
The service topology graph can be used to detect deprecated nodes and network bottlenecks. To detect deprecated nodes, the nodes of the service topology graph are iteratively processed to find nodes without any edges. If there are no edges for any given node, then such nodes can be deprecated. The following algorithm may be used to detect deprecated nodes in the service topology graph.
To detect network bottlenecks, the edges of the service topology graph are iteratively processed to find network bottlenecks. If a request time in any edge crosses the threshold time limit, then the edge is marked as a network bottleneck The following algorithm may be used to detect network bottlenecks in the service topology graph.
In some embodiments, a network latency measure or value may be graphically added to each edge in a service topology graph, which indicates network latency for the connection between two nodes represented by that edge. These network latency values may the request time values found in the span data associated with the edges. In one implementation, the network latency values are weight values from 1-100, where larger numbers represent higher latencies. This is illustrated in
The microservices for which service topology graphs are generated may be implemented in any computing environment. Turning now to
In an embodiment, one or more of the private cloud computing environments 602 may be controlled and administrated by a particular enterprise or business organization, while one or more of the public cloud computing environments 604 may be operated by a cloud computing service provider and exposed as a service available to account holders, such as the particular enterprise in addition to other enterprises. In some embodiments, each private cloud computing environment 602 may be a private or on-premise data center. The private and public cloud computing environments 602 and 604 are connected to each other via a network 606.
The private and public cloud computing environments 602 and 604 of the hybrid cloud computing environment 600 include computing and/or storage infrastructures to support a number of virtual computing instances 608A and 608B. As used herein, the term “virtual computing instance” refers to any software processing entity that can run on a computer system, such as a software application, a software process, a virtual machine (VM), e.g., a VM supported by virtualization products of VMware, Inc., and a software “container”, e.g., a Docker container. However, in this disclosure, the virtual computing instances will be described as being virtual machines, although embodiments of the invention described herein are not limited to virtual machines.
As shown in
Each host 610 may be configured to provide a virtualization layer that abstracts processor, memory, storage and networking resources of the hardware platform 612 into the virtual computing instances, e.g., the virtual machines 608A, that run concurrently on the same host. The virtual machines run on top of a software interface layer, which is referred to herein as a hypervisor 624, that enables sharing of the hardware resources of the host by the virtual machines. One example of the hypervisor 624 that may be used in an embodiment described herein is a VMware ESXi™ hypervisor provided as part of the VMware vSphere® solution made commercially available from VMware, Inc. The hypervisor 624 may run on top of the operating system of the host or directly on hardware components of the host. For other types of virtual computing instances, the host may include other virtualization software platforms to support those virtual computing instances, such as Docker virtualization platform to support software containers.
Each private cloud computing environment 602 includes a virtualization manager 626 that communicates with the hosts 610 via a management network 628. In an embodiment, the virtualization manager 626 is a computer program that resides and executes in a computer system, such as one of the hosts 610, or in a virtual computing instance, such as one of the virtual machines 608A running on the hosts. One example of the virtualization manager 626 is the VMware vCenter Server® product made available from VMware, Inc. The virtualization manager 626 is configured to carry out administrative tasks for the private cloud computing environment 602, including managing the hosts, managing the virtual machines running within each host, provisioning virtual machines, migrating virtual machines from one host to another host, and load balancing between the hosts.
In one embodiment, the virtualization manager 626 includes a hybrid cloud (HC) manager 630 configured to manage and integrate computing resources provided by the private cloud computing environment 602 with computing resources provided by one or more of the public cloud computing environments 604 to form a unified “hybrid” computing platform. The hybrid cloud manager is configured to deploy virtual computing instances, e.g., virtual machines 608A, in the private cloud computing environment, transfer virtual machines from the private cloud computing environment to one or more of the public cloud computing environments, and perform other “cross-cloud” administrative tasks. In one implementation, the hybrid cloud manager 630 is a module or plug-in to the virtualization manager 626, although other implementations may be used, such as a separate computer program executing in any computer system or running in a virtual machine in one of the hosts. One example of the hybrid cloud manager 630 is the VMware® HCXTM product made available from VMware, Inc.
In one embodiment, the hybrid cloud manager 630 is configured to control network traffic into the network 606 via a gateway device 632, which may be implemented as a virtual appliance. The gateway device 632 is configured to provide the virtual machines 608A and other devices in the private cloud computing environment 602 with connectivity to external devices via the network 606. The gateway device 632 may manage external public Internet Protocol (IP) addresses for the virtual machines 108A and route traffic incoming to and outgoing from the private cloud computing environment and provide networking services, such as firewalls, network address translation (NAT), dynamic host configuration protocol (DHCP), load balancing, and virtual private network (VPN) connectivity over the network 606.
Each public cloud computing environment 604 is configured to dynamically provide an enterprise (or users of an enterprise) with one or more virtual computing environments 636 in which an administrator of the enterprise may provision virtual computing instances, e.g., the virtual machines 608B, and install and execute various applications in the virtual computing instances. Each public cloud computing environment includes an infrastructure platform 638 upon which the virtual computing environments can be executed. In the particular embodiment of
In one embodiment, the virtualization platform 646 includes an orchestration component 648 that provides infrastructure resources to the virtual computing environments 636 responsive to provisioning requests. The orchestration component may instantiate virtual machines according to a requested template that defines one or more virtual machines having specified virtual computing resources (e.g., compute, networking and storage resources). Further, the orchestration component may monitor the infrastructure resource consumption levels and requirements of the virtual computing environments and provide additional infrastructure resources to the virtual computing environments as needed or desired. In one example, similar to the private cloud computing environments 602, the virtualization platform may be implemented by running on the hosts 642 VMware ESXi™-based hypervisor technologies provided by VMware, Inc. However, the virtualization platform may be implemented using any other virtualization technologies, including Xen®, Microsoft Hyper-V® and/or Docker virtualization technologies, depending on the virtual computing instances being used in the public cloud computing environment 604.
In one embodiment, each public cloud computing environment 604 may include a cloud director 650 that manages allocation of virtual computing resources to an enterprise. The cloud director may be accessible to users via a REST (Representational State Transfer) API (Application Programming Interface) or any other client-server communication protocol. The cloud director may authenticate connection attempts from the enterprise using credentials issued by the cloud computing provider. The cloud director receives provisioning requests submitted (e.g., via REST API calls) and may propagate such requests to the orchestration component 648 to instantiate the requested virtual computing instances (e.g., the virtual machines 608B). One example of the cloud director is the VMware vCloud Director® product from VMware, Inc. The public cloud computing environment 604 may be VMware cloud (VMC) on Amazon Web Services (AWS).
In one embodiment, at least some of the virtual computing environments 636 may be configured as virtual data centers. Each virtual computing environment includes one or more virtual computing instances, such as the virtual machines 608B, and one or more virtualization managers 652. The virtualization managers 652 may be similar to the virtualization manager 626 in the private cloud computing environments 602. One example of the virtualization manager 652 is the VMware vCenter Server® product made available from VMware, Inc. Each virtual computing environment may further include one or more virtual networks 654 used to communicate between the virtual machines 608B running in that environment and managed by at least one networking gateway device 656, as well as one or more isolated internal networks 658 not connected to the gateway device 656. The gateway device 656, which may be a virtual appliance, is configured to provide the virtual machines 608B and other components in the virtual computing environment 636 with connectivity to external devices, such as components in the private cloud computing environments 602 via the network 606. The gateway device 656 operates in a similar manner as the gateway device 632 in the private cloud computing environments.
In one embodiment, each virtual computing environments 636 includes a hybrid cloud (HC) director 660 configured to communicate with the corresponding hybrid cloud manager 630 in at least one of the private cloud computing environments 602 to enable a common virtualized computing platform between the private and public cloud computing environments. The hybrid cloud director may communicate with the hybrid cloud manager using Internet-based traffic via a VPN tunnel established between the gateway devices 632 and 656, or alternatively, using a direct connection 662. The hybrid cloud director and the corresponding hybrid cloud manager facilitate cross-cloud migration of virtual computing instances, such as virtual machines 608A and 608B, between the private and public computing environments. This cross-cloud migration may include both “cold migration” in which the virtual machine is powered off during migration, as well as “hot migration” in which the virtual machine is powered on during migration. As an example, the hybrid cloud director 660 may be a component of the HCX-Cloud product and the hybrid cloud manager 630 may be a component of the HCX-Enterprise product, which are provided by VMware, Inc.
A computer-implemented method for generating a service topology graph for microservices in a computing environment in accordance with an embodiment of the invention is described with reference to a flow diagram of
Although the operations of the method(s) herein are shown and described in a particular order, the order of the operations of each method may be altered so that certain operations may be performed in an inverse order or so that certain operations may be performed, at least in part, concurrently with other operations. In another embodiment, instructions or sub-operations of distinct operations may be implemented in an intermittent and/or alternating manner.
It should also be noted that at least some of the operations for the methods may be implemented using software instructions stored on a computer useable storage medium for execution by a computer. As an example, an embodiment of a computer program product includes a computer useable storage medium to store a computer readable program that, when executed on a computer, causes the computer to perform operations, as described herein.
Furthermore, embodiments of at least portions of the invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. For the purposes of this description, a computer-usable or computer readable medium can be any apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
The computer-useable or computer-readable medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device), or a propagation medium. Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disc, and an optical disc. Current examples of optical discs include a compact disc with read only memory (CD-ROM), a compact disc with read/write (CD-R/W), a digital video disc (DVD), and a Blu-ray disc.
In the above description, specific details of various embodiments are provided. However, some embodiments may be practiced with less than all of these specific details. In other instances, certain methods, procedures, components, structures, and/or functions are described in no more detail than to enable the various embodiments of the invention, for the sake of brevity and clarity.
Although specific embodiments of the invention have been described and illustrated, the invention is not to be limited to the specific forms or arrangements of parts so described and illustrated. The scope of the invention is to be defined by the claims appended hereto and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
202241040594 | Jul 2022 | IN | national |