From 1d2b48ded0535fd49860e8b7514897b0f006d2d6 Mon Sep 17 00:00:00 2001 From: Julien Erard Date: Wed, 17 Mar 2021 08:50:39 -0700 Subject: [PATCH 1/2] Ensure systemctl is up and running (handle WSL ubuntu) --- recipes/newrelic/infrastructure/amazonlinux2.yml | 6 ++++++ recipes/newrelic/infrastructure/centos_rhel.yml | 6 ++++++ recipes/newrelic/infrastructure/debian.yml | 6 ++++++ recipes/newrelic/infrastructure/suse.yml | 6 ++++++ recipes/newrelic/infrastructure/ubuntu.yml | 6 ++++++ 5 files changed, 30 insertions(+) diff --git a/recipes/newrelic/infrastructure/amazonlinux2.yml b/recipes/newrelic/infrastructure/amazonlinux2.yml index 993c6401e..d0e4f61e4 100644 --- a/recipes/newrelic/infrastructure/amazonlinux2.yml +++ b/recipes/newrelic/infrastructure/amazonlinux2.yml @@ -78,6 +78,12 @@ install: echo "systemctl is required to install the newrelic infrastructure agent. Installation cannot proceed on this linux version." >> /dev/stderr exit 20 fi + - | + IS_SYSTEMCTL_AVAILABLE=$(sudo systemctl status | grep -i running | wc -l) + if [ $IS_SYSTEMCTL_AVAILABLE -eq 0 ] ; then + echo "systemctl is required to install the newrelic infrastructure agent. System has not been booted with systemd as init system. Installation cannot proceed on this linux version." >> /dev/stderr + exit 20 + fi setup_license: cmds: diff --git a/recipes/newrelic/infrastructure/centos_rhel.yml b/recipes/newrelic/infrastructure/centos_rhel.yml index da4203b85..751d7c795 100644 --- a/recipes/newrelic/infrastructure/centos_rhel.yml +++ b/recipes/newrelic/infrastructure/centos_rhel.yml @@ -98,6 +98,12 @@ install: echo "there is no newrelic infrastructure agent available for the distribution '{{.DISTRO_VERSION}}'." >> /dev/stderr exit 21 fi + - | + IS_SYSTEMCTL_AVAILABLE=$(sudo systemctl status | grep -i running | wc -l) + if [ $IS_SYSTEMCTL_AVAILABLE -eq 0 ] ; then + echo "systemctl is required to install the newrelic infrastructure agent. System has not been booted with systemd as init system. Installation cannot proceed on this linux version." >> /dev/stderr + exit 20 + fi vars: DISTRO_VERSION: sh: | diff --git a/recipes/newrelic/infrastructure/debian.yml b/recipes/newrelic/infrastructure/debian.yml index 43f745f4b..e8d39603d 100644 --- a/recipes/newrelic/infrastructure/debian.yml +++ b/recipes/newrelic/infrastructure/debian.yml @@ -80,6 +80,12 @@ install: echo "systemctl is required to install the newrelic infrastructure agent. Installation cannot proceed on this linux version." >> /dev/stderr exit 20 fi + - | + IS_SYSTEMCTL_AVAILABLE=$(sudo systemctl status | grep -i running | wc -l) + if [ $IS_SYSTEMCTL_AVAILABLE -eq 0 ] ; then + echo "systemctl is required to install the newrelic infrastructure agent. System has not been booted with systemd as init system. Installation cannot proceed on this linux version." >> /dev/stderr + exit 20 + fi - | if [ -n "{{.DEBIAN_CODENAME}}" ]; then IS_INFRA_AVAILABLE=$(curl -Is https://download.newrelic.com/infrastructure_agent/linux/apt/dists/{{.DEBIAN_CODENAME}}/InRelease | grep " 2[0-9][0-9] " | wc -l) diff --git a/recipes/newrelic/infrastructure/suse.yml b/recipes/newrelic/infrastructure/suse.yml index 59dec6ef7..c77ff6722 100644 --- a/recipes/newrelic/infrastructure/suse.yml +++ b/recipes/newrelic/infrastructure/suse.yml @@ -78,6 +78,12 @@ install: echo "systemctl is required to install the newrelic infrastructure agent. Installation cannot proceed on this linux version." >> /dev/stderr exit 20 fi + - | + IS_SYSTEMCTL_AVAILABLE=$(sudo systemctl status | grep -i running | wc -l) + if [ $IS_SYSTEMCTL_AVAILABLE -eq 0 ] ; then + echo "systemctl is required to install the newrelic infrastructure agent. System has not been booted with systemd as init system. Installation cannot proceed on this linux version." >> /dev/stderr + exit 20 + fi - | IS_INFRA_AVAILABLE=$(curl -Is https://download.newrelic.com/infrastructure_agent/linux/zypp/sles/{{.SLES_VERSION}}/x86_64/newrelic-infra.repo | grep " 2[0-9][0-9] " | wc -l) if [ $IS_INFRA_AVAILABLE -eq 0 ] ; then diff --git a/recipes/newrelic/infrastructure/ubuntu.yml b/recipes/newrelic/infrastructure/ubuntu.yml index 78f8f8eb8..ab9706e1b 100644 --- a/recipes/newrelic/infrastructure/ubuntu.yml +++ b/recipes/newrelic/infrastructure/ubuntu.yml @@ -84,6 +84,12 @@ install: exit 20 fi fi + - | + IS_SYSTEMCTL_AVAILABLE=$(sudo systemctl status | grep -i running | wc -l) + if [ $IS_SYSTEMCTL_AVAILABLE -eq 0 ] ; then + echo "systemctl is required to install the newrelic infrastructure agent. System has not been booted with systemd as init system. Installation cannot proceed on this linux version." >> /dev/stderr + exit 20 + fi - | IS_INFRA_AVAILABLE=$(curl -Is https://download.newrelic.com/infrastructure_agent/linux/apt/dists/{{.DEBIAN_CODENAME}}/InRelease | grep " 2[0-9][0-9] " | wc -l) if [ $IS_INFRA_AVAILABLE -eq 0 ] ; then From 336762090b84f389a08e266650b1c2c5cc1e904d Mon Sep 17 00:00:00 2001 From: Julien Erard Date: Wed, 17 Mar 2021 09:33:05 -0700 Subject: [PATCH 2/2] Fix older ubuntus --- recipes/newrelic/infrastructure/ubuntu.yml | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/recipes/newrelic/infrastructure/ubuntu.yml b/recipes/newrelic/infrastructure/ubuntu.yml index ab9706e1b..5bbca47ec 100644 --- a/recipes/newrelic/infrastructure/ubuntu.yml +++ b/recipes/newrelic/infrastructure/ubuntu.yml @@ -85,10 +85,12 @@ install: fi fi - | - IS_SYSTEMCTL_AVAILABLE=$(sudo systemctl status | grep -i running | wc -l) - if [ $IS_SYSTEMCTL_AVAILABLE -eq 0 ] ; then - echo "systemctl is required to install the newrelic infrastructure agent. System has not been booted with systemd as init system. Installation cannot proceed on this linux version." >> /dev/stderr - exit 20 + if [ {{.DISTRIB_RELEASE}} -gt 14.04 ]; then + IS_SYSTEMCTL_AVAILABLE=$(sudo systemctl status | grep -i running | wc -l) + if [ $IS_SYSTEMCTL_AVAILABLE -eq 0 ] ; then + echo "systemctl is required to install the newrelic infrastructure agent. System has not been booted with systemd as init system. Installation cannot proceed on this linux version." >> /dev/stderr + exit 20 + fi fi - | IS_INFRA_AVAILABLE=$(curl -Is https://download.newrelic.com/infrastructure_agent/linux/apt/dists/{{.DEBIAN_CODENAME}}/InRelease | grep " 2[0-9][0-9] " | wc -l)