Introduction¶
It’s often common practice that a juju developer needs to test out new juju code on machines that are not the same operating system or architecture to that of their current host. Alternatively in this workflow it is common place to want to want to perform Juju upgrades.
Examples of this would be:
ubuntu/amd64 -> ubuntu/s390x
ubuntu/amd64 -> centos/amd64
macos/amd64 -> ubuntu/amd64
macos/arm64 -> ubutnu/amd64
Doing this has been difficult in the past but with changes to the juju Makefile
we can now build simple streams for multiple platforms and versions.
How it works¶
Bootstrapping¶
We start by telling the juju build systems that we would like a local simple
streams repository created for a given set of Go style os/arch pairs. For this
example we would like a simple stream of our development changes that have
artifacts for linux/amd64
and linux/arm64
.
The juju build system is going place artifacts in a simplestream directory. You
can optionally specify where you would like this directory to be by exporting
JUJU_METADATA_SOURCE
in your environment or simply let the build system choose
for you.
export JUJU_METADATA_SOURCE=<local_simplestreams_path>
This is created by running:
AGENT_PACKAGE_PLATFORMS="linux/amd64 linux/arm64" make simplestreams
This process will build all the juju agent binaries for the platforms specified above and package them into a simple streams repository.
The end of the output for this make
command will also provide the user with an
export
statement that the user should run to help the juju bootstrap command
automatically find this local simple streams repository. Example output:
export JUJU_METADATA_SOURCE="...."
You can ignore the above export requirement if you have previously done this in a previous step.
You can now bootstrap using this simple streams repository using the usual:
juju bootstrap cloudx
Note: You may need to specify additional bootstrap-constrains
to help juju
choose the correct architecture.
Upgrading¶
Often once we have a bootstrapped controller we want to upgrade the controller for testing or time reasons.
To do this we now need to run the make simplestreams
target again but this
time we also want to supply the build system with a build number.
JUJU_BUILD_NUMBER=1 AGENT_PACKAGE_PLATFORMS="linux/amd64 linux/arm64" make simplestreams
Note: A key way to tell if this has worked is by looking at the output of the command to confirm the new version is being used.
You will also be prompted to export the JUJU_METADATA_SOURCE
again. This step
can safely be ignored if previously done from a previous step.
Next we need to get these new version artifacts on to the juju controller that we want to upgrade.
juju sync-agent-binary --version=<version>
Where <version>
is the Juju version we are upgrading to including the build
number from above.
We can now perform the upgrade using:
juju upgrade-controller --agent-version <version>
Where <version>
is the Juju version we are upgrading to including the build
number from above.
Current limitations & future changes¶
Does not support oci artifacts including upgrading of OCI deployed controllers and agents.
Would like to integrate work by @hpidcock for a simplestreams server that continuously builds and updates.