initial
This commit is contained in:
parent
2ff1a01073
commit
9d72b5ce01
|
@ -0,0 +1,16 @@
|
||||||
|
kind: pipeline
|
||||||
|
name: default
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: docker
|
||||||
|
image: plugins/docker
|
||||||
|
settings:
|
||||||
|
repo: sneak/netdata
|
||||||
|
username:
|
||||||
|
from_secret: docker_username
|
||||||
|
password:
|
||||||
|
from_secret: docker_password
|
||||||
|
auto_tag: true
|
||||||
|
tags:
|
||||||
|
- ${DRONE_COMMIT_SHA}
|
||||||
|
- ${DRONE_BRANCH}
|
|
@ -0,0 +1 @@
|
||||||
|
/update-releases.json
|
|
@ -0,0 +1,18 @@
|
||||||
|
FROM debian:jessie
|
||||||
|
|
||||||
|
ADD git-tag /git-tag
|
||||||
|
|
||||||
|
ADD scripts/build.sh /build.sh
|
||||||
|
ADD scripts/run.sh /run.sh
|
||||||
|
|
||||||
|
RUN chmod +x /run.sh /build.sh && sync && sleep 1 && /build.sh
|
||||||
|
|
||||||
|
WORKDIR /
|
||||||
|
|
||||||
|
ENV NETDATA_PORT=19999 SSMTP_TLS=YES SSMTP_SERVER=smtp.gmail.com SSMTP_PORT=587 SSMTP_HOSTNAME=localhost
|
||||||
|
|
||||||
|
ENV DO_NOT_TRACK=1
|
||||||
|
|
||||||
|
EXPOSE $NETDATA_PORT
|
||||||
|
|
||||||
|
ENTRYPOINT ["/run.sh"]
|
|
@ -0,0 +1,121 @@
|
||||||
|
Creative Commons Legal Code
|
||||||
|
|
||||||
|
CC0 1.0 Universal
|
||||||
|
|
||||||
|
CREATIVE COMMONS CORPORATION IS NOT A LAW FIRM AND DOES NOT PROVIDE
|
||||||
|
LEGAL SERVICES. DISTRIBUTION OF THIS DOCUMENT DOES NOT CREATE AN
|
||||||
|
ATTORNEY-CLIENT RELATIONSHIP. CREATIVE COMMONS PROVIDES THIS
|
||||||
|
INFORMATION ON AN "AS-IS" BASIS. CREATIVE COMMONS MAKES NO WARRANTIES
|
||||||
|
REGARDING THE USE OF THIS DOCUMENT OR THE INFORMATION OR WORKS
|
||||||
|
PROVIDED HEREUNDER, AND DISCLAIMS LIABILITY FOR DAMAGES RESULTING FROM
|
||||||
|
THE USE OF THIS DOCUMENT OR THE INFORMATION OR WORKS PROVIDED
|
||||||
|
HEREUNDER.
|
||||||
|
|
||||||
|
Statement of Purpose
|
||||||
|
|
||||||
|
The laws of most jurisdictions throughout the world automatically confer
|
||||||
|
exclusive Copyright and Related Rights (defined below) upon the creator
|
||||||
|
and subsequent owner(s) (each and all, an "owner") of an original work of
|
||||||
|
authorship and/or a database (each, a "Work").
|
||||||
|
|
||||||
|
Certain owners wish to permanently relinquish those rights to a Work for
|
||||||
|
the purpose of contributing to a commons of creative, cultural and
|
||||||
|
scientific works ("Commons") that the public can reliably and without fear
|
||||||
|
of later claims of infringement build upon, modify, incorporate in other
|
||||||
|
works, reuse and redistribute as freely as possible in any form whatsoever
|
||||||
|
and for any purposes, including without limitation commercial purposes.
|
||||||
|
These owners may contribute to the Commons to promote the ideal of a free
|
||||||
|
culture and the further production of creative, cultural and scientific
|
||||||
|
works, or to gain reputation or greater distribution for their Work in
|
||||||
|
part through the use and efforts of others.
|
||||||
|
|
||||||
|
For these and/or other purposes and motivations, and without any
|
||||||
|
expectation of additional consideration or compensation, the person
|
||||||
|
associating CC0 with a Work (the "Affirmer"), to the extent that he or she
|
||||||
|
is an owner of Copyright and Related Rights in the Work, voluntarily
|
||||||
|
elects to apply CC0 to the Work and publicly distribute the Work under its
|
||||||
|
terms, with knowledge of his or her Copyright and Related Rights in the
|
||||||
|
Work and the meaning and intended legal effect of CC0 on those rights.
|
||||||
|
|
||||||
|
1. Copyright and Related Rights. A Work made available under CC0 may be
|
||||||
|
protected by copyright and related or neighboring rights ("Copyright and
|
||||||
|
Related Rights"). Copyright and Related Rights include, but are not
|
||||||
|
limited to, the following:
|
||||||
|
|
||||||
|
i. the right to reproduce, adapt, distribute, perform, display,
|
||||||
|
communicate, and translate a Work;
|
||||||
|
ii. moral rights retained by the original author(s) and/or performer(s);
|
||||||
|
iii. publicity and privacy rights pertaining to a person's image or
|
||||||
|
likeness depicted in a Work;
|
||||||
|
iv. rights protecting against unfair competition in regards to a Work,
|
||||||
|
subject to the limitations in paragraph 4(a), below;
|
||||||
|
v. rights protecting the extraction, dissemination, use and reuse of data
|
||||||
|
in a Work;
|
||||||
|
vi. database rights (such as those arising under Directive 96/9/EC of the
|
||||||
|
European Parliament and of the Council of 11 March 1996 on the legal
|
||||||
|
protection of databases, and under any national implementation
|
||||||
|
thereof, including any amended or successor version of such
|
||||||
|
directive); and
|
||||||
|
vii. other similar, equivalent or corresponding rights throughout the
|
||||||
|
world based on applicable law or treaty, and any national
|
||||||
|
implementations thereof.
|
||||||
|
|
||||||
|
2. Waiver. To the greatest extent permitted by, but not in contravention
|
||||||
|
of, applicable law, Affirmer hereby overtly, fully, permanently,
|
||||||
|
irrevocably and unconditionally waives, abandons, and surrenders all of
|
||||||
|
Affirmer's Copyright and Related Rights and associated claims and causes
|
||||||
|
of action, whether now known or unknown (including existing as well as
|
||||||
|
future claims and causes of action), in the Work (i) in all territories
|
||||||
|
worldwide, (ii) for the maximum duration provided by applicable law or
|
||||||
|
treaty (including future time extensions), (iii) in any current or future
|
||||||
|
medium and for any number of copies, and (iv) for any purpose whatsoever,
|
||||||
|
including without limitation commercial, advertising or promotional
|
||||||
|
purposes (the "Waiver"). Affirmer makes the Waiver for the benefit of each
|
||||||
|
member of the public at large and to the detriment of Affirmer's heirs and
|
||||||
|
successors, fully intending that such Waiver shall not be subject to
|
||||||
|
revocation, rescission, cancellation, termination, or any other legal or
|
||||||
|
equitable action to disrupt the quiet enjoyment of the Work by the public
|
||||||
|
as contemplated by Affirmer's express Statement of Purpose.
|
||||||
|
|
||||||
|
3. Public License Fallback. Should any part of the Waiver for any reason
|
||||||
|
be judged legally invalid or ineffective under applicable law, then the
|
||||||
|
Waiver shall be preserved to the maximum extent permitted taking into
|
||||||
|
account Affirmer's express Statement of Purpose. In addition, to the
|
||||||
|
extent the Waiver is so judged Affirmer hereby grants to each affected
|
||||||
|
person a royalty-free, non transferable, non sublicensable, non exclusive,
|
||||||
|
irrevocable and unconditional license to exercise Affirmer's Copyright and
|
||||||
|
Related Rights in the Work (i) in all territories worldwide, (ii) for the
|
||||||
|
maximum duration provided by applicable law or treaty (including future
|
||||||
|
time extensions), (iii) in any current or future medium and for any number
|
||||||
|
of copies, and (iv) for any purpose whatsoever, including without
|
||||||
|
limitation commercial, advertising or promotional purposes (the
|
||||||
|
"License"). The License shall be deemed effective as of the date CC0 was
|
||||||
|
applied by Affirmer to the Work. Should any part of the License for any
|
||||||
|
reason be judged legally invalid or ineffective under applicable law, such
|
||||||
|
partial invalidity or ineffectiveness shall not invalidate the remainder
|
||||||
|
of the License, and in such case Affirmer hereby affirms that he or she
|
||||||
|
will not (i) exercise any of his or her remaining Copyright and Related
|
||||||
|
Rights in the Work or (ii) assert any associated claims and causes of
|
||||||
|
action with respect to the Work, in either case contrary to Affirmer's
|
||||||
|
express Statement of Purpose.
|
||||||
|
|
||||||
|
4. Limitations and Disclaimers.
|
||||||
|
|
||||||
|
a. No trademark or patent rights held by Affirmer are waived, abandoned,
|
||||||
|
surrendered, licensed or otherwise affected by this document.
|
||||||
|
b. Affirmer offers the Work as-is and makes no representations or
|
||||||
|
warranties of any kind concerning the Work, express, implied,
|
||||||
|
statutory or otherwise, including without limitation warranties of
|
||||||
|
title, merchantability, fitness for a particular purpose, non
|
||||||
|
infringement, or the absence of latent or other defects, accuracy, or
|
||||||
|
the present or absence of errors, whether or not discoverable, all to
|
||||||
|
the greatest extent permissible under applicable law.
|
||||||
|
c. Affirmer disclaims responsibility for clearing rights of other persons
|
||||||
|
that may apply to the Work or any use thereof, including without
|
||||||
|
limitation any person's Copyright and Related Rights in the Work.
|
||||||
|
Further, Affirmer disclaims responsibility for obtaining any necessary
|
||||||
|
consents, permissions or other rights required for any use of the
|
||||||
|
Work.
|
||||||
|
d. Affirmer understands and acknowledges that Creative Commons is not a
|
||||||
|
party to this document and has no duty or obligation with respect to
|
||||||
|
this CC0 or use of the Work.
|
|
@ -0,0 +1,54 @@
|
||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
DEBIAN_FRONTEND=noninteractive
|
||||||
|
|
||||||
|
# some mirrors have issues, i skipped httpredir in favor of an eu mirror
|
||||||
|
|
||||||
|
echo "deb http://ftp.nl.debian.org/debian/ jessie main" > /etc/apt/sources.list
|
||||||
|
echo "deb http://security.debian.org/debian-security jessie/updates main" >> /etc/apt/sources.list
|
||||||
|
|
||||||
|
# install dependencies for build
|
||||||
|
|
||||||
|
apt-get -qq update
|
||||||
|
apt-get -y install zlib1g-dev uuid-dev libmnl-dev gcc make curl git autoconf autogen automake pkg-config netcat-openbsd jq
|
||||||
|
apt-get -y install autoconf-archive lm-sensors nodejs python python-mysqldb python-yaml
|
||||||
|
apt-get -y install ssmtp mailutils apcupsd
|
||||||
|
|
||||||
|
# fetch netdata
|
||||||
|
|
||||||
|
git clone https://github.com/netdata/netdata.git /netdata.git
|
||||||
|
cd /netdata.git
|
||||||
|
TAG=$(</git-tag)
|
||||||
|
if [ ! -z "$TAG" ]; then
|
||||||
|
echo "Checking out tag: $TAG"
|
||||||
|
git checkout tags/$TAG
|
||||||
|
else
|
||||||
|
echo "No tag, using master"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# use the provided installer
|
||||||
|
|
||||||
|
./netdata-installer.sh --dont-wait --dont-start-it --disable-telemetry
|
||||||
|
|
||||||
|
touch /etc/netdata/.opt-out-from-anonymous-statistics
|
||||||
|
|
||||||
|
# removed hack on 2017/1/3
|
||||||
|
#chown root:root /usr/libexec/netdata/plugins.d/apps.plugin
|
||||||
|
#chmod 4755 /usr/libexec/netdata/plugins.d/apps.plugin
|
||||||
|
|
||||||
|
# remove build dependencies
|
||||||
|
|
||||||
|
cd /
|
||||||
|
rm -rf /netdata.git
|
||||||
|
|
||||||
|
dpkg -P zlib1g-dev uuid-dev libmnl-dev gcc make git autoconf autogen automake pkg-config
|
||||||
|
apt-get -y autoremove
|
||||||
|
apt-get clean
|
||||||
|
rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||||
|
|
||||||
|
|
||||||
|
# symlink access log and error log to stdout/stderr
|
||||||
|
|
||||||
|
ln -sf /dev/stdout /var/log/netdata/access.log
|
||||||
|
ln -sf /dev/stdout /var/log/netdata/debug.log
|
||||||
|
ln -sf /dev/stderr /var/log/netdata/error.log
|
|
@ -0,0 +1,110 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# fix permissions due to netdata running as root
|
||||||
|
chown root:root /usr/share/netdata/web/ -R
|
||||||
|
echo -n "" > /usr/share/netdata/web/version.txt
|
||||||
|
|
||||||
|
# set up ssmtp
|
||||||
|
if [[ $SSMTP_TO ]]; then
|
||||||
|
cat << EOF > /etc/ssmtp/ssmtp.conf
|
||||||
|
root=$SSMTP_TO
|
||||||
|
mailhub=$SSMTP_SERVER:$SSMTP_PORT
|
||||||
|
UseSTARTTLS=$SSMTP_TLS
|
||||||
|
hostname=$SSMTP_HOSTNAME
|
||||||
|
FromLineOverride=NO
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat << EOF > /etc/ssmtp/revaliases
|
||||||
|
netdata:netdata@$SSMTP_HOSTNAME:$SSMTP_SERVER:$SSMTP_PORT
|
||||||
|
root:netdata@$SSMTP_HOSTNAME:$SSMTP_SERVER:$SSMTP_PORT
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $SSMTP_USER ]]; then
|
||||||
|
cat << EOF >> /etc/ssmtp/ssmtp.conf
|
||||||
|
AuthUser=$SSMTP_USER
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $SSMTP_PASS ]]; then
|
||||||
|
cat << EOF >> /etc/ssmtp/ssmtp.conf
|
||||||
|
AuthPass=$SSMTP_PASS
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $SLACK_WEBHOOK_URL ]]; then
|
||||||
|
sed -i -e "s@SLACK_WEBHOOK_URL=\"\"@SLACK_WEBHOOK_URL=\"${SLACK_WEBHOOK_URL}\"@" /etc/netdata/health_alarm_notify.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $SLACK_CHANNEL ]]; then
|
||||||
|
sed -i -e "s@DEFAULT_RECIPIENT_SLACK=\"\"@DEFAULT_RECIPIENT_SLACK=\"${SLACK_CHANNEL}\"@" /etc/netdata/health_alarm_notify.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $DISCORD_WEBHOOK_URL ]]; then
|
||||||
|
sed -i -e "s@DISCORD_WEBHOOK_URL=\"\"@DISCORD_WEBHOOK_URL=\"${DISCORD_WEBHOOK_URL}\"@" /etc/netdata/health_alarm_notify.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $DISCORD_RECIPIENT ]]; then
|
||||||
|
sed -i -e "s@DEFAULT_RECIPIENT_DISCORD=\"\"@DEFAULT_RECIPIENT_DISCORD=\"${DISCORD_RECIPIENT}\"@" /etc/netdata/health_alarm_notify.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $TELEGRAM_BOT_TOKEN ]]; then
|
||||||
|
sed -i -e "s@TELEGRAM_BOT_TOKEN=\"\"@TELEGRAM_BOT_TOKEN=\"${TELEGRAM_BOT_TOKEN}\"@" /etc/netdata/health_alarm_notify.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $TELEGRAM_CHAT_ID ]]; then
|
||||||
|
sed -i -e "s@DEFAULT_RECIPIENT_TELEGRAM=\"\"@DEFAULT_RECIPIENT_TELEGRAM=\"${TELEGRAM_CHAT_ID}\"@" /etc/netdata/health_alarm_notify.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $PUSHBULLET_ACCESS_TOKEN ]]; then
|
||||||
|
sed -i -e "s@PUSHBULLET_ACCESS_TOKEN=\"\"@PUSHBULLET_ACCESS_TOKEN=\"${PUSHBULLET_ACCESS_TOKEN}\"@" /etc/netdata/health_alarm_notify.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $PUSHBULLET_DEFAULT_EMAIL ]]; then
|
||||||
|
sed -i -e "s#DEFAULT_RECIPIENT_PUSHBULLET=\"\"#DEFAULT_RECIPIENT_PUSHBULLET=\"${PUSHBULLET_DEFAULT_EMAIL}\"#" /etc/netdata/health_alarm_notify.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $NETDATA_IP ]]; then
|
||||||
|
NETDATA_ARGS="${NETDATA_ARGS} -i ${NETDATA_IP}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# on a client netdata set this destination to be the [PROTOCOL:]HOST[:PORT] of the
|
||||||
|
# central netdata, and give an API_KEY that is secret and only known internally
|
||||||
|
# to the netdata clients, and netdata central
|
||||||
|
if [[ $NETDATA_STREAM_DESTINATION ]] && [[ $NETDATA_STREAM_API_KEY ]]; then
|
||||||
|
cat << EOF > /etc/netdata/stream.conf
|
||||||
|
[stream]
|
||||||
|
enabled = yes
|
||||||
|
destination = $NETDATA_STREAM_DESTINATION
|
||||||
|
api key = $NETDATA_STREAM_API_KEY
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
|
||||||
|
# set 1 or more NETADATA_API_KEY_ENABLE env variables, such as NETDATA_API_KEY_ENABLE_1h213ch12h3rc1289e=1
|
||||||
|
# that matches the API_KEY that you used on the client above, this will enable the netdata client
|
||||||
|
# node to communicate with the netdata central
|
||||||
|
if printenv | grep -q 'NETDATA_API_KEY_ENABLE_'; then
|
||||||
|
printenv | grep -oe 'NETDATA_API_KEY_ENABLE_[^=]\+' | sed 's/NETDATA_API_KEY_ENABLE_//' | xargs -n1 -I{} echo '['{}$']\n\tenabled = yes' >> /etc/netdata/stream.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
# exec custom command
|
||||||
|
if [[ $# -gt 0 ]] ; then
|
||||||
|
exec "$@"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -d "/fakenet/" ]]; then
|
||||||
|
echo "Running fakenet config reload in background"
|
||||||
|
( sleep 10 ; curl -s http://localhost:${NETDATA_PORT}/netdata.conf | sed -e 's/# filename/filename/g' | sed -e 's/\/host\/proc\/net/\/fakenet\/proc\/net/g' > /etc/netdata/netdata.conf ; pkill -9 netdata ) &
|
||||||
|
/usr/sbin/netdata -D -u root -s /host -p ${NETDATA_PORT}
|
||||||
|
# add some artificial sleep because netdata might think it can't bind to $NETDATA_PORT
|
||||||
|
# and report things like "netdata: FATAL: Cannot listen on any socket. Exiting..."
|
||||||
|
sleep 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
for f in /etc/netdata/override/*; do
|
||||||
|
cp -a $f /etc/netdata/
|
||||||
|
done
|
||||||
|
|
||||||
|
# main entrypoint
|
||||||
|
exec /usr/sbin/netdata -D -u root -s /host -p ${NETDATA_PORT} ${NETDATA_ARGS} "$@"
|
Loading…
Reference in New Issue