Update the agent setup scripts.

Refs #6107
This commit is contained in:
Gunnar Beutner 2014-05-12 14:46:02 +02:00
parent 5c54dc7846
commit 9864af3d12
2 changed files with 86 additions and 87 deletions

View File

@ -2,8 +2,12 @@
ICINGA2PKIDIR=@CMAKE_INSTALL_FULL_DATADIR@/icinga2/pki
ICINGA2CONFIG=@CMAKE_INSTALL_FULL_SYSCONFDIR@/icinga2
name=`hostname --fqdn`
echo "Agent name: $name"
if [ -n "$1" ]; then
if [ ! -e $ICINGA2CONFIG/pki/agent/agent.key ]; then
if [ ! -e $ICINGA2CONFIG/pki/$name.key ]; then
echo "You haven't generated a private key for this Icinga 2 instance"
echo "yet. Please run this script without any parameters to generate a key."
exit 1
@ -53,26 +57,8 @@ if [ -n "$1" ]; then
done
fi
while true; do
echo -n "Do you want this agent instance to listen on a TCP port? [y] "
if ! read listener; then
exit 1
fi
if [ "$listener" = "y" -o "$listener" = "n" -o -z "$listener" ]; then
break
fi
echo "Please enter 'y' or 'n'."
done
if [ -z "$listener" ]; then
listener=y
fi
listener_port=""
if [ "$listener" = "y" ]; then
while true; do
echo -n "Which TCP port should the agent listen on? [5665] "
if ! read listener_port; then
@ -85,7 +71,6 @@ if [ -n "$1" ]; then
if [ -z "$listener_port" ]; then
listener_port=5665
fi
fi
upstream_connect=n
@ -108,77 +93,88 @@ if [ -n "$1" ]; then
fi
if [ "$upstream_connect" = "y" ]; then
while true; do
echo -n "Master instance IP address/hostname: "
echo -n "Master instance IP address/hostname [$upstream_name]: "
if ! read upstream_host; then
exit 1
fi
if [ -n "$upstream_host" ]; then
break
if [ -z "$upstream_host" ]; then
upstream_host=$upstream_name
fi
echo "Please enter the master instance's hostname."
done
while true; do
echo -n "Master instace port: "
echo -n "Master instance port [5665]: "
if ! read upstream_port; then
exit 1
fi
if [ -n "$upstream_port" ]; then
break
if [ -z "$upstream_port" ]; then
upstream_port=5665
fi
echo "Please enter the master instance's port."
done
fi
fi
echo "Installing the certificate bundle..."
base64 -d < $1 | tar -C $ICINGA2CONFIG/pki/agent/ -zx || exit 1
chown @ICINGA2_USER@:@ICINGA2_GROUP@ $ICINGA2CONFIG/pki/agent/* || exit 1
base64 -d < $1 | tar -C $ICINGA2CONFIG/pki/ -zx || exit 1
chown @ICINGA2_USER@:@ICINGA2_GROUP@ $ICINGA2CONFIG/pki/* || exit 1
echo "Setting up agent configuration..."
cat >$ICINGA2CONFIG/features-available/agent.conf <<AGENT
echo "Setting up api.configuration..."
cat >$ICINGA2CONFIG/features-available/api.conf <<AGENT
/**
* The agent listener accepts checks from agents.
* The API listener is used for distributed monitoring setups.
*/
library "agent"
object ApiListener "api" {
cert_path = SysconfDir + "/icinga2/pki/" + NodeName + ".crt"
key_path = SysconfDir + "/icinga2/pki/" + NodeName + ".key"
ca_path = SysconfDir + "/icinga2/pki/ca.crt"
bind_port = "$listener_port"
}
object Endpoint NodeName {
host = NodeName
object AgentListener "agent" {
cert_path = SysconfDir + "/icinga2/pki/agent/agent.crt"
key_path = SysconfDir + "/icinga2/pki/agent/agent.key"
ca_path = SysconfDir + "/icinga2/pki/agent/ca.crt"
AGENT
if [ "$master" = "n" ]; then
cat >>$ICINGA2CONFIG/features-available/agent.conf <<AGENT
cat >>$ICINGA2CONFIG/features-available/api.conf <<AGENT
upstream_name = "$upstream_name"
AGENT
fi
if [ "$listener" = "y" ]; then
cat >>$ICINGA2CONFIG/features-available/agent.conf <<AGENT
bind_port = "$listener_port"
cat >>$ICINGA2CONFIG/features-available/api.conf <<AGENT
}
object Zone ZoneName {
AGENT
fi
if [ "$upstream_connect" = "y" ]; then
cat >>$ICINGA2CONFIG/features-available/agent.conf <<AGENT
upstream_host = "$upstream_host"
upstream_port = "$upstream_port"
cat >>$ICINGA2CONFIG/features-available/api.conf <<AGENT
parent = "$upstream_name"
AGENT
fi
cat >>$ICINGA2CONFIG/features-available/agent.conf <<AGENT
cat >>$ICINGA2CONFIG/features-available/api.conf <<AGENT
endpoints = [ NodeName ]
}
AGENT
echo "Enabling agent feature..."
@CMAKE_INSTALL_FULL_SBINDIR@/icinga2-enable-feature agent
if [ "$upstream_connect" = "y" ]; then
cat >>$ICINGA2CONFIG/features-available/api.conf <<AGENT
object Endpoint "$upstream_name" {
host = "$upstream_host"
port = "$upstream_port"
}
object Zone "$upstream_name" {
endpoints = [ "$upstream_name" ]
}
AGENT
fi
echo "Enabling API feature..."
@CMAKE_INSTALL_FULL_SBINDIR@/icinga2-enable-feature api
if [ ! -e "@CMAKE_INSTALL_FULL_SYSCONFDIR@/monitoring" ]; then
ln -s $ICINGA2CONFIG/conf.d/hosts/localhost @CMAKE_INSTALL_FULL_SYSCONFDIR@/monitoring
@ -196,28 +192,22 @@ AGENT
exit 0
fi
name=$(hostname --fqdn)
echo "Host name: $name"
mkdir -p $ICINGA2CONFIG/pki/agent
mkdir -p $ICINGA2CONFIG/pki
chmod 700 $ICINGA2CONFIG/pki
chown @ICINGA2_USER@:@ICINGA2_GROUP@ $ICINGA2CONFIG/pki || exit 1
chmod 700 $ICINGA2CONFIG/pki/agent
chown @ICINGA2_USER@:@ICINGA2_GROUP@ $ICINGA2CONFIG/pki/agent || exit 1
if [ -e $ICINGA2CONFIG/pki/agent/agent.key ]; then
echo "You already have agent certificates in $ICINGA2CONFIG/pki/agent/"
if [ -e $ICINGA2CONFIG/pki/$name.crt ]; then
echo "You already have agent certificates in $ICINGA2CONFIG/pki/"
exit 1
fi
REQ_COMMON_NAME="$name" KEY_DIR="$ICINGA2CONFIG/pki/agent" openssl req -config $ICINGA2PKIDIR/openssl-quiet.cnf -new -newkey rsa:4096 -keyform PEM -keyout $ICINGA2CONFIG/pki/agent/agent.key -outform PEM -out $ICINGA2CONFIG/pki/agent/agent.csr -nodes && \
chmod 600 $ICINGA2CONFIG/pki/agent/agent.key
REQ_COMMON_NAME="$name" KEY_DIR="$ICINGA2CONFIG/pki/" openssl req -config $ICINGA2PKIDIR/openssl-quiet.cnf -new -newkey rsa:4096 -keyform PEM -keyout $ICINGA2CONFIG/pki/$name.key -outform PEM -out $ICINGA2CONFIG/pki/$name.csr -nodes && \
chmod 600 $ICINGA2CONFIG/pki/$name.key
echo "Please sign the following CSR using the Agent CA:"
echo ""
cat $ICINGA2CONFIG/pki/agent/agent.csr
cat $ICINGA2CONFIG/pki/$name.csr
echo ""

View File

@ -28,12 +28,21 @@ fi
openssl x509 -days "$REQ_DAYS" -CA $ICINGA_CA/ca.crt -CAkey $ICINGA_CA/ca.key -req -in $ICINGA_CA/$csrfile -outform PEM -out $ICINGA_CA/$pubkfile.crt -CAserial $ICINGA_CA/serial
cn=`openssl x509 -in $pubkfile.crt -subject | grep -Eo '/CN=[^ ]+' | cut -f2- -d=`
case "$cn" in
*/*)
echo "commonName contains invalid character (/)."
exit 1
;;
esac
mv $pubkfile.crt $cn.crt
pubkfile=$cn
# Make an agent bundle file
mkdir -p $ICINGA_CA/agent
cp $ICINGA_CA/$pubkfile.crt $ICINGA_CA/agent/agent.crt
cp $ICINGA_CA/ca.crt $ICINGA_CA/agent/ca.crt
tar cz -C $ICINGA_CA/agent/ ca.crt agent.crt | base64 > $ICINGA_CA/$pubkfile.bundle
rm -rf $ICINGA_CA/agent
tar cz -C $ICINGA_CA $pubkfile.crt ca.crt | base64 > $ICINGA_CA/$pubkfile.bundle
echo "Done. $pubkfile.crt and $pubkfile.bundle files were written."
exit 0