Today's infrastructure networks are becoming more and more complicated and including ever increasing numbers of devices with network capabilities. The Internet of Things (IoT) growth represents one growth area that cause corporate networks, for example, to include substantially more network connected devices as compared to their historical requirements. One side-effect of adding such a large volume of connected devices is that infrastructure networks (e.g., corporate private networks) have become more complicated and may require additional network support devices such as routers, bridges, domain name servers, network time protocol (NTP) servers, gateways, etc. Each of these network support devices (or simply network devices) requires a configuration of network parameters in order to function as desired within the possibly complex network architecture. In some cases, network devices require consistency for certain network parameters (e.g., Internet Protocol (IP) address of an NTP server). This is, in part, because there may not be multiple NTP servers within a given network because all devices on the network should have a consistent time reference. In other cases, for example to support a secure subnet, that is restricted from standard network communication traffic, within a lager network infrastructure, certain devices must have different values for the same configuration parameter setting as other device not involved (or allowed access to) the secure subnet. In another simple example, if a system administrator were defining an IP address for an interface in a network (or subnet) it would be important to ensure that the address represents a unique interface (i.e., not a duplicated IP address) in that network portion. Simply put, there are situations when configuration parameter settings are desired to be identical and other situations where the same configuration parameter settings must have a different value for selected network devices.
Prior art methods for maintaining network device parameters have been largely manual with limited “home grown” automation and maintenance capabilities available to system administrators. For example, some system administrators would create templates to store base values for configuration settings used to configure a new device, implement scripted methods to apply bulk changes of data to network devices, or utilize standard multi-file differencing utilities. While providing some perceived assistance, templates could easily become outdated and a change to a value representing a configuration setting in a template required determining which network devices had already been configured based on the now outdated template. Automated bulk changes were additionally problematic, for example, if an error was introduced in bulk, the network may be crashed and difficult to restore. Multi-file diff utilities are limited and typically focus on a very few number of files (e.g., mostly 2 and sometimes 3 files but rarely more). Overall, these approaches do not provide a comprehensive solution to address a network administrator's needs. Further, because of the manual nature and overall complexity of the problem being addressed with non-network aware tools, these approaches often resulted in inadvertent incorrect settings being configured for one or more devices within a network infrastructure. Incorrect configuration settings for network devices may cause undesired network performance, or even network failure. Accordingly, care must be taken when setting or adjusting configuration parameters of network devices.
For a detailed description of various examples, reference will now be made to the accompanying drawings, in which:
This disclosure is directed to a network configuration development environment to improve system administrative interfaces to network devices. In particular, but not by way of limitation, this disclosure is related to an interface to view and edit multiple network configuration definitions relative to a plurality of network devices simultaneously to achieve correctness and appropriate consistency for each of those devices to work in a coordinated, and efficient manner to support a network communication infrastructure.
To address issues related to prior art network administration techniques, this disclosure presents methods and systems to improve the complex technical art of network administration. In particular, the disclosed network administration editor, that is part of an overall network configuration development environment, provides automated error checking, consistency validation, change implementation, and automated roll back of changes. Additionally, the disclosed network administration editor provides a multi-file edit capability that may be useful in areas beyond the field of network administration. The multi-file edit capability allows centralized management of contents of potentially numerous files that typically represent slight variations from a master “draft” file and from each other. Visual clues, and “expert help” may be provided via the editor to assist in maintaining and validating portions of files having different contents from each other and ensuring proper consistency across those files.
In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the examples disclosed herein. It will be apparent, however, to one skilled in the art that the disclosed example implementations may be practiced without these specific details. In other instances, structure and devices are shown in block diagram form in order to avoid obscuring the disclosed examples. Moreover, the language used in this disclosure has been principally selected for readability and instructional purposes and may not have been selected to delineate or circumscribe the inventive subject matter, resorting to the claims being necessary to determine such inventive subject matter. Reference in the specification to “one example” or to “an example” means that a particular feature, structure, or characteristic described in connection with the examples is included in at least one implementation.
The term “computing system” is generally taken to refer to at least one electronic computing device that includes, but is not limited to, a single computer, virtual machine, virtual container, host, server, laptop, and/or mobile device or to a plurality of electronic computing devices working together to perform the function described as being performed on or by the computing system. The term also may be used to refer to a number of such electronic computing devices in electronic communication with one another.
As used herein, the term “medium” refers to one or more non-transitory physical media that together store the contents described as being stored thereon. Examples may include non-volatile secondary storage, read-only memory (ROM), and/or random-access memory (RAM). Such media may be optical or magnetic.
As used herein, the terms “application” and “function” refer to one or more computing modules, programs, processes, workloads, threads and/or a set of computing instructions executed by a computing system. Example implementations of applications and functions include software modules, software objects, software instances and/or other types of executable code. Note, the use of the term “application instance” when used in the context of cloud computing refers to an instance within the cloud infrastructure for executing applications (e.g., for a customer in that customer's isolated instance).
As used herein, the term “multi-editor” refers to an editor capable of editing multiple files simultaneously. For example, a number of files representing a set of network devices may be collected and presented to a system administrator (e.g., network administrator) such that information identical to all underlying devices is presented as “normal” text while information that is different in the underlying files may be presented in a “highlighted” manner to identify to the system administrator that there is a difference across the multiple files. In cases where the differences are “expected” (e.g., believed to be intentional based on the nature of the data), a generated “macro” variable may be presented instead of the underlying information. Alternatively, if the differences are “unexpected” (e.g., believed to be a typographical error or configuration error), the presentation may be an overlay of differing text (or other visual clue) to draw further attention to that area of the multi-editor presentation screen. In general, when there are similar and expected variations in underlying data, the multi-editor will not attempt to draw as much attention to that data as it would if the variations were vast and unexpected (e.g., reflective of a typo). Further, variations are not necessarily reflective of the amount of difference in the text but may also take into account the impact of any difference in that data. For example, a single character difference in a network address of an NTP server may have a greater difference than a large amount of character difference in a configuration file comment.
As used herein, a “draft” version of a configuration refers to configuration information (e.g., a configuration file) that is not directly associated with a network device. For example, a master template used for comparison purposes may be stored as a “draft” in the disclosed network configuration repository of information.
As used herein, a “candidate” version of a configuration refers to configuration information (e.g., a configuration file) that is associated with a network device (e.g., switch, router) and contains configuration settings that have not yet been deployed to that network device. For example, saved changes that have not yet been “committed” to a running network but are staged for a coordinated deployment.
As used herein, the term “start-up” when referring to a configuration of a network device is used in its normal and customary sense with respect to network devices and refers to the configuration settings applied to that network device if it is rebooted (e.g., restarted). Changes to a start-up configuration will have no effect on a running network device and will be used the next time that device is restarted.
As used herein, the term “running” when referring to a configuration of a network device is used in its normal and customary sense with respect to network devices and refers to the configuration settings applied to that network device while it is running. The running configuration may or may not match the start-up configuration. For example, a system administrator may change a setting in a running configuration knowing that if the network fails and must be restarted, the change will, upon restart, be reverted back to the start-up configuration.
Referring now to
Networked computing infrastructure 100 comprises a customer network 102, network 108, and a “backend” cloud or server resources platform/network 110. In one example, the customer network 102 may be a local private network, such as local area network (LAN) that includes a variety of network devices that include, but are not limited to switches 150, 151, 152, and 153), servers, wireless access points (WAPs) 154-155, and routers. Each of these networks can contain wired or wireless programmable devices and operate using any number of network protocols (e.g., TCP/IP) and connection technologies (e.g., WiFi® networks, Bluetooth®). In another example, customer network 102 represents an enterprise network that could include or be communicatively coupled to one or more local area networks (LANs) that may be implemented as different subnets (e.g., subnet A 161, subnet B 162, and subnet C 153), virtual networks, data centers, and/or other remote networks (e.g., 108, 112).
As shown in
Networked computing infrastructure 100 also includes cellular network 103 for use with mobile communication devices. Mobile cellular networks support mobile phones and many other types of mobile devices such as laptops etc. Mobile devices in networked computing infrastructure 100 are illustrated as mobile phone 104D, laptop 104E, and tablet 104C. A mobile device such as mobile phone 104D may interact with one or more mobile provider networks as the mobile device moves, typically interacting with a plurality of mobile network towers 120, 130, and 140 for connecting to the cellular network 103. Although referred to as a cellular network in
As Illustrated in
Wireless networks may utilize a variety of protocols and communication techniques (e.g., Global System for Mobile Communications (GSM) based cellular network) wireless fidelity Wi-Fi networks, Bluetooth, Near Field Communication (NFC), and/or other suitable radio-based networks as would be appreciated by one of ordinary skill in the art upon viewing this disclosure. Network 108 may also employ any number of network communication protocols, such as Transmission Control Protocol (TCP) and Internet Protocol (IP). Although not explicitly shown in
In
For example, by utilizing backend cloud or server resources platform/network 110, users of client devices 104A-E may be able to build and execute applications, such as automated processes for various enterprise, IT, and/or other organization-related functions. In one example, backend cloud or server resources platform/network 110 includes one or more data centers 112, where each data center server instance 114 could correspond to a different geographic location. Each data center server instance 114 may be implemented on a physical computing system, such as a single electronic computing device (e.g., a single physical hardware server) or could be in the form a multi-computing device (e.g., multiple physical hardware servers). Examples of data center server instances 114 include, but are not limited to, a web server instance (e.g., a unitary Apache installation), an application server instance (e.g., unitary Java Virtual Machine), and/or a database server instance (e.g., a unitary MySQL catalog).
As is illustrated in
As also shown in
As illustrated in
Persons of ordinary skill in the art are aware that software programs may be developed, encoded, and compiled in a variety of computing languages for a variety of software platforms and/or operating systems and subsequently loaded and executed by processor 205. In one instance, the compiling process of the software program may transform program code written in a programming language to another computer language such that the processor 205 is able to execute the programming code. For example, the compiling process of the software program may generate an executable program that provides encoded instructions (e.g., machine code instructions) for processor 205 to accomplish specific, non-generic, particular computing functions.
After the compiling process, the encoded instructions may then be loaded as computer executable instructions or process steps to processor 205 from storage 220, from memory 210, and/or embedded within processor 205 (e.g., via a cache or on-board ROM). Processor 205 may be configured to execute the stored instructions or process steps in order to perform instructions or process steps to transform the computing device into a non-generic, particular, specially programmed machine or apparatus. Stored data, e.g., data stored by a storage device 220, may be accessed by processor 205 during the execution of computer executable instructions or process steps to instruct one or more components within the computing device 200.
A user interface (e.g., output devices 215 and input devices 230) can include a display, positional input device (such as a mouse, touchpad, touchscreen, or the like), keyboard, or other forms of user input and output devices. The user interface components may be communicatively coupled to processor 205. When the output device is or includes a display, the display can be implemented in various ways, including by a liquid crystal display (LCD) or a cathode-ray tube (CRT) or light emitting diode (LED) display, such as an OLED display. Persons of ordinary skill in the art are aware that the computing device 200 may comprise other components well known in the art, such as sensors, powers sources, and/or analog-to-digital converters, not explicitly shown in
As mentioned above, this disclosure presents a multi-edit capability that allows a user (e.g., network administrator) to simultaneously view and edit multiple text-based configuration files. In some implementations, the presentation format allows the user to view similarities and differences through a stacked text presentation. In this example implementation, text that is the same across all files may be shown once as common stacked text while text that is different across some files may be shown as a textual variable or textual overlay. Textual variables, when present, may be expanded to view and edit the individual file values associated with the variable. In use, to make a corresponding part of all underlying files the same, changes may be made to the common stacked text. Alternatively, to introduce differences across the files, textual variables may be inserted, and individual file values may be edited. In cases where a user wishes to remove a difference across files, the textual variable may be replaced with common stacked text that will affect all underlying files. In some implementations, the scope of the editor (e.g., files shown and affected by editing) may be temporarily limited, for example, by dynamically selecting a subset of the files for viewing and editing operations.
Thus, the disclosed multi-editor represents an improvement to the art of network configuration and administration by providing an intuitive and concise presentation that enables a network administrator to see the similarities and differences across multiple configuration files, each representative of a network device, and the ability to easily change multiple file contents to be the same or different. Further, controlled deployment of changes to configuration parameters to their corresponding devices, and audit tracking of those changes may be provided.
Referring now to
In this example, network configuration data repository 340 is configured to use servers 341 and 342 for maintaining data and performing functions to support a network engineer development environment for network configuration domain 305. Servers 341 and 342 may be configured to maintain data representative of network configuration settings (e.g., parameters) corresponding to individual network devices within network configuration domain 305. This information may be stored logically, for example in a database, and obtained as configuration file representations, or physically as individual files. In either case, the information may be indexed and correlated to support search, update, and deployment capabilities as described herein. That is, individual files may be stored with a one-to-one correspondence to network devices or attributes may be stored within a relational data base such that data may be extracted in a manner to support a proper association with corresponding individual network devices (e.g., a configuration file representation). Block 370 indicates that functions performed by network configuration data repository 340 include, but are not limited to, configuration file indexing; difference identification; parameter correlation; expert systems analysis; variable substitution; and configuration storage, retrieval and deployment. Each of these aspects will be discuss in more detail below.
In the example of
Continuing with
Note that, in practice, there may be hundreds or even thousands of network devices within an actual network configuration domain of a large corporation or enterprise but for simplicity only seven are shown here. In modern corporate networks, most network devices are dedicated switches, routers, or bridges, however, server computers may be configured to perform functions of a network device and may be used in that manner by smaller entities. The concepts of this disclosure are not limited to dedicated network devices and will work advantageously with any existing device configured to support networking functions.
In network configuration domain 305, it is likely that each of the seven network devices will have identical configuration settings for many configuration parameters. For example, there will likely be only one NTP server in the network, and a single DNS master. However, particular parameters may be different on specific devices or groups of devices. For example, all network devices in subnet 1310 may be similarly configured to each other but have differences for certain parameters than the network devices in subnet 2311 (which would each have a set of identical parameters). In a specific case, central router/switch 350 may have at least two interface ports with different IP addresses. All devices in subnet 1310 should be configured to communicate with central router/switch 350 on the first interface port and all devices in subnet 2311 should be configured to communicate with central router/switch 350 on the second interface port. This may be desired to properly load balance data through central router/switch 350 or may be done for security reasons. In any case, network devices within a network configuration domain such as network configuration domain 305 may be expected to have a large degree of overlap with specific reasons and rationale behind any differences in value for a corresponding parameter setting (e.g., different value for a value that corresponds to an NTP server, or DNS master). Because the disclosed network administrator development environment (e.g., multi-edit capability and network configuration data repository) has “knowledge” of network design, variations in values of configuration parameter settings may be properly identified (e.g., as “expected” or “unexpected”) to assist a user managing the network configuration domain.
Referring now to
Block 410 indicates that data may be indexed, correlated and stored in a data repository (e.g., network configuration data repository 340). Block 415 indicates that in addition to standard indexing and correlation techniques, additional techniques that are “network aware” may be used to identify parameters that are expected to be identical across devices and parameters that may be different or required to be unique across devices. Block 420 indicates that “expert systems” techniques, for example machine learning techniques,” may also be applied to the network configuration data. Additionally, connection information, such as a hyperlink of parameters to knowledge base information may also be identified as part of the “expert systems” techniques.
Continuing with process 400, once a data repository is configured (e.g., by blocks 405-420), block 425 indicates that a request for multiple device configurations may be received (e.g., from the disclosed multi-editor capability). Block 430 indicates that additional processing may be performed to determine consistent data versus uniform data, for example, to present a multi-editor view. In this context, consistent data refers to data that is expected to be the same and is in fact the same, whereas uniform data refers to data that is expected to be different in some manner and the difference is not more than normal for that type of configuration parameter setting. Uniform data may then be replaced with a “macro variable” so that the variable (possibly highlighted with a visual cue or other indicator) may be presented in the multi-edit view (e.g., a comprehensive editor view for all configuration files within the scope of a current editing session) of multi-editor interface 360 rather than showing a highlighted difference. Finally, differences that are not considered “uniform” may be shown using any one or more of a variety of techniques to bring attention to that data value (see
Block 435 indicates that user input may be received to alter a data value (e.g., network configuration parameter setting) in one or more devices, for example, because a user edited a value in the multi-editor view. This change may represent a correction of an identified erroneous configuration setting or may simply be a change to “consistent” data that is to be applied across all associated network devices concurrently (e.g., configuration change).
After a set of configuration changes or data value corrections has been identified, block 440 indicates that the system administrator may wait for a pre-defined “maintenance window” in which he is allowed to alter the network configuration. Block 445 indicates that changes may be deployed, from network configuration data repository 340 for example, to a running configuration for each affected network device. Once applied, the network may be monitored to determine if it is functioning acceptably after the change.
Block 450 indicates that the network may be allowed to stabilize after changes because, in some cases, even though changes were applied concurrently, it may take some time for the network to “understand” the configuration changes applied. Block 455 indicates that, if everything is working as expected in the network, changes may be “committed” to network devices by altering their startup configuration settings. Alternatively, if an error occurs (or unexpected results) a rollback may be performed by re-deployment of previous configuration parameter settings to the running configuration or even by initiating a restart of network devices. As explained above, a restart of a network device will cause that device to purge its running configuration and reload from its startup configuration.
Block 460 indicates that the data repository may be updated to reflect the actions performed in this deployment. Block 465 indicates that any change log or audit trail information may also be stored to reflect the time of change, what was changed, and to track who initiated the changes, for example. Additionally, each update (either deployment or commit/save) to a network device may result in a status return that Indicates whether the network device was able to accept the supplied change to configuration. Further, as part of blocks 460 or 465, each network device that was affected may be queried to retrieve its current running (or startup) configuration parameters to verify that they reflect identical information with respect to what was sent to them in the update(s).
Block 510 illustrates text in a “soft” representation to indicate that this information may be present in only one (or very few) of the underlying files associated with this view. The NTP server line with element 515 includes both bold overlaid text and, inside element 515, indications of different characters for at least some of the underlying configuration files. Element 520 again begins with bold text indicating that the first portion of this line is identical across all underlying configuration files and ends with element 525 in a “softer” text indicating that this portion stating “community aruba123” is only contained in a subset of all underlying files. Finally, the portion identified by element 530 shows that “vlan 1” has some files that are consistent while others are not consistent and contain extra information (i.e., 900-902 at the end of the line). Screenshot 500 represents an overlay method that may be combined with one or more other visual indicators (see
Referring now to
Element 610 illustrates a uniform has been identified and the underlying data has been replaced with the macro variable “rate.” In this case, the macro variable is further highlighted because at least one of the underlying files does not have an identical value to the other four routers that are within the scope of this edit session. As illustrated in pop-up dialog 615, it is router 2 that has a value of 600 rather than 6000 as is configured in every other router shown.
Referring now to
Element 620 indicates that the “rate” variable has been removed because it is no longer necessary and is replaced with information reflecting the consistent value 6000 for all four routers (i.e., 1, 3, 4, and 5) within the current scope of this edit session. As will be understood, the scope of the edit session affects the presentation format and also affects how changes to data within an edit session will be applied to the underlying configuration information. Only devices for which the scope of the session is set will “participate” in the edit session at that time.
As explained above, data within a configuration repository may be indexed and thus may be searched by regular expressions (e.g., *-rt-* may return all routers) or other search criteria in order to assist in setting a proper scope for an edit session. For example, the system administrator may provide a search string and the multi-editor may provide a view that includes all devices matching that search criteria with all devices selected and participating in the scope of the edit session until such time as a user may refine the search or de-select the devices corresponding checkbox. As an option, a system administrator may include a “draft” configuration within the scope of an edit session. Recall, that a draft configuration is a configuration that does not represent an actual device and may be considered as a kind of master template for configuration settings.
There may be different draft configurations stored within a data repository for different types of network devices, for example. Use of a draft configuration may assist in configuring new devices or ensuring that existing devices maintain conformance with an overall network configuration design. Further, if a change is made in which a draft configuration is within the scope of the edit session, that edit session may automatically update the draft configuration so that future use of the draft will include current information.
Referring now to
Referring to
In some example implementations, multiple individual editing sessions may be performed prior to deployment of changes within the network configuration domain. In this manner, multiple editing sessions of varying scope may be performed to adjust network configuration parameter settings across different sets or different types of network devices. The sum of the scope of each of these multiple editing sessions may be thought of as a “collective scope.” As a result, the changes from the multiple editing sessions may be deployed as a single update to the network configuration domain (e.g., at the next appropriate maintenance window).
Referring now to
Note that the knowledge system of the configuration data repository may identify macro variables for items that have only one occurrence within the current scope of an editing session. Line 12 represents the next line in the current edit view across three files that is different. Line 12 represents the ‘ntp server . . . ’ configuration line. In this case, there are two (of the 3) files that have this line and one file does not have this line. This situation is highlighted by the annotation on the right noting ‘(2/3)’. Because some implementations may need to be able to scale up to many files, numbers may be shown when more than 1 file has the same information, but not all the files (e.g., 993/1000). Device names may also be placed in a preface line (small text above the line as shown by element 720 for lines 12 and 38). In this case, the preface text for both lines 12 and 38 is ‘device-100, device-200’. This preface line may be collapsed by default, so an administrator would only see the blue background and the right annotation-indicating this line is not in all files, and how many have it. To show the preface line, the system administrator might click on a ‘+’ sign on that line (not shown in
Turning to
Certain terms have been used throughout this description and claims to refer to particular system components. As one skilled in the art will appreciate, different parties may refer to a component by different names. This document does not intend to distinguish between components that differ in name but not function. In this disclosure and claims, the terms “including” and “comprising” are used in an open-ended fashion, and thus should be interpreted to mean “including, but not limited to . . . .” Also, the term “couple” or “couples” is intended to mean either an indirect or direct wired or wireless connection. Thus, if a first device couples to a second device, that connection may be through a direct connection or through an indirect connection via other devices and connections. The recitation “based on” is intended to mean “based at least in part on.” Therefore, if X is based on Y, X may be a function of Y and any number of other factors.
The above discussion is meant to be illustrative of the principles and various implementations of the present disclosure. Numerous variations and modifications will become apparent to those skilled in the art once the above disclosure is fully appreciated. It is Intended that the following claims be interpreted to embrace all such variations and modifications.
This application is related to U.S. patent application Ser. No. ______, entitled “System and Method to Provide Network Insights for Correct and Efficient Network Configuration,” by Charles F. Clark, et al., filed concurrently herewith, which is hereby incorporated by reference in its entirety for all applicable purposes. This application is also related to U.S. patent application Ser. No. ______, entitled, “System and Method for Validating Correctness of Changes to Network Device Configurations,” by Charles F. Clark, et al., filed concurrently herewith, which is hereby incorporated by reference in its entirety for all applicable purposes.