Block Automatic Updates
The a9s Service Broker allows the Platform Operator to allow or forbid the Application Developer to block automatic updates of their Service Instances.
By default the automatic updates property for the Service Instance is set to false
. This results in the Platform
Operator being able to update all Service Instances, in a single execution, without a single one being skipped.
By enabling the Application Developer to block automatic updates, the Application Developers will be able to manually decide which of their Service Instance will get updated and which Service Instance will not.
However, when manually updating Service Instances with the CLI, Application Developers will have to add the
force_update
parameter to their command.
cf update-service MY_SERVICE -c '{ "force_update": true }'
The Application Developer will have to manually update their Service Instances when:
- A new BOSH release is installed
- A new stemcell is available
If there is no new BOSH release or stemcell, it is not required to add the
force_update
parameter when manually updating a Service Instance.The Platform Operator can also ignore the configuration by running the
force_deployment_updater
errand:bosh run-errand force_deployment_updater
This will update these Service Instances regardless of whether the Application Developer allowed the update or not. The
force_deployment_updater
must be installed by the Platform Operator, as shown in the Installation section.
Installation
The Platform Operator can allow the Application Developer to block the automatic update by using the
ops/forbid-automatic-update-of-service-instance.yml
ops file.
The force_deployment_updater
is by default not part of the a9s Data Service deployment manifests. The Platform
Operator can apply the Ops file add-force-deployment-updater.yml
which can be found under the specific a9s Data
Service folder:
- a9s KeyValue:
keyvalue-service/ops/add-force-deployment-updater.yml
- a9s LogMe2:
logme2-service/ops/add-force-deployment-updater.yml
- a9s MariaDB:
mariadb-service/ops/add-force-deployment-updater.yml
- a9s Messaging:
rabbitmq-service/ops/add-force-deployment-updater.yml
- a9s MongoDB:
mongodb-service/ops/add-force-deployment-updater.yml
- a9s PostgreSQL:
postgresql-service/ops/add-force-deployment-updater.yml
- a9s Prometheus:
prometheus-service/ops/add-force-deployment-updater.yml
- a9s Redis®*:
redis-service/ops/add-force-deployment-updater.yml
- a9s Search:
search-service/ops/add-force-deployment-updater.yml
*Redis is a registered trademark of Redis Ltd. Any rights therein are reserved to Redis Ltd. Any use by anynines GmbH is for referential purposes only and does not indicate any sponsorship, endorsement or affiliation between Redis and anynines GmbH.