mirror of
https://github.com/netdata/netdata.git
synced 2021-06-06 23:03:21 +03:00
This PR adds (inactive) support that we will use to fill the gaps on chart when a receiving agent goes offline and the sender reconnects. The streaming component has been reworked to make the connection bi-directional and fix several outstanding bugs in the area. * Fixed an incorrect case of version negotiation. Removed fatal() on exhaustion of fds. * Fixed cases that fell through to polling the socket after closing. * Fixed locking of data related to sender and receiver in the host structure. * Added fine-grained locks to reduce contention. * Added circular buffer to sender to prevent starvation in high-latency conditions. * Fixed case where agent is a proxy and negotiated different streaming versions with sender and receiver. * Changed interface to new parser to put the buffering code in streaming. * Fixed the bug that stopped senders from reconnecting after their socket times out - this was part of the scaling fixes that provide an early shortcut path for rejecting connections without lock contention. * Uses fine-grained locking and a different approach to thread shutdown instead. * Added liveness detection to connections to allow selection of the best connection.
40 lines
1.3 KiB
Docker
40 lines
1.3 KiB
Docker
ARG DISTRO=arch
|
|
ARG VERSION=current
|
|
FROM netdata/package-builders:${DISTRO}${VERSION}
|
|
|
|
ARG ACLK=no
|
|
ARG EXTRA_CFLAGS
|
|
|
|
COPY . /opt/netdata/source
|
|
WORKDIR /opt/netdata/source
|
|
|
|
RUN git config --global user.email "root@container"
|
|
RUN git config --global user.name "Fake root"
|
|
|
|
# RUN make distclean -> not safe if tree state changed on host since last config
|
|
# Kill everything that is not in .gitignore preserving any fresh changes, i.e. untracked changes will be
|
|
# deleted but local changes to tracked files will be preserved.
|
|
RUN if git status --porcelain | grep '^[MADRC]'; then \
|
|
git stash && git clean -dxf && (git stash apply || true) \
|
|
else \
|
|
git clean -dxf ; \
|
|
fi
|
|
|
|
# Not everybody is updating distclean properly - fix.
|
|
RUN find . -name '*.Po' -exec rm \{\} \;
|
|
RUN rm -rf autom4te.cache
|
|
RUN rm -rf .git/
|
|
RUN find . -type f >/opt/netdata/manifest
|
|
|
|
RUN CFLAGS="-O1 -ggdb -Wall -Wextra -Wformat-signedness -fstack-protector-all -DNETDATA_INTERNAL_CHECKS=1\
|
|
-D_FORTIFY_SOURCE=2 -DNETDATA_VERIFY_LOCKS=1 ${EXTRA_CFLAGS}" ./netdata-installer.sh --disable-lto
|
|
|
|
RUN ln -sf /dev/stdout /var/log/netdata/access.log
|
|
RUN ln -sf /dev/stdout /var/log/netdata/debug.log
|
|
RUN ln -sf /dev/stderr /var/log/netdata/error.log
|
|
|
|
RUN rm /var/lib/netdata/registry/netdata.public.unique.id
|
|
|
|
CMD ["/usr/sbin/netdata","-D"]
|
|
ENTRYPOINT []
|