nextcloud with nginx install on Archlinux
nextcloud with nginx install on Archlinux
Modules Install
$ yaourt -S nginx-mainline php-fpm php-gd php-intl php-mcrypt php-apcu nextcloud mariadb syslog-ng
Modules Setup
SYSLOG
$ systemctl enable syslog-ng
$ systemctl restart syslog-ng
PHP
/etc/php/php.ini
date.timezone = Asia/Shanghai
display_errors=On
extension=gd.so
extension=iconv.so
extension=intl.so
extension=mcrypt.so
extension=mysqli.so
zend_extension=opcache.so
extension=pdo_mysql.so
extension=zip.so
[opcache]
opcache.enable=1
opcache.enable_cli=1
/etc/php/conf.d/apcu.ini
extension=apcu.so
[apc]
apc.enable=1
apc.shm_size=32M
apc.ttl=7200
apc.enable_cli=1
MariaDB
$ mysql_install_db --user=mysql --basedir=/usr --datadir=/var/lib/mysql
$ systemctl enable mariadb
$ systemctl restart mariadb
$ mysql_secure_installation
Nginx
TLS/SSL
$ mkdir /etc/nginx/ssl
$ cd /etc/nginx/ssl
$ openssl req -new -x509 -nodes -newkey rsa:4096 $ -keyout server.key -out server.crt -days 1095
$ chmod 400 server.key
$ chmod 444 server.crt
PHP-FPM
/etc/php/php-fpm.d/www.conf
env[PATH] = /usr/local/bin:/usr/bin:/bin
$ systemctl enable php-fpm
$ systemctl restart php-fpm
NextCloud
Init DB
- $ mysql -u root -p
- mysql> CREATE DATABASE `nextcloud` DEFAULT CHARACTER SET `utf8` COLLATE `utf8_unicode_ci`;
- mysql> CREATE USER `nextcloud`@'localhost' IDENTIFIED BY 'xxxxx';
- mysql> GRANT ALL PRIVILEGES ON `nextcloud`.* TO `nextcloud`@`localhost`;
- mysql> \q
Nginx
$ mkdir /etc/nginx/conf.d/
$ touch /etc/nginx/conf.d/nextcloud.conf
/etc/nginx/nginx.conf
- http {
- include conf.d/*.conf
- ...
- }
/etc/nginx/conf.d/nextcloud.conf
- upstream php-handler {
- #server 127.0.0.1:9000;
- server unix:/var/run/php-fpm/php-fpm.sock;
- }
-
- #server {
- # listen 80;
- # server_name 45.63.49.131;
- # # enforce https
- # return 301 https://$server_name$request_uri;
- #}
-
- server {
- listen 8080;
- listen 443 ssl http2;
- ssl on;
- server_name 45.63.49.131;
-
- ssl_certificate ssl/server.crt;
- ssl_certificate_key ssl/server.key;
-
- # Add headers to serve security related headers
- # Before enabling Strict-Transport-Security headers please read into this
- # topic first.
- add_header Strict-Transport-Security "max-age=15768000;
- includeSubDomains; preload;";
- add_header X-Content-Type-Options nosniff;
- add_header X-Frame-Options "SAMEORIGIN";
- add_header X-XSS-Protection "1; mode=block";
- add_header X-Robots-Tag none;
- add_header X-Download-Options noopen;
- add_header X-Permitted-Cross-Domain-Policies none;
-
- # Path to the root of your installation
- root /usr/share/webapps/nextcloud/;
-
- location = /robots.txt {
- allow all;
- log_not_found off;
- access_log off;
- }
-
- # The following 2 rules are only needed for the user_webfinger app.
- # Uncomment it if you're planning to use this app.
- #rewrite ^/.well-known/host-meta /public.php?service=host-meta last;
- #rewrite ^/.well-known/host-meta.json /public.php?service=host-meta-json
- # last;
-
- location = /.well-known/carddav {
- return 301 $scheme://$host/remote.php/dav;
- }
- location = /.well-known/caldav {
- return 301 $scheme://$host/remote.php/dav;
- }
-
- # set max upload size
- client_max_body_size 512M;
- fastcgi_buffers 64 4K;
-
- # Disable gzip to avoid the removal of the ETag header
- gzip off;
-
- # Uncomment if your server is build with the ngx_pagespeed module
- # This module is currently not supported.
- #pagespeed off;
-
- error_page 403 /core/templates/403.php;
- error_page 404 /core/templates/404.php;
-
- location / {
- rewrite ^ /index.php$uri;
- }
-
- location ~ ^/(?:build|tests|config|lib|3rdparty|templates|data)/ {
- deny all;
- }
- location ~ ^/(?:\.|autotest|occ|issue|indie|db_|console) {
- deny all;
- }
-
- location ~ ^/(?:index|remote|public|cron|core/ajax/update|status|ocs/v[12]|updater/.+|ocs-provider/.+|core/templates/40[34])\.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_param HTTPS on;
- #Avoid sending the security headers twice
- fastcgi_param modHeadersAvailable true;
- fastcgi_param front_controller_active true;
- fastcgi_pass php-handler;
- fastcgi_intercept_errors on;
- fastcgi_request_buffering off;
- }
-
- location ~ ^/(?:updater|ocs-provider)(?:$|/) {
- try_files $uri/ =404;
- index index.php;
- }
-
- # Adding the cache control header for js and css files
- # Make sure it is BELOW the PHP block
- location ~* \.(?:css|js|woff|svg|gif)$ {
- try_files $uri /index.php$uri$is_args$args;
- add_header Cache-Control "public, max-age=7200";
- # Add headers to serve security related headers (It is intended to
- # have those duplicated to the ones above)
- # Before enabling Strict-Transport-Security headers please read into
- # this topic first.
- # add_header Strict-Transport-Security "max-age=15768000;
- # includeSubDomains; preload;";
- add_header X-Content-Type-Options nosniff;
- add_header X-Frame-Options "SAMEORIGIN";
- add_header X-XSS-Protection "1; mode=block";
- add_header X-Robots-Tag none;
- add_header X-Download-Options noopen;
- add_header X-Permitted-Cross-Domain-Policies none;
- # Optional: Don't log access to assets
- access_log off;
- }
-
- location ~* \.(?:png|html|ttf|ico|jpg|jpeg)$ {
- try_files $uri /index.php$uri$is_args$args;
- # Optional: Don't log access to other assets
- access_log off;
- }
- }
Set ownership on /usr/share/webapps/nextcloud
$ sudo chown http:http -R /usr/share/webapps/nextcloud
Generate /etc/webapps/nextcloud/config/php.config
$ cd /usr/share/webapps/nextcloud
$ sudo -u http php occ maintenance:install --database
"mysql" --database-host “localhost:/var/run/mysqld/mysqld.sock” --database-name “nextcloud” --database-user “nextcloud” --database-pass
"xxxx" --admin-user “llwang” --admin-pass “xxxx”
Import server.crt in ‘opera or chrome’
- 选项-->高级设置-->管理证书-->导入
$ opera “https://xxx.com:8080”