Raspberry Pi Nextcloud image
This commit is contained in:
parent
49eadb84f9
commit
aa338c285d
60
rpi3/nextcloud/Dockerfile
Normal file
60
rpi3/nextcloud/Dockerfile
Normal file
@ -0,0 +1,60 @@
|
||||
FROM arm32v7/debian:stretch
|
||||
MAINTAINER Przemek Grondek <github@nerull7.info>
|
||||
|
||||
ENV NEXTCLOUD_VER 12.0.0
|
||||
|
||||
ENV DEBIAN_FRONTEND noninteractive
|
||||
RUN apt-get update && \
|
||||
apt-get install -y nginx mysql-server php-fpm php-mysql php-gd php-json php-curl php-intl php-mcrypt php-imagick php-zip php-xml php-mbstring php-smbclient pwgen bzip2 gosu supervisor cron && \
|
||||
apt-get clean
|
||||
|
||||
# Make required catalogs
|
||||
RUN mkdir -p /run/mysqld \
|
||||
/run/php
|
||||
|
||||
# Setup php
|
||||
RUN sed -i "s/;cgi.fix_pathinfo=1/cgi.fix_pathinfo=0/g" /etc/php/7.0/fpm/php.ini && \
|
||||
sed -i "s/;env\[HOSTNAME\] = $HOSTNAME/env\[HOSTNAME\] = $HOSTNAME/g" /etc/php/7.0/fpm/pool.d/www.conf && \
|
||||
sed -i "s/;env\[PATH\] = \/usr\/local\/bin:\/usr\/bin:\/bin/env\[PATH\] = \/usr\/local\/bin:\/usr\/bin:\/bin/g" /etc/php/7.0/fpm/pool.d/www.conf && \
|
||||
sed -i "s/;env\[TMP\] = \/tmp/env\[TMP\] = \/tmp/g" /etc/php/7.0/fpm/pool.d/www.conf && \
|
||||
sed -i "s/;env\[TMPDIR\] = \/tmp/env\[TMPDIR\] = \/tmp/g" /etc/php/7.0/fpm/pool.d/www.conf && \
|
||||
sed -i "s/;env\[TEMP\] = \/tmp/env\[TEMP\] = \/tmp/g" /etc/php/7.0/fpm/pool.d/www.conf
|
||||
|
||||
# Setup nginx
|
||||
ADD nextcloud /etc/nginx/sites-available/nextcloud
|
||||
RUN rm -rf /etc/nginx/sites-enabled/default && \
|
||||
ln -s /etc/nginx/sites-available/nextcloud /etc/nginx/sites-enabled/nextcloud && \
|
||||
sed -i "s/\/var\/log\/nginx/\/data\/nginx-log/g" /etc/nginx/nginx.conf
|
||||
|
||||
# Setup MySQL
|
||||
RUN sed -i "s/\/var\/lib\/mysql/\/data\/mysql/g" /etc/mysql/mariadb.conf.d/50-server.cnf && \
|
||||
chown mysql:mysql /var/run/mysqld
|
||||
|
||||
# Setup nextcloud
|
||||
RUN rm -rf /var/www/*
|
||||
ADD https://download.nextcloud.com/server/releases/nextcloud-${NEXTCLOUD_VER}.tar.bz2 /var/www
|
||||
RUN mv /var/www/nextcloud/* \
|
||||
/var/www/nextcloud/.htaccess \
|
||||
/var/www/nextcloud/.user.ini \
|
||||
/var/www && \
|
||||
rmdir /var/www/nextcloud && \
|
||||
echo "*/15 * * * * www-data php -f /var/www/cron.php" >> /etc/crontab
|
||||
|
||||
# Provision data
|
||||
RUN mkdir -p /provision/nextcloud && \
|
||||
cp -r /var/www/apps /provision/nextcloud && \
|
||||
cp -r /var/www/config /provision/nextcloud && \
|
||||
rm -rf /var/www/apps \
|
||||
/var/www/config && \
|
||||
ln -s /data/nextcloud/config /var/www && \
|
||||
ln -s /data/nextcloud/apps /var/www && \
|
||||
ln -s /data/nextcloud/data /var/www
|
||||
|
||||
EXPOSE 80
|
||||
VOLUME ["/data"]
|
||||
|
||||
COPY run.sh /
|
||||
COPY supervisord.conf /
|
||||
RUN chmod +x /run.sh
|
||||
|
||||
CMD /run.sh
|
63
rpi3/nextcloud/nextcloud
Normal file
63
rpi3/nextcloud/nextcloud
Normal file
@ -0,0 +1,63 @@
|
||||
server {
|
||||
listen 80 default_server;
|
||||
listen [::]:80 default_server;
|
||||
|
||||
root /var/www;
|
||||
index index.php;
|
||||
|
||||
# set max upload size
|
||||
client_max_body_size 10G;
|
||||
fastcgi_buffers 64 4K;
|
||||
|
||||
# Disable gzip to avoid the removal of the ETag header
|
||||
gzip off;
|
||||
|
||||
rewrite ^/caldav(.*)$ /remote.php/caldav$1 redirect;
|
||||
rewrite ^/carddav(.*)$ /remote.php/carddav$1 redirect;
|
||||
rewrite ^/webdav(.*)$ /remote.php/webdav$1 redirect;
|
||||
|
||||
index index.php;
|
||||
error_page 403 /core/templates/403.php;
|
||||
error_page 404 /core/templates/404.php;
|
||||
|
||||
location / {
|
||||
# The following 2 rules are only needed with webfinger
|
||||
rewrite ^/.well-known/host-meta /public.php?service=host-meta last;
|
||||
rewrite ^/.well-known/host-meta.json /public.php?service=host-meta-json last;
|
||||
|
||||
rewrite ^/.well-known/carddav /remote.php/carddav/ redirect;
|
||||
rewrite ^/.well-known/caldav /remote.php/caldav/ redirect;
|
||||
|
||||
rewrite ^(/core/doc/[^\/]+/)$ $1/index.html;
|
||||
|
||||
try_files $uri $uri/ /index.php;
|
||||
}
|
||||
|
||||
location = /robots.txt {
|
||||
allow all;
|
||||
log_not_found off;
|
||||
access_log off;
|
||||
}
|
||||
|
||||
location ~ ^/(?:\.htaccess|data|config|db_structure\.xml|README){
|
||||
deny all;
|
||||
}
|
||||
|
||||
location ~ \.php(?:$|/) {
|
||||
fastcgi_split_path_info ^(.+\.php)(/.+)$;
|
||||
include fastcgi_params;
|
||||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||
fastcgi_param PATH_INFO $fastcgi_path_info;
|
||||
fastcgi_pass unix:/run/php/php7.0-fpm.sock;
|
||||
fastcgi_read_timeout 300;
|
||||
}
|
||||
|
||||
# Optional: set long EXPIRES header on static assets
|
||||
location ~* \.(?:jpg|jpeg|gif|bmp|ico|png|css|js|swf)$ {
|
||||
expires 30d;
|
||||
# Optional: Don't log access to assets
|
||||
access_log off;
|
||||
}
|
||||
|
||||
}
|
||||
|
50
rpi3/nextcloud/run.sh
Normal file
50
rpi3/nextcloud/run.sh
Normal file
@ -0,0 +1,50 @@
|
||||
#!/bin/bash
|
||||
|
||||
function first_run() {
|
||||
echo FIRST RUN
|
||||
|
||||
mkdir -p /data/nextcloud \
|
||||
/data/nextcloud/config \
|
||||
/data/nextcloud/data \
|
||||
/data/nginx-log
|
||||
|
||||
cp -r /provision/nextcloud/apps /data/nextcloud
|
||||
cp -r /provision/nextcloud/config /data/nextcloud
|
||||
cp -r /var/lib/mysql /data
|
||||
|
||||
chown -R www-data:www-data /data/nextcloud /var/www
|
||||
chown -R mysql:mysql /data/mysql
|
||||
|
||||
SQL_ROOT_PASSWORD="$(pwgen -s -1 16)"
|
||||
SQL_NEXTCLOUD_PASSWORD="$(pwgen -s -1 16)"
|
||||
|
||||
mysqld_safe &
|
||||
|
||||
sleep 5
|
||||
|
||||
mysql -u root -e "
|
||||
CREATE USER 'nextcloud'@'localhost' IDENTIFIED BY '$SQL_NEXTCLOUD_PASSWORD';
|
||||
CREATE DATABASE nextcloud;
|
||||
GRANT ALL PRIVILEGES ON nextcloud . * TO nextcloud@localhost;
|
||||
FLUSH PRIVILEGES;"
|
||||
mysqladmin -u root password $SQL_ROOT_PASSWORD
|
||||
|
||||
cd /var/www
|
||||
gosu www-data php occ maintenance:install \
|
||||
--database "mysql" --database-name "nextcloud" \
|
||||
--database-user "nextcloud" --database-pass "$SQL_NEXTCLOUD_PASSWORD" \
|
||||
--admin-user "admin" --admin-pass "password"
|
||||
gosu www-data php occ background:cron
|
||||
|
||||
killall mysqld
|
||||
|
||||
touch /data/.provisioned
|
||||
|
||||
sleep 10
|
||||
}
|
||||
|
||||
if [ ! -f "/data/.provisioned" ];
|
||||
then
|
||||
first_run
|
||||
fi
|
||||
supervisord -n -c /supervisord.conf
|
15
rpi3/nextcloud/supervisord.conf
Normal file
15
rpi3/nextcloud/supervisord.conf
Normal file
@ -0,0 +1,15 @@
|
||||
[supervisord]
|
||||
[program:mysqld]
|
||||
command=mysqld_safe
|
||||
#numproc=1
|
||||
#autostart=true
|
||||
#autorestart=true
|
||||
|
||||
[program:nginx]
|
||||
command=nginx -g "daemon off;"
|
||||
|
||||
[program:php-fcgi]
|
||||
command=php-fpm7.0 -F
|
||||
|
||||
[program:cron]
|
||||
command=cron -f
|
Loading…
Reference in New Issue
Block a user