2016-02-07 20:02:44 +00:00
#!/bin/sh
set -e
2017-01-31 19:53:05 +00:00
CLICKHOUSE_USER=clickhouse
CLICKHOUSE_GROUP=${CLICKHOUSE_USER}
CLICKHOUSE_DATADIR=/var/lib/clickhouse
2017-01-31 21:36:13 +00:00
CLICKHOUSE_LOGDIR=/var/log/clickhouse-server
2017-01-31 19:53:05 +00:00
2018-03-01 20:16:03 +00:00
test -f /etc/default/clickhouse && . /etc/default/clickhouse
2017-01-31 19:53:05 +00:00
2017-01-09 13:42:29 +00:00
if [ "$1" = configure ]; then
2018-01-19 18:54:40 +00:00
if [ -x "/bin/systemctl" ] && [ -f /etc/systemd/system/clickhouse-server.service ] && [ -d /run/systemd/system ]; then
# if old rc.d service present - remove it
if [ -x "/etc/init.d/clickhouse-server" ]; then
update-rc.d clickhouse-server remove
echo "ClickHouse init script has migrated to systemd. Please manually stop old server and restart the service: sudo killall clickhouse-server && sleep 5 && sudo service clickhouse-server restart"
fi
/bin/systemctl daemon-reload
/bin/systemctl enable clickhouse-server
else
# If you downgrading to version older than 1.1.54336 run: systemctl disable clickhouse-server
if [ -x "/etc/init.d/clickhouse-server" ]; then
update-rc.d clickhouse-server defaults 19 19 >/dev/null || exit $?
fi
2017-10-11 15:00:34 +00:00
fi
# Make sure the administrative user exists
if ! getent passwd ${CLICKHOUSE_USER} > /dev/null; then
2018-03-27 11:29:11 +00:00
if [ "$OS" == "rhel" ] || [ "$OS" == "centos" ] || [ "$OS" == "fedora" ]; then
adduser --system --no-create-home --home /nonexistent \
--shell /bin/false clickhouse > /dev/null
else
adduser --system --disabled-login --no-create-home --home /nonexistent \
2018-03-28 02:38:07 +00:00
--shell /bin/false --group --gecos "ClickHouse server" clickhouse > /dev/null
2018-03-27 11:29:11 +00:00
fi
2017-10-11 15:00:34 +00:00
fi
# if the user was created manually, make sure the group is there as well
if ! getent group ${CLICKHOUSE_GROUP} > /dev/null; then
addgroup --system ${CLICKHOUSE_GROUP} > /dev/null
fi
# make sure user is in the correct group
if ! id -Gn ${CLICKHOUSE_USER} | grep -qw ${CLICKHOUSE_USER}; then
adduser ${CLICKHOUSE_USER} ${CLICKHOUSE_GROUP} > /dev/null
fi
# check validity of user and group
if [ "`id -u ${CLICKHOUSE_USER}`" -eq 0 ]; then
echo "The ${CLICKHOUSE_USER} system user must not have uid 0 (root).
2017-01-09 13:42:29 +00:00
Please fix this and reinstall this package." >&2
2017-10-11 15:00:34 +00:00
exit 1
fi
2017-01-09 13:42:29 +00:00
2017-10-11 15:00:34 +00:00
if [ "`id -g ${CLICKHOUSE_GROUP}`" -eq 0 ]; then
echo "The ${CLICKHOUSE_USER} system user must not have root as primary group.
2017-01-09 13:42:29 +00:00
Please fix this and reinstall this package." >&2
2017-10-11 15:00:34 +00:00
exit 1
fi
if [ ! -d ${CLICKHOUSE_DATADIR} ]; then
2017-10-11 19:07:03 +00:00
mkdir -p ${CLICKHOUSE_DATADIR}
chown ${CLICKHOUSE_USER}:${CLICKHOUSE_GROUP} ${CLICKHOUSE_DATADIR}
chmod 700 ${CLICKHOUSE_DATADIR}
2017-10-11 15:00:34 +00:00
fi
if [ ! -d ${CLICKHOUSE_LOGDIR} ]; then
mkdir -p ${CLICKHOUSE_LOGDIR}
chown root:${CLICKHOUSE_GROUP} ${CLICKHOUSE_LOGDIR}
# Allow everyone to read logs, root and clickhouse to read-write
chmod 775 ${CLICKHOUSE_LOGDIR}
fi
if [ -d ${CLICKHOUSE_LOGDIR} ]; then
2017-10-11 19:07:03 +00:00
# only for compatibility for old metrika user, remove string after 2017-06-01
2017-10-11 15:00:34 +00:00
su -s /bin/sh ${CLICKHOUSE_USER} -c "test -w ${CLICKHOUSE_LOGDIR}" || chown -R root:${CLICKHOUSE_GROUP} ${CLICKHOUSE_LOGDIR}; chmod -R ug+rw ${CLICKHOUSE_LOGDIR}
fi
# Clean old dynamic compilation results
if [ -d "${CLICKHOUSE_DATADIR}/build" ]; then
rm -f ${CLICKHOUSE_DATADIR}/build/*.cpp ${CLICKHOUSE_DATADIR}/build/*.so ||:
fi
2017-01-09 13:42:29 +00:00
2017-01-31 19:53:05 +00:00
fi