Skip to content

Commit

Permalink
Merge pull request #378 from foundriesio/make-app-stop-configurable
Browse files Browse the repository at this point in the history
composeappmanager: Make app stopping configurable
  • Loading branch information
mike-sul authored Dec 12, 2024
2 parents 7442c0b + dde46f1 commit e224b1f
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 3 deletions.
13 changes: 10 additions & 3 deletions src/composeappmanager.cc
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,10 @@ ComposeAppManager::Config::Config(const PackageConfig& pconfig) {
create_containers_before_reboot = boost::lexical_cast<bool>(raw.at("create_containers_before_reboot"));
}

if (raw.count("stop_apps_before_update") > 0) {
stop_apps_before_update = boost::lexical_cast<bool>(raw.at("stop_apps_before_update"));
}

if (raw.count("storage_watermark") > 0) {
const std::string storage_watermark_str{raw.at("storage_watermark")};

Expand Down Expand Up @@ -367,9 +371,12 @@ data::InstallationResult ComposeAppManager::install(const Uptane::Target& target
// the subsequent "sync target" process will restart the apps (excluding those removed from the configuration).
stopDisabledComposeApps(target);

if (getCurrent().sha256Hash() != target.sha256Hash()) {
// If this ostree + apps update, then stop the Apps that is about to be updated
// so they are not started automatically by dockerd just after reboot.
if (getCurrent().sha256Hash() != target.sha256Hash() || cfg_.stop_apps_before_update) {
// If this is "ostree + apps" update or the `stop_apps_before_update` configuration variable is set to `true`,
// then stop the Apps that is about to be updated
// so they are not started automatically by dockerd just after reboot
// or it is required by the app use case to force stopping of all app services/containers if
// at least one of its container images is updated (`docker compose up` restarts only updated containers).
// If ostree is not updated then the updated Apps will be started in this context.
// If ostree is updated and a device is suddenly rebooted before Apps installation, then
// it ensures that the previous version Apps are not automatically started on boot.
Expand Down
1 change: 1 addition & 0 deletions src/composeappmanager.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ class ComposeAppManager : public RootfsTreeManager {
std::string docker_images_reload_cmd{"systemctl reload docker"};
std::string hub_auth_creds_endpoint{Docker::RegistryClient::DefAuthCredsEndpoint};
bool create_containers_before_reboot{true};
bool stop_apps_before_update{true};
int storage_watermark{80};
};

Expand Down

0 comments on commit e224b1f

Please sign in to comment.