X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/ebe7ceb136d38c41bcc193b93bb2f619ffe61944..d7a3c93b3073fae63ca4f9e52c489724b8dea813:/cookbooks/docker/recipes/default.rb?ds=sidebyside diff --git a/cookbooks/docker/recipes/default.rb b/cookbooks/docker/recipes/default.rb index 54d65dfe5..1c8643d03 100644 --- a/cookbooks/docker/recipes/default.rb +++ b/cookbooks/docker/recipes/default.rb @@ -17,29 +17,56 @@ # limitations under the License. # -include_recipe "apt" +include_recipe "apt::docker" package %w[ docker-ce docker-ce-cli containerd.io + docker-compose-plugin ] directory "/etc/docker" do owner "root" group "root" - mode 0o755 + mode "755" end template "/etc/docker/daemon.json" do source "daemon.json.erb" owner "root" group "root" - mode 0o644 + mode "644" +end + +service "containerd" do + action [:enable, :start] + subscribes :restart, "template[/etc/docker/daemon.json]" end service "docker" do action [:enable, :start] subscribes :restart, "template[/etc/docker/daemon.json]" - not_if { ENV["TEST_KITCHEN"] } +end + +systemd_service "docker-system-prune" do + description "Cleanup up unused docker images and containers" + after ["docker.service"] + wants ["docker.service"] + user "root" + exec_start "/usr/bin/docker system prune --all --force" + sandbox :enable_network => true + memory_deny_write_execute false + restrict_address_families "AF_UNIX" +end + +systemd_timer "docker-system-prune" do + description "Cleanup up unused docker images and containers" + on_boot_sec "2h" + on_unit_active_sec "7d" + randomized_delay_sec "4h" +end + +service "docker-system-prune.timer" do + action [:enable, :start] end