Note: With the latest 1.23.0 release, the Anbox Cloud documentation is moved to https://documentation.ubuntu.com/anbox-cloud/en/latest/. Hence, the information in this discourse post may be obsolete. The documentation posts on discourse will be unlisted and archived shortly.
Discourse will still be used for user engagement and release announcements.
Instances are the centre piece of the Anbox Cloud stack. Every time you launch an application or an image, Anbox Cloud creates an instance for it. Every instance provides a full Android system.
All instances in Anbox Cloud are ephemeral, which means that as soon as an instance is stopped, all of its data is deleted. Anbox Cloud DOES NOT back up any data from the Android or the outer Ubuntu instance. Backup and restore of data must be implemented separately through addons. See Example: Back up data for information on how to do this.
Regular instances vs. base instances
Anbox Cloud differentiates between two types of instances: regular and base. The instance type is visible in the output of the amc ls
command.
Regular instances are containers or virtual machines that are launched from either an application or an image. They exist until they are deleted.
Base instances are temporary containers or virtual machines that are used when bootstrapping an application. They are automatically deleted when the application bootstrap is completed.
When we refer to instances in this documentation without specifying the instance type, we mean regular instances.
Application instances vs. raw instances
Instances are based on either applications or images. So if you launch an application or an image, Anbox Management Service (AMS) automatically creates an instance for it.
Application instances are containers or virtual machines created when launching an application and run the full Android system. If the application is based on an Android app (an APK package), this app is launched after the system boots and monitored by the watchdog. With the default configuration, you will see only the app and not the Android launcher.
Raw instances are containers or virtual machines created when launching an image. They run the full Android system, without any additional apps installed.
Life cycle of an instance
Creating an instance
When you create an instance by either launching or initialising an application or an image, AMS schedules the instance on a LXD node. The instance then executes the following steps in order:
- Configure the network interface and gateway.
- (Only for raw instances) Install addons that are specified with
--addons
. - Expose services that are specified with
--service
or through the application manifest. - Execute the
pre-start
hook provided by the installed addons. - Launch the Android container.
- Execute the
post-start
hook provided by the installed addons.
Launching an instance is successful only if all of the above steps succeed. If there are issues during the process, the status of the instance changes to error
. You can view the available logs from the instance for further troubleshooting.
Stopping an instance
Instances can be stopped because of the following scenarios:
- You stopped it.
- You deleted it.
- An error occurred.
When an instance is stopped, it executes the following steps in order:
- Stop the Android container.
- Execute the
post-stop
hook provided by the installed addons. - Shut down the instance.
Beyond that, the instance will be removed from AMS either because you deleted it or because an error occurred during its runtime.
Possible instance statuses
An instance moves through different stages and correspondingly can have the following statuses depending on its current state.
Status | Description |
---|---|
created |
AMS has created an internal database object for the instance and will next schedule the instance onto a suitable LXD node. |
prepared |
AMS has decided the LXD node on which it will schedule the instance. |
started |
The instance is started and now booting. During the boot sequence, possible hooks are executed. Once all hooks have been executed, the instance will switch to running . |
running |
The instance is fully up and running. |
stopped |
The instance has been stopped and can be restarted when required. |
deleted |
The instance has been deleted and will be removed from the AMS database soon. |
error |
An error occurred while processing the instance. The instance is stopped. |
unknown |
A possible error occurred and the real state of the instance cannot be determined. |
If you encounter the error
or the unknown
status, use amc show <instance_id>
or amc-showlog
to troubleshoot. If you are still unable to figure out the issue, file a bug with the relevant instance logs.
Development mode
AMS allows to start an instance in development mode. This mode turns off some features that are usually active in an instance. It is mainly useful when developing addons inside an instance.
When development mode is enabled, the instance sends status updates to AMS when the Anbox runtime is terminated, however, AMS allows the instance to continue running. This allows you to restart the Anbox runtime inside the instance, providing an easy way to test addons or develop a platform plugin.
To check whether development mode is enabled, run amc show <instance_ID>
or look at the /var/lib/anbox/session.yaml
file in the instance. If the devmode
field in the configuration file is set to true
, development mode is active.
Related information
- How to create an instance
- How to start an instance
- How to wait for an instance
- How to access an instance
- How to expose services on an instance
- How to view the instance logs
- How to stop an instance
- How to delete an instance
- How to list instances
- How to configure geographic location
- How to back up and restore application data