#!/usr/bin/env sh LOG_FILE=/var/log/rpxy/rpxy.log CONFIG_FILE=/etc/rpxy.toml LOG_SIZE=10M LOG_NUM=10 # logrotate if [ $LOGROTATE_NUM ]; then LOG_NUM=${LOGROTATE_NUM} fi if [ $LOGROTATE_SIZE ]; then LOG_SIZE=${LOGROTATE_SIZE} fi cat > /etc/logrotate.conf << EOF # see "man logrotate" for details # rotate log files weekly weekly # use the adm group by default, since this is the owning group # of /var/log/syslog. su root adm # keep 4 weeks worth of backlogs rotate 4 # create new (empty) log files after rotating old ones create # use date as a suffix of the rotated file #dateext # uncomment this if you want your log files compressed #compress # packages drop log rotation information into this directory include /etc/logrotate.d # system-specific logs may be also be configured here. EOF cat > /etc/logrotate.d/rpxy << EOF ${LOG_FILE} { dateext daily missingok rotate ${LOG_NUM} notifempty compress delaycompress dateformat -%Y-%m-%d-%s size ${LOG_SIZE} copytruncate } EOF cp -p /etc/cron.daily/logrotate /etc/cron.hourly/ service cron start # debug level logging if [ -z $LOG_LEVEL ]; then LOG_LEVEL=info fi echo "rpxy: Logging with level ${LOG_LEVEL}" RUST_LOG=${LOG_LEVEL} /opt/rpxy/sbin/rpxy --config ${CONFIG_FILE}