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
|
|
|
CLICKHOUSE_SERVER_ETCDIR=/etc/clickhouse-server
|
|
|
|
|
|
|
|
|
2017-01-09 13:42:29 +00:00
|
|
|
if [ "$1" = configure ]; then
|
|
|
|
|
2017-10-11 15:00:34 +00:00
|
|
|
if [ -x "/etc/init.d/clickhouse-server" ]; then
|
|
|
|
update-rc.d clickhouse-server defaults 19 19 >/dev/null || exit $?
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Make sure the administrative user exists
|
|
|
|
if ! getent passwd ${CLICKHOUSE_USER} > /dev/null; then
|
|
|
|
adduser --system --disabled-login --no-create-home --home /nonexistent \
|
|
|
|
--shell /bin/false --group --gecos "Clickhouse server" clickhouse > /dev/null
|
|
|
|
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
|
|
|
|
|
|
|
|
|
|
|
|
if [ -d ${CLICKHOUSE_SERVER_ETCDIR} ]; then
|
|
|
|
# -R only for compatibility for old metrika user, remove -R after 2017-06-01
|
|
|
|
su -s /bin/sh ${CLICKHOUSE_USER} -c "test -w ${CLICKHOUSE_SERVER_ETCDIR}" || chown -R ${CLICKHOUSE_USER}:${CLICKHOUSE_GROUP} ${CLICKHOUSE_SERVER_ETCDIR}
|
|
|
|
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
|