Update Image
In JFrog Connect, you can use the Update Image action to update edge device images at scale.
The Update Image action enables you to easily update device images at scale. JFrog Connect integrates SWUpdate functionality to provide a robust and scalable method of deploying image updates.
Connect uses JFrog Artifactory only as the image repository and employs update flow mechanisms such as on-failure and rollback, retries, and status monitoring.
When you create a Deployment that uses Update Image in an update flow, you can configure the deployment to update the image on a single device or use Connect’s robust filter mechanism to update images on any subset of devices in your fleet.
Availability: This feature is available to some customers by feature flag.
Prerequisites
SWUpdate installed on the devices.
Familiarity with the SWUpdate methodology described in SWUpdate: software update for embedded system and Update strategy examples.
SWUpdate image file (*.SWU) uploaded to the Artifactory repository. The SWU file includes the IMG file and sw-description file.
The default upload limit in Artifactory is 100 MG. You may need to change this if your IMG file is larger.
SWUpdate File Example
The following is an example of an SWU file configured for a double-copy update.
filename
: The name of your compressed IMG file.sha256
: The sha256 attribute of the IMG file. This can be obtained by runningsha256sum <path_to_img>
on linux machines. You can find a description of the attribute in the Attribute Reference table.type
: SWUpdate has several options for the handler. (See Handler List.) The type is the string identifier for the handler, as it is set by the handler when it registers itself. For example:ubivol
,raw
,rawfile
. The type you use depends on the handler you choose.compressed
: String to indicate that the file indicated byfilename
is compressed and must be decompressed before being installed. The value denotes the compression type. The currently supported values arezlib
andzstd
.device
: device: Device node as found in/dev
or a symlink to it. This can be specified as an absolute path or a name in the/dev
folder. For example, if/dev/mtd-dtb
is a link to/dev/mtd3
, thenmtd3
,mtd-dtb
,/dev/mtd3
, and/dev/mtd-dtb
are valid names. For Raspberry Pi, the rootfs is usually/dev/mmcblck0p2
. Usage depends on the handler. For files, this attribute indicates on which device thefilesystem
must be mounted. If not specified, the current rootfs will be used.
To install double-copy using this file, you would need to run the command:
swupdate - i stable,copy1
or
swupdate - i stable,copy2
For additional examples and explanations, see SWUpdate: syntax and tags with the default parser.
Drag the Action
To include the Update Image action in your update flow, do the following:
Go to Deployment in the left menu and click Create Update Flow.
Drag the Update Image action and drop it in the workflow. It must be the last action in the workflow.
Tip: You can use the Update Image action only once in an update flow.
Configure the Action
Click the action to open and configure it.
Enter a name for the action.
Choose the JFrog Registry where your new image is stored. If your registry name does not appear in the list, click Add (+) to add yours to the list.
Enter the Artifactory Path, for example,
generic-repo/1.0/file.txt
. You can also make all or part of the path a parameter. For example, you could make the version folder a parameter:generic-repo/{{version}}/file.text
. Then you enter the version value when the actual deployment is run.
Artifactory Edge
If you want the action to pull content from an Artifactory Edge account, complete the procedures in Link to Artifactory Edge.
Agent Installation and Registration
Complete the following information for agent installation and registration:
Retain Device Credentials: Mark this to keep the current device credentials in the new image. If you leave it unmarked, you will need to register the device again after the deployment is completed. This option is recommended if you want to install a new agent version and keep the previous device credentials.
Install Agent: Mark this to back up your current agent and reinstall it in the new image. When you choose this, the device credentials will also be backed up and used with the new image. You don't need to mark this if the agent is embedded in the new image.
Partition Name: Enter the name of the new partition. (The name will look like a path, as shown below.)
Install Agent is the recommended setting for most cases. Generally, a recommended best practice is to use a separate partition (double copy strategy) for the image update. If you do the image update using a single partition, the agent and its credentials will not be backed up.
Tip: If you leave both options unmarked, then the result will be that all the devices will have the same credentials.
SWUpdate Command
The action runs SWUpdate CLI commands like the default command shown below. You can enter additional commands and run options for the action to run on the device. For each additional command, click the + and choose the command and run option. The display at the bottom enables you to review the full command that will be run before you save the action.
Check Status of the Software Update
To check the progress of the software update, do the following:
Go to Deployment in the left menu. In the Deployments tab, click in the Status column of the relevant deployment.
In the list of devices that appears for that deployment, choose the device you want to see and open the Update Image action.
What’s Next?
Learn more about Update Parameters and find out how they can be useful in your workflows.
Last updated