1.4.4-210 agent updated (#94)
This commit is contained in:
Родитель
23f929ed86
Коммит
e14782cae4
|
@ -0,0 +1,11 @@
|
|||
FROM ubuntu:16.04
|
||||
MAINTAINER OMSContainers@microsoft.com
|
||||
LABEL vendor=Microsoft\ Corp \
|
||||
com.microsoft.product="OMS Container Docker Provider" \
|
||||
com.microsoft.version="1.0.0-31"
|
||||
ENV tmpdir /opt
|
||||
RUN /usr/bin/apt-get update && /usr/bin/apt-get install -y libc-bin wget openssl curl sudo python-ctypes sysv-rc net-tools rsyslog cron vim dmidecode apt-transport-https && rm -rf /var/lib/apt/lists/*
|
||||
COPY setup.sh main.sh $tmpdir/
|
||||
WORKDIR ${tmpdir}
|
||||
RUN chmod 775 $tmpdir/*.sh; sync; $tmpdir/setup.sh
|
||||
CMD [ "/opt/main.sh" ]
|
|
@ -0,0 +1,80 @@
|
|||
#!/bin/bash
|
||||
|
||||
sed -i -e 's/bind 127.0.0.1/bind 0.0.0.0/g' /etc/opt/microsoft/omsagent/sysconf/omsagent.d/container.conf
|
||||
sed -i -e 's/bind 127.0.0.1/bind 0.0.0.0/g' /etc/opt/microsoft/omsagent/sysconf/omsagent.d/syslog.conf
|
||||
sed -i -e 's/^exit 101$/exit 0/g' /usr/sbin/policy-rc.d
|
||||
|
||||
#Using the get_hostname for hostname instead of the host field in syslog messages
|
||||
sed -i.bak "s/record\[\"Host\"\] = hostname/record\[\"Host\"\] = OMS::Common.get_hostname/" /opt/microsoft/omsagent/plugin/filter_syslog.rb
|
||||
|
||||
#using /var/opt/microsoft/docker-cimprov/state instead of /var/opt/microsoft/omsagent/state since the latter gets deleted during onboarding
|
||||
mkdir -p /var/opt/microsoft/docker-cimprov/state
|
||||
if [[ "$KUBERNETES_SERVICE_HOST" ]];then
|
||||
#kubernetes treats node names as lower case
|
||||
curl --unix-socket /var/run/docker.sock "http:/info" | python -c "import sys, json; print json.load(sys.stdin)['Name'].lower()" > /var/opt/microsoft/docker-cimprov/state/containerhostname
|
||||
else
|
||||
curl --unix-socket /var/run/docker.sock "http:/info" | python -c "import sys, json; print json.load(sys.stdin)['Name']" > /var/opt/microsoft/docker-cimprov/state/containerhostname
|
||||
fi
|
||||
#check if file was written successfully
|
||||
cat /var/opt/microsoft/docker-cimprov/state/containerhostname
|
||||
|
||||
#Setup sudo permission for containerlogtailfilereader
|
||||
chmod +w /etc/sudoers.d/omsagent
|
||||
echo "#run containerlogtailfilereader.rb for docker-provider" >> /etc/sudoers.d/omsagent
|
||||
echo "omsagent ALL=(ALL) NOPASSWD: /opt/microsoft/omsagent/ruby/bin/ruby /opt/microsoft/omsagent/plugin/containerlogtailfilereader.rb *" >> /etc/sudoers.d/omsagent
|
||||
chmod 440 /etc/sudoers.d/omsagent
|
||||
|
||||
#Disable dsc & copy container tailfilereader
|
||||
/opt/microsoft/omsconfig/Scripts/OMS_MetaConfigHelper.py --disable
|
||||
rm -f /etc/opt/microsoft/omsagent/conf/omsagent.d/omsconfig.consistencyinvoker.conf
|
||||
#cp -f /opt/microsoft/docker-cimprov/tailfilereader.rb /opt/microsoft/omsagent/plugin/.
|
||||
|
||||
#service omid start
|
||||
/opt/omi/bin/omiserver -s
|
||||
/opt/omi/bin/omiserver --configfile=/etc/opt/omi/conf/omiserver.conf -d
|
||||
|
||||
if [ -z $INT ]; then
|
||||
if [ -a /etc/omsagent-secret/DOMAIN ]; then
|
||||
/opt/microsoft/omsagent/bin/omsadmin.sh -w `cat /etc/omsagent-secret/WSID` -s `cat /etc/omsagent-secret/KEY` -d `cat /etc/omsagent-secret/DOMAIN`
|
||||
elif [ -a /etc/omsagent-secret/WSID ]; then
|
||||
/opt/microsoft/omsagent/bin/omsadmin.sh -w `cat /etc/omsagent-secret/WSID` -s `cat /etc/omsagent-secret/KEY`
|
||||
elif [ -a /run/secrets/DOMAIN ]; then
|
||||
/opt/microsoft/omsagent/bin/omsadmin.sh -w `cat /run/secrets/WSID` -s `cat /run/secrets/KEY` -d `cat /run/secrets/DOMAIN`
|
||||
elif [ -a /run/secrets/WSID ]; then
|
||||
/opt/microsoft/omsagent/bin/omsadmin.sh -w `cat /run/secrets/WSID` -s `cat /run/secrets/KEY`
|
||||
elif [ -z $DOMAIN ]; then
|
||||
/opt/microsoft/omsagent/bin/omsadmin.sh -w $WSID -s $KEY
|
||||
else
|
||||
/opt/microsoft/omsagent/bin/omsadmin.sh -w $WSID -s $KEY -d $DOMAIN
|
||||
fi
|
||||
else
|
||||
echo WORKSPACE_ID=$WSID > /etc/omsagent-onboard.conf
|
||||
echo SHARED_KEY=$KEY >> /etc/omsagent-onboard.conf
|
||||
/opt/microsoft/omsagent/bin/omsadmin.sh
|
||||
fi
|
||||
|
||||
#Hack for omi upgrade
|
||||
|
||||
/opt/omi/bin/omicli id
|
||||
/opt/omi/bin/omicli ei root/cimv2 Container_HostInventory
|
||||
|
||||
#service omsagent start
|
||||
#/opt/microsoft/omsagent/bin/service_control start
|
||||
|
||||
#check if agent onboarded successfully
|
||||
/opt/microsoft/omsagent/bin/omsadmin.sh -l
|
||||
|
||||
#get omsagent and docker-provider versions
|
||||
dpkg -l | grep omi | awk '{print $2 " " $3}'
|
||||
dpkg -l | grep omsagent | awk '{print $2 " " $3}'
|
||||
dpkg -l | grep docker-cimprov | awk '{print $2 " " $3}'
|
||||
|
||||
|
||||
shutdown() {
|
||||
/opt/omi/bin/service_control stop
|
||||
/opt/microsoft/omsagent/bin/service_control stop
|
||||
}
|
||||
|
||||
trap "shutdown" SIGTERM
|
||||
|
||||
sleep inf & wait
|
|
@ -0,0 +1,17 @@
|
|||
TMPDIR="/opt"
|
||||
cd $TMPDIR
|
||||
wget https://github.com/Microsoft/OMS-Agent-for-Linux/releases/download/OMSAgent_GA_v1.4.4-210/omsagent-1.4.4-210.universal.x64.sh
|
||||
wget https://github.com/Microsoft/Docker-Provider/releases/download/1.0.0-31/docker-cimprov-1.0.0-31.universal.x86_64.sh
|
||||
chmod 775 $TMPDIR/*.sh
|
||||
|
||||
$TMPDIR/omsagent-*.universal.x64.sh --extract
|
||||
mv $TMPDIR/omsbundle* $TMPDIR/omsbundle
|
||||
$TMPDIR/omsbundle/bundles/scx-1.6.*-*.universal.x64.sh --install
|
||||
/usr/bin/dpkg -i $TMPDIR/omsbundle/100/omsagent*.deb
|
||||
/usr/bin/dpkg -i $TMPDIR/omsbundle/100/omsconfig*.deb
|
||||
#/$TMPDIR/omsbundle/oss-kits/docker-cimprov-1.0.0-*.x86_64.sh --install
|
||||
#Use downloaded docker-provider instead of the bundled one
|
||||
/$TMPDIR/docker-cimprov-1.0.0-*.x86_64.sh --install
|
||||
rm -rf $TMPDIR/omsbundle
|
||||
rm -f $TMPDIR/omsagent*.sh
|
||||
rm -f $TMPDIR/docker-cimprov*.sh
|
Загрузка…
Ссылка в новой задаче