-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathstart.sh
executable file
·94 lines (70 loc) · 3.01 KB
/
start.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#!/bin/bash
set -o errexit
set -o pipefail
set -o nounset
DATAROOTDIR="/usr/share"
SYSCONFDIR="/etc"
SPHINXCFG="/etc/piler/sphinx.conf"
PILER_HOST=${PILER_HOST:-archive.yourdomain.com}
PILER_CONF="/etc/piler/piler.conf"
CONFIG_SITE_PHP="/etc/piler/config-site.php"
CONFIG_PHP="/var/piler/www/config.php"
create_mysql_db() {
echo "Creating mysql database"
sed -e "s%MYSQL_HOSTNAME%${MYSQL_HOSTNAME}%g" \
-e "s%MYSQL_DATABASE%${MYSQL_DATABASE}%g" \
-e "s%MYSQL_USERNAME%${PILER_USER}%g" \
-e "s%MYSQL_PASSWORD%${MYSQL_PILER_PASSWORD}%g" \
"${DATAROOTDIR}/piler/db-mysql-root.sql.in" | \
mysql -h "$MYSQL_HOSTNAME" -u root --password="$MYSQL_ROOT_PASSWORD"
mysql -h "$MYSQL_HOSTNAME" -u "$PILER_USER" --password="$MYSQL_PILER_PASSWORD" "$MYSQL_DATABASE" < "${DATAROOTDIR}/piler/db-mysql.sql"
echo "Done."
}
pre_seed_sphinx() {
echo "Writing sphinx configuration"
sed -e "s%MYSQL_HOSTNAME%${MYSQL_HOSTNAME}%" \
-e "s%MYSQL_DATABASE%${MYSQL_DATABASE}%" \
-e "s%MYSQL_USERNAME%${PILER_USER}%" \
-e "s%MYSQL_PASSWORD%${MYSQL_PILER_PASSWORD}%" \
-e "s%220%311%" \
-e "s%type = mysql%type = mysql\n sql_sock = /var/run/mysqld/mysqld.sock%" \
"${SYSCONFDIR}/piler/sphinx.conf.dist" > "$SPHINXCFG"
echo "Done."
echo "Initializing sphinx indices"
su "$PILER_USER" -c "indexer --all --config ${SYSCONFDIR}/piler/sphinx.conf"
echo "Done."
}
fix_configs() {
local piler_nginx_conf="/etc/piler/piler-nginx.conf"
if [[ ! -f "$PILER_CONF" ]]; then
cp /etc/piler/piler.conf.dist "$PILER_CONF"
chmod 640 "$PILER_CONF"
chown root:piler "$PILER_CONF"
sed -i "s%hostid=.*%hostid=${PILER_HOST%%:*}%" "$PILER_CONF"
sed -i "s%tls_enable=.*%tls_enable=1%" "$PILER_CONF"
sed -i "s%mysqlpwd=.*%mysqlpwd=${MYSQL_PILER_PASSWORD}%" "$PILER_CONF"
fi
if [[ ! -f "$piler_nginx_conf" ]]; then
cp /etc/piler/piler-nginx.conf.dist "$piler_nginx_conf"
sed -i "s%PILER_HOST%${PILER_HOST}%" "$piler_nginx_conf"
fi
ln -sf "$piler_nginx_conf" /etc/nginx/sites-enabled/piler
sed -i "s%HOSTNAME%${PILER_HOST}%" "$CONFIG_SITE_PHP"
sed -i "s%MYSQL_PASSWORD%${MYSQL_PILER_PASSWORD}%" "$CONFIG_SITE_PHP"
sed -i "s%^\$config\['DECRYPT_BINARY'\].*%\$config\['DECRYPT_BINARY'\] = '/usr/bin/pilerget';%" "$CONFIG_PHP"
sed -i "s%^\$config\['DECRYPT_ATTACHMENT_BINARY'\].*%\$config\['DECRYPT_ATTACHMENT_BINARY'\] = '/usr/bin/pileraget';%" "$CONFIG_PHP"
sed -i "s%^\$config\['PILER_BINARY'\].*%\$config\['PILER_BINARY'\] = '/usr/sbin/piler';%" "$CONFIG_PHP"
}
service rsyslog start
service mysql start
mysqlshow -h "$MYSQL_HOSTNAME" -u "$PILER_USER" --password="$MYSQL_PILER_PASSWORD" "$MYSQL_DATABASE" > /dev/null 2>&1 || create_mysql_db
pre_seed_sphinx
fix_configs
service cron start
service php7.2-fpm start
service nginx start
/etc/init.d/rc.searchd start
# fix for overlay, https://github.com/phusion/baseimage-docker/issues/198
touch /var/spool/cron/crontabs/piler
/etc/init.d/rc.piler start
while true; do sleep 120; done