Ensure curl is installed during bootstrapping
This commit is contained in:
@@ -11,7 +11,7 @@ class Mrsk::Cli::Main < Mrsk::Cli::Base
|
|||||||
desc "deploy", "Deploy app to servers"
|
desc "deploy", "Deploy app to servers"
|
||||||
def deploy
|
def deploy
|
||||||
runtime = print_runtime do
|
runtime = print_runtime do
|
||||||
say "Ensure Docker is installed...", :magenta
|
say "Ensure curl and Docker are installed...", :magenta
|
||||||
invoke "mrsk:cli:server:bootstrap"
|
invoke "mrsk:cli:server:bootstrap"
|
||||||
|
|
||||||
say "Log into image registry...", :magenta
|
say "Log into image registry...", :magenta
|
||||||
@@ -173,7 +173,7 @@ class Mrsk::Cli::Main < Mrsk::Cli::Base
|
|||||||
desc "registry", "Login and -out of the image registry"
|
desc "registry", "Login and -out of the image registry"
|
||||||
subcommand "registry", Mrsk::Cli::Registry
|
subcommand "registry", Mrsk::Cli::Registry
|
||||||
|
|
||||||
desc "server", "Bootstrap servers with Docker"
|
desc "server", "Bootstrap servers with curl and Docker"
|
||||||
subcommand "server", Mrsk::Cli::Server
|
subcommand "server", Mrsk::Cli::Server
|
||||||
|
|
||||||
desc "traefik", "Manage Traefik load balancer"
|
desc "traefik", "Manage Traefik load balancer"
|
||||||
|
|||||||
@@ -1,6 +1,15 @@
|
|||||||
class Mrsk::Cli::Server < Mrsk::Cli::Base
|
class Mrsk::Cli::Server < Mrsk::Cli::Base
|
||||||
desc "bootstrap", "Ensure Docker is installed on servers"
|
desc "bootstrap", "Ensure curl and Docker are installed on servers"
|
||||||
def bootstrap
|
def bootstrap
|
||||||
on(MRSK.hosts + MRSK.accessory_hosts) { execute "which docker || (apt-get update -y && apt-get install docker.io -y)" }
|
on(MRSK.hosts + MRSK.accessory_hosts) do
|
||||||
|
dependencies_to_install = [].tap do |dependencies|
|
||||||
|
dependencies << "curl" unless execute "which curl", raise_on_non_zero_exit: false
|
||||||
|
dependencies << "docker.io" unless execute "which docker", raise_on_non_zero_exit: false
|
||||||
|
end
|
||||||
|
|
||||||
|
if dependencies_to_install.any?
|
||||||
|
execute "apt-get update -y && apt-get install #{dependencies_to_install.join(' ')} -y)"
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user