From 10c46723fe7d536d7660244951a0fa4587c885fc Mon Sep 17 00:00:00 2001 From: jaminmc <1310376+jaminmc@users.noreply.github.com> Date: Fri, 21 Feb 2025 09:45:30 -0500 Subject: [PATCH] Add ZFS to Podman. Now it works on ZFS! (#2526) * Allow Podman to work on ZFS containers * Fix ZFS for Podman-Create missing folder. * Added option to install Portainer or Portainer agent in Podman * Fix source for Podman Homeassistant so Portainer and other containers can be installed. * fix Podman not creating storage/volumes, until one exists. --- install/podman-homeassistant-install.sh | 61 +++++++++++++++++++++++++ install/podman-install.sh | 61 +++++++++++++++++++++++++ json/podman-homeassistant.json | 8 ++-- json/podman.json | 2 +- 4 files changed, 127 insertions(+), 5 deletions(-) diff --git a/install/podman-homeassistant-install.sh b/install/podman-homeassistant-install.sh index cff4b32b3..b4a2b167b 100644 --- a/install/podman-homeassistant-install.sh +++ b/install/podman-homeassistant-install.sh @@ -19,11 +19,72 @@ $STD apt-get install -y sudo $STD apt-get install -y mc msg_ok "Installed Dependencies" +get_latest_release() { + curl -sL https://api.github.com/repos/$1/releases/latest | grep '"tag_name":' | cut -d'"' -f4 +} + +PORTAINER_LATEST_VERSION=$(get_latest_release "portainer/portainer") +PORTAINER_AGENT_LATEST_VERSION=$(get_latest_release "portainer/agent") + +if $STD mount | grep 'on / type zfs' > null && echo "ZFS"; then + msg_info "Enabling ZFS support." + mkdir -p /etc/containers + cat <<'EOF' >/usr/local/bin/overlayzfsmount +#!/bin/sh +exec /bin/mount -t overlay overlay "$@" +EOF + chmod +x /usr/local/bin/overlayzfsmount + cat <<'EOF' >/etc/containers/storage.conf +[storage] +driver = "overlay" +runroot = "/run/containers/storage" +graphroot = "/var/lib/containers/storage" + +[storage.options] +pull_options = {enable_partial_images = "false", use_hard_links = "false", ostree_repos=""} +mount_program = "/usr/local/bin/overlayzfsmount" + +[storage.options.overlay] +mountopt = "nodev" +EOF +fi + msg_info "Installing Podman" $STD apt-get -y install podman $STD systemctl enable --now podman.socket +echo -e 'unqualified-search-registries=["docker.io"]' >> /etc/containers/registries.conf msg_ok "Installed Podman" +read -r -p "Would you like to add Portainer? " prompt +if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then + msg_info "Installing Portainer $PORTAINER_LATEST_VERSION" + podman volume create portainer_data >/dev/null + $STD podman run -d \ + -p 8000:8000 \ + -p 9443:9443 \ + --name=portainer \ + --restart=always \ + -v /run/podman/podman.sock:/var/run/docker.sock \ + -v portainer_data:/data \ + portainer/portainer-ce:latest + msg_ok "Installed Portainer $PORTAINER_LATEST_VERSION" +else + read -r -p "Would you like to add the Portainer Agent? " prompt + if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then + msg_info "Installing Portainer agent $PORTAINER_AGENT_LATEST_VERSION" + podman volume create temp >/dev/null + podman volume remove temp >/dev/null + $STD podman run -d \ + -p 9001:9001 \ + --name portainer_agent \ + --restart=always \ + -v /run/podman/podman.sock:/var/run/docker.sock \ + -v /var/lib/containers/storage/volumes:/var/lib/docker/volumes \ + portainer/agent + msg_ok "Installed Portainer Agent $PORTAINER_AGENT_LATEST_VERSION" + fi +fi + msg_info "Pulling Home Assistant Image" $STD podman pull docker.io/homeassistant/home-assistant:stable msg_ok "Pulled Home Assistant Image" diff --git a/install/podman-install.sh b/install/podman-install.sh index 2b496ba75..a584a96aa 100644 --- a/install/podman-install.sh +++ b/install/podman-install.sh @@ -19,12 +19,73 @@ $STD apt-get install -y sudo $STD apt-get install -y mc msg_ok "Installed Dependencies" +get_latest_release() { + curl -sL https://api.github.com/repos/$1/releases/latest | grep '"tag_name":' | cut -d'"' -f4 +} + +PORTAINER_LATEST_VERSION=$(get_latest_release "portainer/portainer") +PORTAINER_AGENT_LATEST_VERSION=$(get_latest_release "portainer/agent") + +if $STD mount | grep 'on / type zfs' > null && echo "ZFS"; then + msg_info "Enabling ZFS support." + mkdir -p /etc/containers + cat <<'EOF' >/usr/local/bin/overlayzfsmount +#!/bin/sh +exec /bin/mount -t overlay overlay "$@" +EOF + chmod +x /usr/local/bin/overlayzfsmount + cat <<'EOF' >/etc/containers/storage.conf +[storage] +driver = "overlay" +runroot = "/run/containers/storage" +graphroot = "/var/lib/containers/storage" + +[storage.options] +pull_options = {enable_partial_images = "false", use_hard_links = "false", ostree_repos=""} +mount_program = "/usr/local/bin/overlayzfsmount" + +[storage.options.overlay] +mountopt = "nodev" +EOF +fi + msg_info "Installing Podman" $STD apt-get -y install podman $STD systemctl enable --now podman.socket echo -e 'unqualified-search-registries=["docker.io"]' >> /etc/containers/registries.conf msg_ok "Installed Podman" +read -r -p "Would you like to add Portainer? " prompt +if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then + msg_info "Installing Portainer $PORTAINER_LATEST_VERSION" + podman volume create portainer_data >/dev/null + $STD podman run -d \ + -p 8000:8000 \ + -p 9443:9443 \ + --name=portainer \ + --restart=always \ + -v /run/podman/podman.sock:/var/run/docker.sock \ + -v portainer_data:/data \ + portainer/portainer-ce:latest + msg_ok "Installed Portainer $PORTAINER_LATEST_VERSION" +else + read -r -p "Would you like to add the Portainer Agent? " prompt + if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then + msg_info "Installing Portainer agent $PORTAINER_AGENT_LATEST_VERSION" + podman volume create temp >/dev/null + podman volume remove temp >/dev/null + $STD podman run -d \ + -p 9001:9001 \ + --name portainer_agent \ + --restart=always \ + -v /run/podman/podman.sock:/var/run/docker.sock \ + -v /var/lib/containers/storage/volumes:/var/lib/docker/volumes \ + portainer/agent + msg_ok "Installed Portainer Agent $PORTAINER_AGENT_LATEST_VERSION" + fi +fi + + motd_ssh customize diff --git a/json/podman-homeassistant.json b/json/podman-homeassistant.json index 1e38b8b0c..a60757dd6 100644 --- a/json/podman-homeassistant.json +++ b/json/podman-homeassistant.json @@ -31,10 +31,6 @@ "password": null }, "notes": [ - { - "text": "Doesn't work with ZFS", - "type": "warning" - }, { "text": "If the LXC is created Privileged, the script will automatically set up USB passthrough.", "type": "warning" @@ -42,6 +38,10 @@ { "text": "config path: `/var/lib/containers/storage/volumes/hass_config/_data`", "type": "info" + }, + { + "text": "Options to Install Portainer or Portainer Agent", + "type": "warning" } ] } \ No newline at end of file diff --git a/json/podman.json b/json/podman.json index d995ffdcc..eb2871f11 100644 --- a/json/podman.json +++ b/json/podman.json @@ -32,7 +32,7 @@ }, "notes": [ { - "text": "Doesn't work with ZFS", + "text": "Options to Install Portainer or Portainer Agent", "type": "warning" } ]