mirror of
https://github.com/mastodon/mastodon.git
synced 2024-12-31 15:31:05 +01:00
[Nanobox] Enable ElasticSearch support by default (#6977)
Admins can still disable the feature by adding `ES_ENABLED=false` to their environment, if they prefer not to use it. Be sure to set the variable before you deploy!
This commit is contained in:
parent
fb3dc00dda
commit
3886bfb5eb
2 changed files with 34 additions and 3 deletions
|
@ -14,9 +14,9 @@ DB_PORT=5432
|
||||||
DATABASE_URL=postgresql://$DATA_DB_USER:$DATA_DB_PASS@$DATA_DB_HOST/gonano
|
DATABASE_URL=postgresql://$DATA_DB_USER:$DATA_DB_PASS@$DATA_DB_HOST/gonano
|
||||||
|
|
||||||
# Optional ElasticSearch configuration
|
# Optional ElasticSearch configuration
|
||||||
# ES_ENABLED=true
|
ES_ENABLED=true
|
||||||
# ES_HOST=localhost
|
ES_HOST=$DATA_ELASTIC_HOST
|
||||||
# ES_PORT=9200
|
ES_PORT=9200
|
||||||
|
|
||||||
# Optimizations
|
# Optimizations
|
||||||
LD_PRELOAD=/data/lib/libjemalloc.so
|
LD_PRELOAD=/data/lib/libjemalloc.so
|
||||||
|
|
31
boxfile.yml
31
boxfile.yml
|
@ -61,6 +61,11 @@ deploy.config:
|
||||||
before_live:
|
before_live:
|
||||||
web.web:
|
web.web:
|
||||||
- bundle exec rake db:migrate:setup
|
- bundle exec rake db:migrate:setup
|
||||||
|
- |-
|
||||||
|
if [[ "${ES_ENABLED}" != "false" ]]
|
||||||
|
then
|
||||||
|
bundle exec rake chewy:deploy
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
web.web:
|
web.web:
|
||||||
|
@ -208,6 +213,32 @@ data.db:
|
||||||
done
|
done
|
||||||
|
|
||||||
|
|
||||||
|
data.elastic:
|
||||||
|
image: nanobox/elasticsearch:5
|
||||||
|
|
||||||
|
cron:
|
||||||
|
- id: backup
|
||||||
|
schedule: '0 3 * * *'
|
||||||
|
command: |
|
||||||
|
id=$(cat /proc/sys/kernel/random/uuid)
|
||||||
|
curl -X PUT -H "Content-Type: application/json" "127.0.0.1:9200/_snapshot/${id}" -d "{\"type\": \"fs\",\"settings\": {\"location\": \"/var/tmp/${id}\",\"compress\": true}}"
|
||||||
|
curl -X PUT -H "Content-Type: application/json" "127.0.0.1:9200/_snapshot/${id}/backup?wait_for_completion=true&pretty"
|
||||||
|
tar -cz -C "/var/tmp/${id}" . |
|
||||||
|
curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/backup-${HOSTNAME}-$(date -u +%Y-%m-%d.%H-%M-%S).tgz -X POST -T - >&2
|
||||||
|
curl -X DELETE -H "Content-Type: application/json" "127.0.0.1:9200/_snapshot/${id}"
|
||||||
|
rm -rf "/var/tmp/${id}"
|
||||||
|
curl -k -s -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/ |
|
||||||
|
sed 's/,/\n/g' |
|
||||||
|
grep ${HOSTNAME} |
|
||||||
|
sort |
|
||||||
|
head -n-${BACKUP_COUNT:-1} |
|
||||||
|
sed 's/.*: \?"\(.*\)".*/\1/' |
|
||||||
|
while read file
|
||||||
|
do
|
||||||
|
curl -k -H "X-AUTH-TOKEN: ${WAREHOUSE_DATA_HOARDER_TOKEN}" https://${WAREHOUSE_DATA_HOARDER_HOST}:7410/blobs/${file} -X DELETE
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
data.redis:
|
data.redis:
|
||||||
image: nanobox/redis:4.0
|
image: nanobox/redis:4.0
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue