[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

US20210224054A1 - Updating an edge computing device - Google Patents

Updating an edge computing device Download PDF

Info

Publication number
US20210224054A1
US20210224054A1 US17/301,572 US202117301572A US2021224054A1 US 20210224054 A1 US20210224054 A1 US 20210224054A1 US 202117301572 A US202117301572 A US 202117301572A US 2021224054 A1 US2021224054 A1 US 2021224054A1
Authority
US
United States
Prior art keywords
disk image
system disk
location
computing device
boot
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US17/301,572
Inventor
Deepanjyoti Sarkar
Kanika GOYAL
Devidas Joshi
Vikas Kumar
Andrea D'Amato
Srikanth Kumar KOVURI RAJAIAH
Ravindra Mysore Seetharam
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Microsoft Technology Licensing LLC
Original Assignee
Microsoft Technology Licensing LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Microsoft Technology Licensing LLC filed Critical Microsoft Technology Licensing LLC
Priority to US17/301,572 priority Critical patent/US20210224054A1/en
Assigned to MICROSOFT TECHNOLOGY LICENSING, LLC reassignment MICROSOFT TECHNOLOGY LICENSING, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: JOSHI, DEVIDAS, SEETHARAM, Ravindra Mysore, KUMAR, VIKAS, SARKAR, Deepanjyoti, GOYAL, Kanika, D'AMATO, ANDREA, KOVURI RAJAIAH, Srikanth Kumar
Publication of US20210224054A1 publication Critical patent/US20210224054A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/61Installation
    • G06F8/63Image based installation; Cloning; Build to order
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1415Saving, restoring, recovering or retrying at system level
    • G06F11/1433Saving, restoring, recovering or retrying at system level during software upgrading
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/61Installation
    • G06F8/62Uninstallation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/4401Bootstrapping
    • G06F9/4416Network booting; Remote initial program loading [RIPL]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44536Selecting among different versions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45562Creating, deleting, cloning virtual machine instances
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45579I/O management, e.g. providing access to device drivers or storage
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/815Virtual

Definitions

  • Examples are disclosed that relate to updating system software of a computing device configured to be located at a network edge between a local network and a cloud service.
  • One disclosed example provides a method comprising booting into a system disk image at a boot location, and receiving and storing an updated system disk image from a server computing device. The method further comprises changing the boot location from a location of the system disk image to a location of the updated system disk image and booting into the updated system disk image.
  • FIG. 1 shows a block diagram of an example computing environment comprising an edge computing device between a local network and a cloud service.
  • FIG. 2 shows a block diagram of an example edge computing device.
  • FIG. 3 shows a block diagram of an example host computing device comprising a virtual machine.
  • FIG. 4 illustrates an example of a cluster of computing devices configured to be located at a network edge between a local network and a cloud service.
  • FIGS. 5A-5B show a flow diagram depicting an example method for updating system software of a computing device.
  • FIG. 6 shows a flow diagram depicting an example method for initially setting up a virtual edge computing device.
  • FIG. 7 shows a block diagram of an example computing system.
  • a networked computing environment may comprise distributed server systems that enable data to be stored and processed in a computing “cloud” system accessible by client devices over a wide area network.
  • Such environments also may include “edge” computing devices that are located at an interface of a local area network (LAN) and a wide area network (WAN), such as the internet.
  • An edge computing device may help manage uploads/downloads to/from cloud services in an efficient manner, and may cache uploaded files locally for faster client access to the files.
  • an edge computing device also may include some processing functionality of a cloud service (e.g. classification/machine learning functions), and thus may help to provide for lower latency processing of data and more efficient network bandwidth usage compared to sending the data to the cloud service for processing.
  • Various components of a LAN may be configured to receive updates to software and firmware from a remote server system automatically via computer network.
  • a personal computer (PC) within a LAN may receive updates via an auto-update application that communicates with a remote update service in the cloud.
  • the auto-update application on the PC communicates with the cloud service to download the updates, and also may manage installation of the updates.
  • the updates may be provided as individual binary files configured to replace specific older binaries on the PC.
  • various software and/or firmware components of the PC may be updated at different times and at different rates.
  • an update process may pose various issues. For example, due the different times and frequencies at which different software and/or firmware components may be updated, compatibility issues may arise. Further, a computing device may not work properly if any updates are only partially installed. Additionally, when problems with an update arise, it may be difficult to identify and roll back individual updates to correct the issues. Also, a computing device may operate more slowly or be unavailable while the updates are installed. In addition, a software binary update mechanism may not handle entire operating system updates well. For example, updating the edge computing device from a first version of a server operating system to a second version of the server operating system may be difficult. As an edge computing device is configured to act as a seamless extension of cloud functionality at a location physically closer to the user than a cloud data center, any such performance issues may negatively impact a user experience.
  • an updated system disk image may be obtained from a server computing device and stored on the computing device, wherein the updated system disk image has been tested to help ensure compatibility of components on the image and expected performance.
  • a boot location then may be changed to a location of the updated system disk image, and the computing device may then boot into the updated system disk image.
  • the download of an entire disk image allows the computing device to conveniently be updated with a full stack of well-tested, updated software.
  • FIG. 1 shows an example computing environment including an edge computing device 102 located at a network edge between a local area network (LAN) 104 and a cloud service 106 .
  • the edge computing device 102 may reside at any suitable location between the LAN 104 and the cloud service 106 , such as in a server rack of the LAN 104 or other suitable location on the customer's physical premises, at a cell tower, a WiFi hotspot, and/or an intermediate data center between the local network and the cloud service, as examples.
  • the edge computing device 102 may be configured to complement the cloud service 106 by providing one or more services at the network edge.
  • the edge computing device 102 may provide storage or data processing services to one or more client-side devices 108 , which may include as workstations (e.g. PCs), internet of things (IoT) devices (e.g. camera systems and/or other sensors), and/or or mobile computing devices.
  • the edge computing device 102 may be configured as a local cache for managing the uploading and downloading of data to/from the cloud, and may be configured to perform some data processing tasks locally.
  • the edge computing device 102 also may be configured to provide storage tiering, data backup, and/or any other suitable services. By providing such services at the network edge, the edge computing device 102 may reduce latency between the cloud service 106 and the client-side devices 108 and provide continuity-of-service during lapses in connectivity with the cloud, among other advantages.
  • FIG. 2 shows a block diagram of an edge computing device 202 (which may represent edge computing device 102 ) that has obtained a software and/or firmware update.
  • the edge computing device 202 comprises a processor 204 and one or more physical storage devices, such as first storage device 206 and second storage device 216 , among other possible components.
  • the first storage device 206 comprises an image partition 210 storing one or more bootable system images, such as system disk image 212 and updated system disk image 214 .
  • the edge computing device 202 may boot into the system disk image 212 .
  • the updated system disk image 214 is obtained, and the boot location is changed to the location of the updated system disk image 214 .
  • the system then reboots into the updated system disk image 214 .
  • the edge computing device 202 may include multiple physical hardware storage devices, an example of which is depicted in FIG. 2 as second storage device 216 .
  • the second storage device 216 may be used to store user files 218 and/or client settings 220 . In this manner, any errors encountered on the first storage device 206 may be isolated so as not to affect the user files 218 or the client settings 220 .
  • image partition 210 is a partition of a physical disk and is configured to boot a physical device.
  • the image partition may reside on a virtual hard disk and may be configured to boot a virtual machine installed on a suitable computing device.
  • FIG. 3 depicts a block diagram of a virtual machine host device 302 , such as a hypervisor host.
  • the virtual machine host 302 is configured to boot a virtual edge device 308 into a basic OS 310 located on a first virtual storage device 306 .
  • the host 302 is also configured to mount an image partition 312 of the first virtual storage device 306 as a virtual hard disk (VHD) for the virtual edge device 308 .
  • VHD virtual hard disk
  • the virtual edge device 308 may operate in a manner analogous to the edge computing device 202 of FIG. 2 to enable any suitable physical computing device to operate as the edge computing device 302 .
  • the image partition 312 may be analogous to the image partition 210 in the example of FIG. 2 .
  • the image partition 312 may host one or more bootable disk images, such as a system disk image 314 and an updated system disk image 316 (downloaded as an update, for example), analogous to the system disk image 212 and the updated system disk image 214 in the example of FIG. 2 .
  • the virtual edge device 308 may be configured to boot into the basic OS 310 .
  • the basic OS 310 may be configured to change a boot location of the virtual edge device 308 to boot into the system disk image 314 a first time the virtual edge device 308 is set up. Then, for updates, an OS running inside the system disk image 314 downloads the updated system disk image 316 and swaps the boot location of the virtual edge device 308 to the updated image 316 .
  • the virtual edge device 308 may include multiple virtual storage devices. One example is depicted in FIG. 3 as second storage device 320 .
  • the second storage device 320 may be used to store user files 324 and/or client settings 328 for the virtual edge device 308 .
  • the virtual edge device 308 also comprises a processor 304 .
  • a cluster 402 of computing devices 404 may operate as an edge computing device, wherein each of the computing devices 404 may be referred to as an edge device node.
  • the cluster 402 is located at a network edge between a LAN 406 and a cloud service 408 , analogous to the edge computing device 102 of FIG. 1 .
  • each individual computing device 404 may be structurally analogous to the computing devices 202 and/or 302 in the examples of FIG. 2 and FIG. 3 , respectively.
  • the use of such a cluster may allow computer resource usage to be dynamically scaled according to client need, and provide redundancy in data storage, among other possible advantages.
  • the cluster 402 may be configured to complement the cloud service 408 by providing one or more services at the network edge to one or more client-side devices 410 , such as workstations in the customer's office, internet of things (IoT) devices (e.g. cameras and/or other sensors), and/or mobile computing devices.
  • client-side devices 410 such as workstations in the customer's office, internet of things (IoT) devices (e.g. cameras and/or other sensors), and/or mobile computing devices.
  • one node of the cluster 402 may be configured as an orchestrator 414 to manage one or more other nodes 404 .
  • the orchestrator 414 may be similar or identical to each of the nodes 404 from a hardware standpoint, but may include software executable to exercise control over various aspects of the other nodes of the cluster 402 .
  • the orchestrator 414 may coordinate an updating process between the cluster 402 and an update server 412 .
  • Updating the cluster 402 may present various challenges compared to updating a single edge device. For example, if updating of the cluster is not commonly controlled, two or more nodes 404 may end up booting into different versions of the system disk image, thereby giving rise to compatibility issues between the different nodes of the cluster. Accordingly, the orchestrator 414 may be configured to orchestrate the updating of the nodes 404 in the cluster 402 to help ensure that each node is configured to boot into the same version of the system disk image.
  • FIGS. 5A-5B show a flow diagram depicting an example method 500 for updating system software of a computing device.
  • the following description of method 500 is provided with reference to the software and hardware components described above and shown in FIGS. 1-4 , but it will be appreciated that method 500 also may be performed in other contexts using other suitable hardware and software components.
  • method 500 includes booting into a system disk image at a boot location.
  • booting the edge computing device 202 may comprise booting a physical edge computing device 202 into the system disk image 212 located within an image partition 210 .
  • method 500 may include booting a virtual edge computing device into a system disk image stored on a virtual hard disk hosted by a physical machine.
  • an edge computing device may be implemented via any suitable arrangement of physical and virtual machines.
  • Method 500 further includes, at 506 , receiving an updated system disk image from a server computing device and storing the updated system disk image.
  • the updated system disk image may comprise a full updated stack with consistent and well-tested dependencies, which may help ensure software and firmware compatibility.
  • the edge computing device 202 may receive the updated system disk image 214 from a server computing device, such as the update server 110 of FIG. 1 , and store the updated system disk image 214 in a new directory within the image partition 210 on the first storage device 206 .
  • a server computing device such as the update server 110 of FIG. 1
  • user files may be stored on a different physical storage device than a physical storage device storing the system disk image and the updated system disk image.
  • client settings also may be stored on a different physical storage device than that used to store the system disk image and updated system disk image, as indicated at 510 .
  • the edge computing device may act as an orchestrator and instruct one or more other computing devices of the cluster to obtain a specified system disk image version, as indicated at 512 . It will be appreciated that this may be the most recently updated system disk image or may be an older version of the system disk image. For example, some updates may run successfully on some nodes, but not on others. As it may be desirable for all the nodes of the cluster to be consistent, the orchestrator may instruct all other nodes of the cluster to use a prior system disk image to help ensure that each node of the cluster is operating using the same prior system disk image.
  • method 500 may include, at 514 , receiving, from another computing device of the cluster of computing devices (e.g. an orchestrator device), an instruction to obtain a specific version of the updated system disk image.
  • the edge computing device may then obtain and store the specific version of the updated system disk image as described above with reference to process 512 .
  • method 500 includes changing the boot location from a location of the system disk image to a location of the updated system disk image.
  • the boot location of the physical edge computing device 202 itself may be changed.
  • changing the boot location may comprise changing the boot location of the virtual machine 310 .
  • method 500 includes booting into the updated system disk image.
  • the edge computing device 202 may boot directly into the updated system disk image 214 , or the virtual edge device 308 may boot into the updated system disk image 316 .
  • the edge computing device may access a uniform, updated stack provided by the updated system disk image, avoiding potential disruptions associated with installing individual updates.
  • method 500 includes receiving an instruction to roll back updates contained within the updated system disk image. For example, if an error arising from the updated system disk occurs during or after booting into the updated system disk image, it may be less disruptive for the edge computing device to resume booting into an older version of the system disk image. Accordingly, in some examples, a server computing device operated by the service provider, a LAN administrator, or other entity may instruct the edge computing device to roll back the updates. In other examples, at 522 , the instruction may be automatically generated via a program on the edge computing device itself when the computing device encounters an error during or after booting into the updated system disk image. For example, the system disk image, the updated system disk image, and/or the basic OS may include an executable that may detect potential errors and instruct the edge device to roll back the updates if an error is detected.
  • the instruction may be provided by an orchestrator device.
  • method 500 may include, at one node of a cluster of computing devices, instructing one or more computing devices of the cluster of computing devices to roll back updates contained within the updated system disk image.
  • the updated system may run correctly on some of the computing devices 404 in the example of FIG. 4 , but not on others.
  • the orchestrator 414 may be configured to instruct one or more of the computing devices 404 booting into the updated system disk image to roll back the updates to an older version of the system disk image. In this manner, the orchestrator 414 may ensure that each node of the cluster may boot into the same version of the system disk image.
  • method 500 may comprise, at one node of a cluster of computing devices, receiving, from another computing device of the cluster of computing devices, an instruction to roll back updates contained within the updated system disk image, as indicated at 526 .
  • one of the computing devices 404 may receive this instruction from the orchestrator 414 .
  • method 500 further comprises, based on receiving the instruction to roll back the updates, changing the boot location from the location of the updated system disk image to the location of the system disk image. It will be appreciated that the boot location may be changed in a similar manner as described above regarding process 516 . In this manner, the edge computing device may quickly access the stack contained within the system disk image.
  • the edge computing device may either retain or delete one or more previous versions of the system disk image after successfully booting into the updated system disk image. Retaining a previous version allows updates to be rolled back to a previous version of the system disk image without downloading or otherwise obtaining the previous version of the system disk image from another storage location, but does utilize storage space for each prior system disk image. As such, in some examples, a single prior version (e.g. an immediately prior version) of the image may be retained.
  • method 500 includes booting into the system disk image.
  • the edge computing device then utilizes a previous version of the stack installed on the system disk image. In this manner, the updates may be quickly and uniformly rolled back, which may ensure consistency between different edge computing devices and reduce disruptions experienced by the customer.
  • FIG. 6 shows an example method 600 for initially setting up a virtual edge computing device as a virtual machine.
  • Method 600 includes, at 602 , receiving an initialization disk image, e.g. by downloading the initialization disk image from a cloud service.
  • the method 600 may include mounting the initialization disk image as a virtual disk.
  • the initialization disk image 312 may be mounted as a VHD in the example of FIG. 3 .
  • the initialization disk image comprises an operating system partition and an image partition, the image partition comprising the system disk image.
  • Method 600 further comprises, at 606 , booting into the operating system partition, and then at 608 changing the boot location from a location of the operating system partition to the location of the system disk image.
  • the methods and processes described herein may be tied to a computing system of one or more computing devices.
  • such methods and processes may be implemented as a computer-application program or service, an application-programming interface (API), a library, and/or other computer-program product.
  • API application-programming interface
  • FIG. 7 schematically shows a non-limiting embodiment of a computing system 700 that can enact one or more of the methods and processes described above.
  • Computing system 700 is shown in simplified form.
  • Computing system 700 may take the form of one or more personal computers, server computers, tablet computers, home-entertainment computers, network computing devices, gaming devices, mobile computing devices, mobile communication devices (e.g., smart phone), and/or other computing devices.
  • the computing devices 102 , 202 , 302 , and 404 , the orchestrator 414 , and/or the client-side devices 108 and 410 may comprise aspects of the computing system 700 .
  • Computing system 700 includes a logic machine 702 and a storage machine 704 .
  • Computing system 700 may optionally include a display subsystem 706 , input subsystem 708 , communication subsystem 710 , and/or other components not shown in FIG. 7 .
  • Logic machine 702 includes one or more physical devices configured to execute instructions.
  • the logic machine may be configured to execute instructions that are part of one or more applications, services, programs, routines, libraries, objects, components, data structures, or other logical constructs.
  • Such instructions may be implemented to perform a task, implement a data type, transform the state of one or more components, achieve a technical effect, or otherwise arrive at a desired result.
  • the logic machine may include one or more processors configured to execute software instructions. Additionally or alternatively, the logic machine may include one or more hardware or firmware logic machines configured to execute hardware or firmware instructions. Processors of the logic machine may be single-core or multi-core, and the instructions executed thereon may be configured for sequential, parallel, and/or distributed processing. Individual components of the logic machine optionally may be distributed among two or more separate devices, which may be remotely located and/or configured for coordinated processing. Aspects of the logic machine may be virtualized and executed by remotely accessible, networked computing devices configured in a cloud-computing configuration.
  • Storage machine 704 includes one or more physical devices configured to hold instructions executable by the logic machine to implement the methods and processes described herein. When such methods and processes are implemented, the state of storage machine 704 may be transformed—e.g., to hold different data.
  • Storage machine 704 may include removable and/or built-in devices.
  • Storage machine 704 may include optical memory (e.g., CD, DVD, HD-DVD, Blu-Ray Disc, etc.), semiconductor memory (e.g., RAM, EPROM, EEPROM, etc.), and/or magnetic memory (e.g., hard-disk drive, floppy-disk drive, tape drive, MRAM, etc.), among others.
  • Storage machine 704 may include volatile, nonvolatile, dynamic, static, read/write, read-only, random-access, sequential-access, location-addressable, file-addressable, and/or content-addressable devices.
  • storage machine 704 includes one or more physical devices.
  • aspects of the instructions described herein alternatively may be propagated by a communication medium (e.g., an electromagnetic signal, an optical signal, etc.) that is not held by a physical device for a finite duration.
  • a communication medium e.g., an electromagnetic signal, an optical signal, etc.
  • logic machine 702 and storage machine 704 may be integrated together into one or more hardware-logic components.
  • Such hardware-logic components may include field-programmable gate arrays (FPGAs), program- and application-specific integrated circuits (PASIC/ASICs), program- and application-specific standard products (PSSP/ASSPs), system-on-a-chip (SOC), and complex programmable logic devices (CPLDs), for example.
  • FPGAs field-programmable gate arrays
  • PASIC/ASICs program- and application-specific integrated circuits
  • PSSP/ASSPs program- and application-specific standard products
  • SOC system-on-a-chip
  • CPLDs complex programmable logic devices
  • program may be used to describe an aspect of computing system 700 implemented to perform a particular function.
  • a program may be instantiated via logic machine 702 executing instructions held by storage machine 704 . It will be understood that different programs may be instantiated from the same application, service, code block, object, library, routine, API, function, etc. Likewise, the same program may be instantiated by different applications, services, code blocks, objects, routines, APIs, functions, etc.
  • program may encompass individual or groups of executable files, data files, libraries, drivers, scripts, database records, etc.
  • a “service”, as used herein, is an application program executable across multiple user sessions.
  • a service may be available to one or more system components, programs, and/or other services.
  • a service may run on one or more server-computing devices.
  • display subsystem 706 may be used to present a visual representation of data held by storage machine 704 .
  • This visual representation may take the form of a graphical user interface (GUI).
  • GUI graphical user interface
  • Display subsystem 706 may include one or more display devices utilizing virtually any type of technology. Such display devices may be combined with logic machine 702 and/or storage machine 704 in a shared enclosure, or such display devices may be peripheral display devices.
  • input subsystem 708 may comprise or interface with one or more user-input devices such as a keyboard, mouse, touch screen, or game controller.
  • the input subsystem may comprise or interface with selected natural user input (NUI) componentry.
  • NUI natural user input
  • Such componentry may be integrated or peripheral, and the transduction and/or processing of input actions may be handled on- or off-board.
  • NUI componentry may include a microphone for speech and/or voice recognition; an infrared, color, stereoscopic, and/or depth camera for machine vision and/or gesture recognition; a head tracker, eye tracker, accelerometer, and/or gyroscope for motion detection and/or intent recognition; as well as electric-field sensing componentry for assessing brain activity.
  • communication subsystem 710 may be configured to communicatively couple computing system 700 with one or more other computing devices.
  • Communication subsystem 710 may include wired and/or wireless communication devices compatible with one or more different communication protocols.
  • the communication subsystem may be configured for communication via a wireless telephone network, or a wired or wireless local- or wide-area network.
  • the communication subsystem may allow computing system 700 to send and/or receive messages to and/or from other devices via a network such as the Internet.
  • Another example provides, on a computing device configured to be located at a network edge between a local network and a cloud service, a method for updating system software of the computing device, the method comprising: booting into a system disk image at a boot location, receiving, from a server computing device, an updated system disk image and storing the updated system disk image, changing the boot location from a location of the system disk image to a location of the updated system disk image, and booting into the updated system disk image.
  • the method may additionally or alternatively include storing user files on a different physical storage device than a physical storage device storing the system disk image and the updated system disk image.
  • the method may additionally or alternatively include storing client settings on a different physical storage device than a physical storage device storing the system disk image and the updated system disk image.
  • Booting into the system disk image at the boot location may additionally or alternatively include booting a virtual machine into the system disk image.
  • the method may additionally or alternatively include, before booting into the system disk image at the boot location, installing the system disk image by receiving an initialization disk image, the initialization disk image comprising an operating system partition and an image partition, the image partition comprising the system disk image, booting into the operating system partition, and changing the boot location from a location of the operating system partition to the location of the system disk image.
  • the method may additionally or alternatively include mounting the initialization disk image as a virtual disk.
  • the method may additionally or alternatively include receiving an instruction to roll back updates contained within the updated system disk image, based on receiving the instruction to roll back the updates, changing the boot location from the location of the updated system disk image to the location of the system disk image, and booting into the system disk image.
  • Receiving the instruction to roll back the updates may additionally or alternatively include receiving an instruction to automatically to roll back the updates if the computing device encounters an error during or after booting into the updated system disk image.
  • the computing device may additionally or alternatively include one node of a cluster of computing devices.
  • the method may additionally or alternatively include instructing one or more computing devices of the cluster of computing devices to boot into a specified system disk version.
  • the method may additionally or alternatively include receiving, from another computing device of the cluster of computing devices, an instruction to boot into a specified system disk version.
  • a computing device comprising a processor, and a storage device storing instructions executable by the processor to receive an initialization disk image, the initialization disk image comprising an operating system partition and an image partition, the image partition comprising a system disk image, boot into the operating system partition, change a boot location from a location of the operating system partition to a location of the system disk image, boot into the system disk image, receive an updated system disk image, change the boot location from the location of the system disk image to a location of the updated system disk image, and boot into the updated system disk image.
  • Booting into the operating system partition may additionally or alternatively include booting a virtual machine into the operating system partition
  • changing the boot location may additionally or alternatively include changing the boot location of the virtual machine.
  • the instructions may additionally or alternatively be executable to mount the initialization disk image as a virtual disk.
  • the instructions may additionally or alternatively be executable to receive an instruction to roll back updates contained within the updated system disk image, based on receiving the instruction to roll back the updates, change the boot location from the location of the updated system disk image to the location of the system disk image, and boot into the system disk image.
  • the instructions may additionally or alternatively be executable to automatically roll back the updates if the computing device encounters an error during or after booting into the updated system disk image.
  • the instructions may additionally or alternatively be executable to instruct one or more other computing devices of a cluster of computing devices to boot into a specified system disk image version.
  • the instructions may additionally or alternatively be executable to receive, from another computing device of a cluster of computing devices, an instruction to boot into a specified system disk image version.
  • Another aspect provides a computing device configured to orchestrate updating system software on a plurality of computing devices of a cluster of computing devices, the computing device comprising a processor, and a storage device storing instructions executable by the processor to configure a boot location for each computing device of the plurality of computing devices to boot into a location of a system disk image, receive an updated system disk image, and change the boot location from the location of the system disk image to a location of the updated system disk image such that each computing device of the plurality of computing devices boots into the updated system disk image.
  • the instructions may additionally or alternatively be executable to receive an initialization disk image, the initialization disk image comprising an operating system partition and an image partition, the image partition comprising the system disk image, configure the boot location for each computing device of the plurality of computing devices to boot into a location of the operating system partition, and change the boot location from the location of the operating system partition to the location of the system disk image such that each computing device of the plurality of computing devices boots into the system disk image.
  • the instructions may additionally or alternatively be executable to instruct each computing device of the plurality of computing devices to boot into a specified system disk image version.

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Security & Cryptography (AREA)
  • Quality & Reliability (AREA)
  • Stored Programmes (AREA)

Abstract

Examples are disclosed that relate to updating system software of a computing device located at a network edge between a local network and a cloud service. One disclosed example provides a method comprising booting into a system disk image at a boot location, receiving and storing an updated system disk image from a server computing device. The method further comprises changing the boot location from a location of the system disk image to a location of the updated system disk image and booting into the updated system disk image.

Description

    CROSS REFERENCE TO RELATED APPLICATIONS
  • This application is a continuation from U.S. patent application Ser. No. 16/224,480 filed Dec. 18, 2018, which claims priority to U.S. Provisional patent Application Ser. No. 62/733,907, filed Sep. 20, 2018, and entitled “UPDATING AN EDGE COMPUTING DEVICE”, the entirety of each of which is hereby incorporated by reference for all purposes.
  • BACKGROUND
  • Many types of computing devices receive updates to software and/or firmware by download over computer networks, wherein the updates are in the form of individual binary files configured to replace prior versions of those files.
  • SUMMARY
  • Examples are disclosed that relate to updating system software of a computing device configured to be located at a network edge between a local network and a cloud service. One disclosed example provides a method comprising booting into a system disk image at a boot location, and receiving and storing an updated system disk image from a server computing device. The method further comprises changing the boot location from a location of the system disk image to a location of the updated system disk image and booting into the updated system disk image.
  • This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter. Furthermore, the claimed subject matter is not limited to implementations that solve any or all disadvantages noted in any part of this disclosure.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 shows a block diagram of an example computing environment comprising an edge computing device between a local network and a cloud service.
  • FIG. 2 shows a block diagram of an example edge computing device.
  • FIG. 3 shows a block diagram of an example host computing device comprising a virtual machine.
  • FIG. 4 illustrates an example of a cluster of computing devices configured to be located at a network edge between a local network and a cloud service.
  • FIGS. 5A-5B show a flow diagram depicting an example method for updating system software of a computing device.
  • FIG. 6 shows a flow diagram depicting an example method for initially setting up a virtual edge computing device.
  • FIG. 7 shows a block diagram of an example computing system.
  • DETAILED DESCRIPTION
  • A networked computing environment may comprise distributed server systems that enable data to be stored and processed in a computing “cloud” system accessible by client devices over a wide area network. Such environments also may include “edge” computing devices that are located at an interface of a local area network (LAN) and a wide area network (WAN), such as the internet. An edge computing device may help manage uploads/downloads to/from cloud services in an efficient manner, and may cache uploaded files locally for faster client access to the files. Further, an edge computing device also may include some processing functionality of a cloud service (e.g. classification/machine learning functions), and thus may help to provide for lower latency processing of data and more efficient network bandwidth usage compared to sending the data to the cloud service for processing.
  • Various components of a LAN may be configured to receive updates to software and firmware from a remote server system automatically via computer network. For example, a personal computer (PC) within a LAN may receive updates via an auto-update application that communicates with a remote update service in the cloud. As updates are made available through the cloud-based update service, the auto-update application on the PC communicates with the cloud service to download the updates, and also may manage installation of the updates. The updates may be provided as individual binary files configured to replace specific older binaries on the PC.
  • Under such an update system, various software and/or firmware components of the PC may be updated at different times and at different rates. In the case of an edge computing device, such an update process may pose various issues. For example, due the different times and frequencies at which different software and/or firmware components may be updated, compatibility issues may arise. Further, a computing device may not work properly if any updates are only partially installed. Additionally, when problems with an update arise, it may be difficult to identify and roll back individual updates to correct the issues. Also, a computing device may operate more slowly or be unavailable while the updates are installed. In addition, a software binary update mechanism may not handle entire operating system updates well. For example, updating the edge computing device from a first version of a server operating system to a second version of the server operating system may be difficult. As an edge computing device is configured to act as a seamless extension of cloud functionality at a location physically closer to the user than a cloud data center, any such performance issues may negatively impact a user experience.
  • Accordingly, examples are disclosed that relate to updating computing devices, such as edge computing devices, in a manner that may help to avoid such issues. Briefly, instead of individual updated binaries, an updated system disk image may be obtained from a server computing device and stored on the computing device, wherein the updated system disk image has been tested to help ensure compatibility of components on the image and expected performance. A boot location then may be changed to a location of the updated system disk image, and the computing device may then boot into the updated system disk image. In contrast with piecemeal update methods, the download of an entire disk image allows the computing device to conveniently be updated with a full stack of well-tested, updated software.
  • FIG. 1 shows an example computing environment including an edge computing device 102 located at a network edge between a local area network (LAN) 104 and a cloud service 106. The edge computing device 102 may reside at any suitable location between the LAN 104 and the cloud service 106, such as in a server rack of the LAN 104 or other suitable location on the customer's physical premises, at a cell tower, a WiFi hotspot, and/or an intermediate data center between the local network and the cloud service, as examples.
  • In some examples, the edge computing device 102 may be configured to complement the cloud service 106 by providing one or more services at the network edge. For example, the edge computing device 102 may provide storage or data processing services to one or more client-side devices 108, which may include as workstations (e.g. PCs), internet of things (IoT) devices (e.g. camera systems and/or other sensors), and/or or mobile computing devices. As described above, the edge computing device 102 may be configured as a local cache for managing the uploading and downloading of data to/from the cloud, and may be configured to perform some data processing tasks locally. The edge computing device 102 also may be configured to provide storage tiering, data backup, and/or any other suitable services. By providing such services at the network edge, the edge computing device 102 may reduce latency between the cloud service 106 and the client-side devices 108 and provide continuity-of-service during lapses in connectivity with the cloud, among other advantages.
  • Updates to edge device software and/or firmware may be provided to the edge computing device 102 via a server computing device, such as cloud service 106 or another update server 110. FIG. 2 shows a block diagram of an edge computing device 202 (which may represent edge computing device 102) that has obtained a software and/or firmware update. The edge computing device 202 comprises a processor 204 and one or more physical storage devices, such as first storage device 206 and second storage device 216, among other possible components.
  • The first storage device 206 comprises an image partition 210 storing one or more bootable system images, such as system disk image 212 and updated system disk image 214. Prior to obtaining the updated system disk image 214, the edge computing device 202 may boot into the system disk image 212. During an update, the updated system disk image 214 is obtained, and the boot location is changed to the location of the updated system disk image 214. The system then reboots into the updated system disk image 214.
  • In some examples, the edge computing device 202 may include multiple physical hardware storage devices, an example of which is depicted in FIG. 2 as second storage device 216. The second storage device 216 may be used to store user files 218 and/or client settings 220. In this manner, any errors encountered on the first storage device 206 may be isolated so as not to affect the user files 218 or the client settings 220.
  • In the example of FIG. 2, image partition 210 is a partition of a physical disk and is configured to boot a physical device. In other examples, the image partition may reside on a virtual hard disk and may be configured to boot a virtual machine installed on a suitable computing device. FIG. 3 depicts a block diagram of a virtual machine host device 302, such as a hypervisor host. The virtual machine host 302 is configured to boot a virtual edge device 308 into a basic OS 310 located on a first virtual storage device 306. The host 302 is also configured to mount an image partition 312 of the first virtual storage device 306 as a virtual hard disk (VHD) for the virtual edge device 308. After being set up on the host, the virtual edge device 308 may operate in a manner analogous to the edge computing device 202 of FIG. 2 to enable any suitable physical computing device to operate as the edge computing device 302.
  • The image partition 312 may be analogous to the image partition 210 in the example of FIG. 2. The image partition 312 may host one or more bootable disk images, such as a system disk image 314 and an updated system disk image 316 (downloaded as an update, for example), analogous to the system disk image 212 and the updated system disk image 214 in the example of FIG. 2.
  • As described above, the virtual edge device 308 may be configured to boot into the basic OS 310. The basic OS 310 may be configured to change a boot location of the virtual edge device 308 to boot into the system disk image 314 a first time the virtual edge device 308 is set up. Then, for updates, an OS running inside the system disk image 314 downloads the updated system disk image 316 and swaps the boot location of the virtual edge device 308 to the updated image 316.
  • The virtual edge device 308 may include multiple virtual storage devices. One example is depicted in FIG. 3 as second storage device 320. The second storage device 320 may be used to store user files 324 and/or client settings 328 for the virtual edge device 308. In addition to the virtual storage devices, the virtual edge device 308 also comprises a processor 304.
  • With reference now to FIG. 4, an example computing environment is illustrated in which a cluster 402 of computing devices 404 may operate as an edge computing device, wherein each of the computing devices 404 may be referred to as an edge device node. The cluster 402 is located at a network edge between a LAN 406 and a cloud service 408, analogous to the edge computing device 102 of FIG. 1. However, each individual computing device 404 may be structurally analogous to the computing devices 202 and/or 302 in the examples of FIG. 2 and FIG. 3, respectively. The use of such a cluster may allow computer resource usage to be dynamically scaled according to client need, and provide redundancy in data storage, among other possible advantages.
  • Like the edge computing device 102 example of FIG. 1, the cluster 402 may be configured to complement the cloud service 408 by providing one or more services at the network edge to one or more client-side devices 410, such as workstations in the customer's office, internet of things (IoT) devices (e.g. cameras and/or other sensors), and/or mobile computing devices. In some examples, one node of the cluster 402 may be configured as an orchestrator 414 to manage one or more other nodes 404. The orchestrator 414 may be similar or identical to each of the nodes 404 from a hardware standpoint, but may include software executable to exercise control over various aspects of the other nodes of the cluster 402. For example, the orchestrator 414 may coordinate an updating process between the cluster 402 and an update server 412.
  • Updating the cluster 402 may present various challenges compared to updating a single edge device. For example, if updating of the cluster is not commonly controlled, two or more nodes 404 may end up booting into different versions of the system disk image, thereby giving rise to compatibility issues between the different nodes of the cluster. Accordingly, the orchestrator 414 may be configured to orchestrate the updating of the nodes 404 in the cluster 402 to help ensure that each node is configured to boot into the same version of the system disk image.
  • FIGS. 5A-5B show a flow diagram depicting an example method 500 for updating system software of a computing device. The following description of method 500 is provided with reference to the software and hardware components described above and shown in FIGS. 1-4, but it will be appreciated that method 500 also may be performed in other contexts using other suitable hardware and software components.
  • First referring to FIG. 5A, at 502, method 500 includes booting into a system disk image at a boot location. In some examples, as illustrated in FIG. 2, booting the edge computing device 202 may comprise booting a physical edge computing device 202 into the system disk image 212 located within an image partition 210. In other examples, at 504, method 500 may include booting a virtual edge computing device into a system disk image stored on a virtual hard disk hosted by a physical machine. In yet other examples, an edge computing device may be implemented via any suitable arrangement of physical and virtual machines.
  • Method 500 further includes, at 506, receiving an updated system disk image from a server computing device and storing the updated system disk image. The updated system disk image may comprise a full updated stack with consistent and well-tested dependencies, which may help ensure software and firmware compatibility.
  • In the physical machine update example of FIG. 2, the edge computing device 202 may receive the updated system disk image 214 from a server computing device, such as the update server 110 of FIG. 1, and store the updated system disk image 214 in a new directory within the image partition 210 on the first storage device 206. In such examples, as indicated at 508, user files may be stored on a different physical storage device than a physical storage device storing the system disk image and the updated system disk image. Likewise, client settings also may be stored on a different physical storage device than that used to store the system disk image and updated system disk image, as indicated at 510.
  • Where the edge computing device is one of a cluster of computing devices (virtual or physical), the edge computing device may act as an orchestrator and instruct one or more other computing devices of the cluster to obtain a specified system disk image version, as indicated at 512. It will be appreciated that this may be the most recently updated system disk image or may be an older version of the system disk image. For example, some updates may run successfully on some nodes, but not on others. As it may be desirable for all the nodes of the cluster to be consistent, the orchestrator may instruct all other nodes of the cluster to use a prior system disk image to help ensure that each node of the cluster is operating using the same prior system disk image.
  • Continuing with the cluster example, where the edge computing device is not an orchestrator device, method 500 may include, at 514, receiving, from another computing device of the cluster of computing devices (e.g. an orchestrator device), an instruction to obtain a specific version of the updated system disk image. The edge computing device may then obtain and store the specific version of the updated system disk image as described above with reference to process 512.
  • Referring next to FIG. 5B, having received the updated system disk image, at 516, method 500 includes changing the boot location from a location of the system disk image to a location of the updated system disk image. As described above with reference to FIG. 2, the boot location of the physical edge computing device 202 itself may be changed. In another example, as described above regarding FIG. 3, changing the boot location may comprise changing the boot location of the virtual machine 310.
  • Next, at 518, method 500 includes booting into the updated system disk image. For example, the edge computing device 202 may boot directly into the updated system disk image 214, or the virtual edge device 308 may boot into the updated system disk image 316. In this manner, the edge computing device may access a uniform, updated stack provided by the updated system disk image, avoiding potential disruptions associated with installing individual updates.
  • In some circumstances, it may be desirable to roll back or revert updates installed on the edge computing device to a previous version. Accordingly, at 520, method 500 includes receiving an instruction to roll back updates contained within the updated system disk image. For example, if an error arising from the updated system disk occurs during or after booting into the updated system disk image, it may be less disruptive for the edge computing device to resume booting into an older version of the system disk image. Accordingly, in some examples, a server computing device operated by the service provider, a LAN administrator, or other entity may instruct the edge computing device to roll back the updates. In other examples, at 522, the instruction may be automatically generated via a program on the edge computing device itself when the computing device encounters an error during or after booting into the updated system disk image. For example, the system disk image, the updated system disk image, and/or the basic OS may include an executable that may detect potential errors and instruct the edge device to roll back the updates if an error is detected.
  • In examples that utilize a cluster of computing devices, the instruction may be provided by an orchestrator device. Accordingly, at 524, method 500 may include, at one node of a cluster of computing devices, instructing one or more computing devices of the cluster of computing devices to roll back updates contained within the updated system disk image. For example, the updated system may run correctly on some of the computing devices 404 in the example of FIG. 4, but not on others. In this example, the orchestrator 414 may be configured to instruct one or more of the computing devices 404 booting into the updated system disk image to roll back the updates to an older version of the system disk image. In this manner, the orchestrator 414 may ensure that each node of the cluster may boot into the same version of the system disk image.
  • Likewise, where the computing device is within a cluster but not an orchestrator, method 500 may comprise, at one node of a cluster of computing devices, receiving, from another computing device of the cluster of computing devices, an instruction to roll back updates contained within the updated system disk image, as indicated at 526. For example, one of the computing devices 404 may receive this instruction from the orchestrator 414.
  • At 528, method 500 further comprises, based on receiving the instruction to roll back the updates, changing the boot location from the location of the updated system disk image to the location of the system disk image. It will be appreciated that the boot location may be changed in a similar manner as described above regarding process 516. In this manner, the edge computing device may quickly access the stack contained within the system disk image.
  • As updating the edge computing device is performed by swapping the boot location, in some examples, the edge computing device may either retain or delete one or more previous versions of the system disk image after successfully booting into the updated system disk image. Retaining a previous version allows updates to be rolled back to a previous version of the system disk image without downloading or otherwise obtaining the previous version of the system disk image from another storage location, but does utilize storage space for each prior system disk image. As such, in some examples, a single prior version (e.g. an immediately prior version) of the image may be retained.
  • Continuing, at 530, after the boot location is changed to the system image, method 500 includes booting into the system disk image. The edge computing device then utilizes a previous version of the stack installed on the system disk image. In this manner, the updates may be quickly and uniformly rolled back, which may ensure consistency between different edge computing devices and reduce disruptions experienced by the customer.
  • As described above, in examples where an edge computing device is implemented as a virtual machine, the system disk image may be installed as a virtual hard disk on a host physical computing device. FIG. 6 shows an example method 600 for initially setting up a virtual edge computing device as a virtual machine. Method 600 includes, at 602, receiving an initialization disk image, e.g. by downloading the initialization disk image from a cloud service. As indicated at 604, the method 600 may include mounting the initialization disk image as a virtual disk. For example, the initialization disk image 312 may be mounted as a VHD in the example of FIG. 3.
  • The initialization disk image comprises an operating system partition and an image partition, the image partition comprising the system disk image. Method 600 further comprises, at 606, booting into the operating system partition, and then at 608 changing the boot location from a location of the operating system partition to the location of the system disk image.
  • In some examples, the methods and processes described herein may be tied to a computing system of one or more computing devices. In particular, such methods and processes may be implemented as a computer-application program or service, an application-programming interface (API), a library, and/or other computer-program product.
  • FIG. 7 schematically shows a non-limiting embodiment of a computing system 700 that can enact one or more of the methods and processes described above. Computing system 700 is shown in simplified form. Computing system 700 may take the form of one or more personal computers, server computers, tablet computers, home-entertainment computers, network computing devices, gaming devices, mobile computing devices, mobile communication devices (e.g., smart phone), and/or other computing devices. For example, the computing devices 102, 202, 302, and 404, the orchestrator 414, and/or the client- side devices 108 and 410 may comprise aspects of the computing system 700.
  • Computing system 700 includes a logic machine 702 and a storage machine 704. Computing system 700 may optionally include a display subsystem 706, input subsystem 708, communication subsystem 710, and/or other components not shown in FIG. 7.
  • Logic machine 702 includes one or more physical devices configured to execute instructions. For example, the logic machine may be configured to execute instructions that are part of one or more applications, services, programs, routines, libraries, objects, components, data structures, or other logical constructs. Such instructions may be implemented to perform a task, implement a data type, transform the state of one or more components, achieve a technical effect, or otherwise arrive at a desired result.
  • The logic machine may include one or more processors configured to execute software instructions. Additionally or alternatively, the logic machine may include one or more hardware or firmware logic machines configured to execute hardware or firmware instructions. Processors of the logic machine may be single-core or multi-core, and the instructions executed thereon may be configured for sequential, parallel, and/or distributed processing. Individual components of the logic machine optionally may be distributed among two or more separate devices, which may be remotely located and/or configured for coordinated processing. Aspects of the logic machine may be virtualized and executed by remotely accessible, networked computing devices configured in a cloud-computing configuration.
  • Storage machine 704 includes one or more physical devices configured to hold instructions executable by the logic machine to implement the methods and processes described herein. When such methods and processes are implemented, the state of storage machine 704 may be transformed—e.g., to hold different data.
  • Storage machine 704 may include removable and/or built-in devices. Storage machine 704 may include optical memory (e.g., CD, DVD, HD-DVD, Blu-Ray Disc, etc.), semiconductor memory (e.g., RAM, EPROM, EEPROM, etc.), and/or magnetic memory (e.g., hard-disk drive, floppy-disk drive, tape drive, MRAM, etc.), among others. Storage machine 704 may include volatile, nonvolatile, dynamic, static, read/write, read-only, random-access, sequential-access, location-addressable, file-addressable, and/or content-addressable devices.
  • It will be appreciated that storage machine 704 includes one or more physical devices. However, aspects of the instructions described herein alternatively may be propagated by a communication medium (e.g., an electromagnetic signal, an optical signal, etc.) that is not held by a physical device for a finite duration.
  • Aspects of logic machine 702 and storage machine 704 may be integrated together into one or more hardware-logic components. Such hardware-logic components may include field-programmable gate arrays (FPGAs), program- and application-specific integrated circuits (PASIC/ASICs), program- and application-specific standard products (PSSP/ASSPs), system-on-a-chip (SOC), and complex programmable logic devices (CPLDs), for example.
  • The term “program” may be used to describe an aspect of computing system 700 implemented to perform a particular function. In some cases, a program may be instantiated via logic machine 702 executing instructions held by storage machine 704. It will be understood that different programs may be instantiated from the same application, service, code block, object, library, routine, API, function, etc. Likewise, the same program may be instantiated by different applications, services, code blocks, objects, routines, APIs, functions, etc. The term “program” may encompass individual or groups of executable files, data files, libraries, drivers, scripts, database records, etc.
  • It will be appreciated that a “service”, as used herein, is an application program executable across multiple user sessions. A service may be available to one or more system components, programs, and/or other services. In some implementations, a service may run on one or more server-computing devices.
  • When included, display subsystem 706 may be used to present a visual representation of data held by storage machine 704. This visual representation may take the form of a graphical user interface (GUI). As the herein described methods and processes change the data held by the storage machine, and thus transform the state of the storage machine, the state of display subsystem 706 may likewise be transformed to visually represent changes in the underlying data. Display subsystem 706 may include one or more display devices utilizing virtually any type of technology. Such display devices may be combined with logic machine 702 and/or storage machine 704 in a shared enclosure, or such display devices may be peripheral display devices.
  • When included, input subsystem 708 may comprise or interface with one or more user-input devices such as a keyboard, mouse, touch screen, or game controller. In some embodiments, the input subsystem may comprise or interface with selected natural user input (NUI) componentry. Such componentry may be integrated or peripheral, and the transduction and/or processing of input actions may be handled on- or off-board. Example NUI componentry may include a microphone for speech and/or voice recognition; an infrared, color, stereoscopic, and/or depth camera for machine vision and/or gesture recognition; a head tracker, eye tracker, accelerometer, and/or gyroscope for motion detection and/or intent recognition; as well as electric-field sensing componentry for assessing brain activity.
  • When included, communication subsystem 710 may be configured to communicatively couple computing system 700 with one or more other computing devices. Communication subsystem 710 may include wired and/or wireless communication devices compatible with one or more different communication protocols. As non-limiting examples, the communication subsystem may be configured for communication via a wireless telephone network, or a wired or wireless local- or wide-area network. In some embodiments, the communication subsystem may allow computing system 700 to send and/or receive messages to and/or from other devices via a network such as the Internet.
  • Another example provides, on a computing device configured to be located at a network edge between a local network and a cloud service, a method for updating system software of the computing device, the method comprising: booting into a system disk image at a boot location, receiving, from a server computing device, an updated system disk image and storing the updated system disk image, changing the boot location from a location of the system disk image to a location of the updated system disk image, and booting into the updated system disk image. The method may additionally or alternatively include storing user files on a different physical storage device than a physical storage device storing the system disk image and the updated system disk image. The method may additionally or alternatively include storing client settings on a different physical storage device than a physical storage device storing the system disk image and the updated system disk image. Booting into the system disk image at the boot location may additionally or alternatively include booting a virtual machine into the system disk image. The method may additionally or alternatively include, before booting into the system disk image at the boot location, installing the system disk image by receiving an initialization disk image, the initialization disk image comprising an operating system partition and an image partition, the image partition comprising the system disk image, booting into the operating system partition, and changing the boot location from a location of the operating system partition to the location of the system disk image. The method may additionally or alternatively include mounting the initialization disk image as a virtual disk. The method may additionally or alternatively include receiving an instruction to roll back updates contained within the updated system disk image, based on receiving the instruction to roll back the updates, changing the boot location from the location of the updated system disk image to the location of the system disk image, and booting into the system disk image. Receiving the instruction to roll back the updates may additionally or alternatively include receiving an instruction to automatically to roll back the updates if the computing device encounters an error during or after booting into the updated system disk image. The computing device may additionally or alternatively include one node of a cluster of computing devices. The method may additionally or alternatively include instructing one or more computing devices of the cluster of computing devices to boot into a specified system disk version. The method may additionally or alternatively include receiving, from another computing device of the cluster of computing devices, an instruction to boot into a specified system disk version.
  • Another aspect provides a computing device comprising a processor, and a storage device storing instructions executable by the processor to receive an initialization disk image, the initialization disk image comprising an operating system partition and an image partition, the image partition comprising a system disk image, boot into the operating system partition, change a boot location from a location of the operating system partition to a location of the system disk image, boot into the system disk image, receive an updated system disk image, change the boot location from the location of the system disk image to a location of the updated system disk image, and boot into the updated system disk image. Booting into the operating system partition may additionally or alternatively include booting a virtual machine into the operating system partition, and changing the boot location may additionally or alternatively include changing the boot location of the virtual machine. The instructions may additionally or alternatively be executable to mount the initialization disk image as a virtual disk. The instructions may additionally or alternatively be executable to receive an instruction to roll back updates contained within the updated system disk image, based on receiving the instruction to roll back the updates, change the boot location from the location of the updated system disk image to the location of the system disk image, and boot into the system disk image. The instructions may additionally or alternatively be executable to automatically roll back the updates if the computing device encounters an error during or after booting into the updated system disk image. The instructions may additionally or alternatively be executable to instruct one or more other computing devices of a cluster of computing devices to boot into a specified system disk image version. The instructions may additionally or alternatively be executable to receive, from another computing device of a cluster of computing devices, an instruction to boot into a specified system disk image version.
  • Another aspect provides a computing device configured to orchestrate updating system software on a plurality of computing devices of a cluster of computing devices, the computing device comprising a processor, and a storage device storing instructions executable by the processor to configure a boot location for each computing device of the plurality of computing devices to boot into a location of a system disk image, receive an updated system disk image, and change the boot location from the location of the system disk image to a location of the updated system disk image such that each computing device of the plurality of computing devices boots into the updated system disk image. The instructions may additionally or alternatively be executable to receive an initialization disk image, the initialization disk image comprising an operating system partition and an image partition, the image partition comprising the system disk image, configure the boot location for each computing device of the plurality of computing devices to boot into a location of the operating system partition, and change the boot location from the location of the operating system partition to the location of the system disk image such that each computing device of the plurality of computing devices boots into the system disk image. The instructions may additionally or alternatively be executable to instruct each computing device of the plurality of computing devices to boot into a specified system disk image version.
  • It will be understood that the configurations and/or approaches described herein are exemplary in nature, and that these specific embodiments or examples are not to be considered in a limiting sense, because numerous variations are possible. The specific routines or methods described herein may represent one or more of any number of processing strategies. As such, various acts illustrated and/or described may be performed in the sequence illustrated and/or described, in other sequences, in parallel, or omitted. Likewise, the order of the above-described processes may be changed.
  • The subject matter of the present disclosure includes all novel and non-obvious combinations and sub-combinations of the various processes, systems and configurations, and other features, functions, acts, and/or properties disclosed herein, as well as any and all equivalents thereof.

Claims (20)

1. On a computing device configured as an edge device node in a cluster of computing devices configured to operate as an edge computing device located at a network edge between a local network and a cloud service to perform functions of the cloud service at the network edge, a method for updating system software of the computing device, the method comprising:
booting into a system disk image at a boot location;
receiving, from a server computing device, an updated system disk image and storing the updated system disk image;
changing the boot location from a location of the system disk image to a location of the updated system disk image;
booting into the updated system disk image;
detecting a potential error, wherein the detecting is performed at the computing device; and
automatically generating an instruction to roll back in response to detecting the potential error;
based on the instruction to roll back, changing the boot location from the location of the updated system disk image to a location of the specified prior version of the system disk image; and
booting into the specified prior version of the system disk image.
2. The method of claim 1, further comprising storing user files on a different physical storage device than a physical storage device storing the system disk image and the updated system disk image.
3. The method of claim 1, further comprising storing client settings on a different physical storage device than a physical storage device storing the system disk image and the updated system disk image.
4. The method of claim 1, wherein booting into the system disk image at the boot location comprises booting a virtual machine into the system disk image.
5. The method of claim 1, further comprising, before booting into the system disk image at the boot location, installing the system disk image by:
receiving an initialization disk image, the initialization disk image comprising an operating system partition and an image partition, the image partition comprising the system disk image;
booting into the operating system partition; and
changing the boot location from a location of the operating system partition to the location of the system disk image.
6. The method of claim 5, further comprising mounting the initialization disk image as a virtual disk.
7. The method of claim 1, wherein the instruction to roll back is generated by an executable on the updated system disk image.
8. The method of claim 1, wherein the instruction to roll back is generated by an executable within an operating system of the computing device.
9. The method of claim 1, wherein the instruction to roll back is generated by an executable on the system disk image.
10. A computing device configured as an edge device located at a network edge between a local network and a cloud service to perform functions of the cloud service at the network edge, the computing device comprising:
a processor; and
a storage device storing instructions executable by the processor to
receive an initialization disk image from a cloud-side update server, the initialization disk image comprising an operating system partition and an image partition, the image partition comprising a system disk image;
boot into the operating system partition;
change a boot location from a location of the operating system partition to a location of the system disk image;
boot into the system disk image;
receive an updated system disk image;
change the boot location from the location of the system disk image to a location of the updated system disk image;
boot into the updated system disk image;
detect a potential error, wherein the detecting is performed at the computing device;
automatically generating an instruction to roll back in response to detecting the potential error;
based on the instruction to roll back, change the boot location from the location of the updated system disk image to a location of the specified prior version of the system disk image; and
boot into the specified prior version of the system disk image.
11. The computing device of claim 10, wherein the instructions executable to boot into the operating system partition comprises instructions executable to boot a virtual machine into the operating system partition, and wherein the instructions executable to change the boot location are executable to change the boot location of the virtual machine.
12. The computing device of claim 10, wherein the instructions are further executable to mount the initialization disk image as a virtual disk.
13. The computing device of claim 10, wherein the instructions are further executable to generate the instruction to roll back at an executable on the updated system disk image.
14. The computing device of claim 10, wherein the instructions are executable to generate the instruction to roll back at an executable within an operating system of the computing device.
15. The computing device of claim 10, wherein the instructions are executable to generate the instruction to roll back at an executable on the system disk image.
16. A computer-readable storage device comprising:
instructions executable by a computing device configured as an edge device located at a network edge between a local network and a cloud service to perform functions of the cloud service at the network edge, the instructions comprising instructions executable to
boot into a system disk image at a boot location;
receive, from a server computing device, an updated system disk image and storing the updated system disk image;
change the boot location from a location of the system disk image to a location of the updated system disk image;
boot into the updated system disk image;
detect a potential error, wherein the detecting is performed at the computing device; and
automatically generate a rollback instruction at the computing device in response to detecting the potential error;
based on the instruction to roll back, change the boot location from the location of the updated system disk image to a location of the specified prior version of the system disk image; and
boot into the specified prior version of the system disk image.
17. The computer-readable storage device of claim 16, wherein the instructions are executable to store user files on a different physical storage device than a physical storage device storing the system disk image and the updated system disk image.
18. The computer-readable storage device of claim 16, wherein the instructions are executable to store client settings on a different physical storage device than a physical storage device storing the system disk image and the updated system disk image.
19. The computer-readable storage device of claim 16, wherein the instruction to roll back is received from an executable within an operating system of the computing device.
20. The computer-readable storage device of claim 16, wherein the instruction to roll back is received from an executable on one or more of the system disk image or the updated system disk image.
US17/301,572 2018-09-20 2021-04-08 Updating an edge computing device Abandoned US20210224054A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US17/301,572 US20210224054A1 (en) 2018-09-20 2021-04-08 Updating an edge computing device

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US201862733907P 2018-09-20 2018-09-20
US16/224,480 US10990372B2 (en) 2018-09-20 2018-12-18 Updating an edge computing device
US17/301,572 US20210224054A1 (en) 2018-09-20 2021-04-08 Updating an edge computing device

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US16/224,480 Continuation US10990372B2 (en) 2018-09-20 2018-12-18 Updating an edge computing device

Publications (1)

Publication Number Publication Date
US20210224054A1 true US20210224054A1 (en) 2021-07-22

Family

ID=69884190

Family Applications (2)

Application Number Title Priority Date Filing Date
US16/224,480 Active US10990372B2 (en) 2018-09-20 2018-12-18 Updating an edge computing device
US17/301,572 Abandoned US20210224054A1 (en) 2018-09-20 2021-04-08 Updating an edge computing device

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US16/224,480 Active US10990372B2 (en) 2018-09-20 2018-12-18 Updating an edge computing device

Country Status (3)

Country Link
US (2) US10990372B2 (en)
EP (1) EP3853720B1 (en)
WO (1) WO2020060610A1 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11758682B2 (en) * 2019-09-19 2023-09-12 Baidu Usa Llc Distributed infrastructure and mobile architecture for edge computing
US12061574B2 (en) 2022-09-15 2024-08-13 Red Hat, Inc. Updating edge nodes in distributed computing environments using partitions

Families Citing this family (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10860307B2 (en) * 2019-04-24 2020-12-08 Dell Products, L.P. Fragmented firmware storage system and method therefor
US11169818B2 (en) * 2019-04-25 2021-11-09 Dell Products L.P. Systems and methods for dynamically locating and accessing operating system (OS) file system data from a pre-boot environment
US11635990B2 (en) 2019-07-01 2023-04-25 Nutanix, Inc. Scalable centralized manager including examples of data pipeline deployment to an edge system
US11501881B2 (en) 2019-07-03 2022-11-15 Nutanix, Inc. Apparatus and method for deploying a mobile device as a data source in an IoT system
EP3809259B1 (en) * 2019-10-16 2023-08-16 NXP USA, Inc. Network node firmware update
US11726764B2 (en) * 2020-11-11 2023-08-15 Nutanix, Inc. Upgrade systems for service domains
US11665221B2 (en) 2020-11-13 2023-05-30 Nutanix, Inc. Common services model for multi-cloud platform
CN112653758B (en) 2020-12-21 2023-04-07 北京百度网讯科技有限公司 Method, device, equipment and medium for updating edge node
US11736585B2 (en) 2021-02-26 2023-08-22 Nutanix, Inc. Generic proxy endpoints using protocol tunnels including life cycle management and examples for distributed cloud native services and applications
CN113064615B (en) * 2021-03-26 2023-09-26 西安万像电子科技有限公司 Software updating method and device, storage medium and electronic device
US20220327003A1 (en) 2021-04-09 2022-10-13 Oracle International Corporation Cloud edge device virtualization
CN113407208A (en) * 2021-06-17 2021-09-17 南方电网数字电网研究院有限公司 Edge device function online configuration method based on remote deployment
WO2024030348A1 (en) * 2022-08-02 2024-02-08 Centurylink Intellectual Property Llc Enhanced pre-loading for edge gateways in communications networks

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080168434A1 (en) * 2007-01-04 2008-07-10 International Business Machines Corporation Apparatus and method to update multiple devices disposed in a computing system
US20180267864A1 (en) * 2017-03-17 2018-09-20 Canon Kabushiki Kaisha Image forming apparatus that automatically executes system rollback, method of controlling the same, and storage medium
US10275282B1 (en) * 2015-11-11 2019-04-30 Amazon Technologies, Inc. Automated rollback

Family Cites Families (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7668938B1 (en) * 2000-01-14 2010-02-23 Microsoft Corporation Method and system for dynamically purposing a computing device
US7216251B2 (en) * 2000-02-19 2007-05-08 Powerquest Corporation Computer imaging recovery without a working partition or a secondary medium
US7340638B2 (en) 2003-01-30 2008-03-04 Microsoft Corporation Operating system update and boot failure recovery
US7219343B2 (en) 2003-04-10 2007-05-15 International Business Machines Corporation Firmware update mechanism in a multi-node data processing system
US20070208832A1 (en) 2006-01-31 2007-09-06 Bea Systems, Inc. RFID edge server allowing configuration updates without restart
US20080126446A1 (en) * 2006-11-27 2008-05-29 Storage Appliance Corporation Systems and methods for backing up user settings
WO2008085207A2 (en) * 2006-12-29 2008-07-17 Prodea Systems, Inc. Multi-services application gateway
US7822963B2 (en) 2007-06-05 2010-10-26 Hewlett-Packard Development Company, L.P. Remote computer operating system upgrade
US9262366B2 (en) * 2007-09-21 2016-02-16 Microsoft Technology Licensing, Llc Software deployment in large-scale networked systems
US8069343B2 (en) * 2009-03-20 2011-11-29 Concorso James A Computer with bootable restoration
US20110126186A1 (en) 2009-11-23 2011-05-26 Srinivasan Kattiganehalli Y Appliance maintenance in computing system environment
US8489922B2 (en) 2010-11-17 2013-07-16 Apple Inc. Networked recovery system
US8719561B2 (en) * 2010-11-29 2014-05-06 International Business Machines Corporation Automatic configuration sampling for managing configuration parameters of a computer system
US8874888B1 (en) 2011-01-13 2014-10-28 Google Inc. Managed boot in a cloud system
US8813076B2 (en) * 2011-11-17 2014-08-19 International Business Machines Corporation Virtual machine updates
US8782387B2 (en) 2011-12-31 2014-07-15 International Business Machines Corporation Secure boot of a data breakout appliance with multiple subsystems at the edge of a mobile data network
CN102761481A (en) 2012-06-29 2012-10-31 杭州华三通信技术有限公司 EVI (Ethernet Virtualization Interconnection) network based version upgrading method and device
US20140033188A1 (en) * 2012-07-26 2014-01-30 Microsoft Corporation System updates from cloud blob storage using vhd differentials
US9141400B2 (en) * 2012-12-21 2015-09-22 Unisys Corporation Technique for deploying operating systems in a virtualized environment
US9519489B2 (en) 2012-12-21 2016-12-13 Hewlett Packard Enterprise Development Lp Boot from modified image
US9733950B2 (en) 2013-03-14 2017-08-15 Microchip Technology Incorporated Boot sequencing for multi boot devices
US10613914B2 (en) * 2013-04-01 2020-04-07 Oracle International Corporation Orchestration service for a distributed computing system
US9448807B2 (en) * 2013-04-29 2016-09-20 Global Foundries Inc. Automatic creation, deployment, and upgrade of disk images
US9262257B2 (en) 2014-04-21 2016-02-16 Netapp, Inc. Providing boot data in a cluster network environment
US11550557B2 (en) * 2016-02-12 2023-01-10 Nutanix, Inc. Virtualized file server
US11106454B2 (en) 2016-04-15 2021-08-31 Nec Corporation Software update control device, software update control method, and recording medium having software update control program stored thereon
WO2018095537A1 (en) 2016-11-25 2018-05-31 Nokia Technologies Oy Application provisioning to mobile edge
KR101954623B1 (en) 2017-02-27 2019-03-06 한국전자통신연구원 Apparatus and method for updating software on the virtualized environment
US20190012184A1 (en) * 2017-07-04 2019-01-10 Cloudendure Ltd. System and method for deploying cloud based computing environment agnostic applications
US10819577B2 (en) * 2017-07-31 2020-10-27 Cisco Technology, Inc. Node update in a software-defined network

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080168434A1 (en) * 2007-01-04 2008-07-10 International Business Machines Corporation Apparatus and method to update multiple devices disposed in a computing system
US10275282B1 (en) * 2015-11-11 2019-04-30 Amazon Technologies, Inc. Automated rollback
US20180267864A1 (en) * 2017-03-17 2018-09-20 Canon Kabushiki Kaisha Image forming apparatus that automatically executes system rollback, method of controlling the same, and storage medium

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11758682B2 (en) * 2019-09-19 2023-09-12 Baidu Usa Llc Distributed infrastructure and mobile architecture for edge computing
US12061574B2 (en) 2022-09-15 2024-08-13 Red Hat, Inc. Updating edge nodes in distributed computing environments using partitions

Also Published As

Publication number Publication date
WO2020060610A1 (en) 2020-03-26
US10990372B2 (en) 2021-04-27
US20200097274A1 (en) 2020-03-26
EP3853720A1 (en) 2021-07-28
EP3853720B1 (en) 2024-11-06

Similar Documents

Publication Publication Date Title
US20210224054A1 (en) Updating an edge computing device
US8924952B1 (en) Updating software utilizing multiple partitions
US10713028B2 (en) On-demand installer for resource packages
US9354858B2 (en) Desktop image management for virtual desktops using on-demand stub creation
US20150227384A1 (en) Desktop image management for virtual desktops
EP3273363A1 (en) Zero downtime database updates with database configuration changes
CN108319554B (en) Application function testing method, computer readable storage medium and terminal device
US20170339223A1 (en) Adding and removing virtual disks remotely to a streaming machine
US20150278032A1 (en) Providing services on system being recovered
WO2020076397A1 (en) Error source module identification and remedial action
US20200150950A1 (en) Upgrade managers for differential upgrade of distributed computing systems
US20230367607A1 (en) Methods and apparatus for hypervisor boot up
CN106462442B (en) System and method for loading virtual machine
US20160266892A1 (en) Patching of virtual machines during data recovery
US9329855B2 (en) Desktop image management for virtual desktops using a branch reflector
US11481206B2 (en) Code update in system management mode
US11086652B2 (en) Fault-tolerant application virtualization using computer vision
US11579864B1 (en) Accelerated behavior change for upgrades in distributed systems
US20160203016A1 (en) Methods, systems, and computer readable media for virtual machine (vm) deployment
US20160011814A1 (en) Choosing a multipath i/o (mpio) path control module (pcm) for a logical unit number (lun) on a host that supports multiple pcms
US10996893B2 (en) Non-volatile storage partition identifier
US20140137092A1 (en) Information processing apparatus, information processing system, non-transitory computer-readable storage medium having stored therein information processing program, and information processing method
US11310112B2 (en) Automatic server configuration using a switch
CN113805858A (en) Method and device for continuously deploying software developed by scripting language
US20150350340A1 (en) Management of headless hardware in data center

Legal Events

Date Code Title Description
AS Assignment

Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:SARKAR, DEEPANJYOTI;GOYAL, KANIKA;JOSHI, DEVIDAS;AND OTHERS;SIGNING DATES FROM 20181207 TO 20181217;REEL/FRAME:055863/0190

STPP Information on status: patent application and granting procedure in general

Free format text: APPLICATION DISPATCHED FROM PREEXAM, NOT YET DOCKETED

STPP Information on status: patent application and granting procedure in general

Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION

STPP Information on status: patent application and granting procedure in general

Free format text: NON FINAL ACTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER

STPP Information on status: patent application and granting procedure in general

Free format text: FINAL REJECTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: NON FINAL ACTION MAILED

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION