首页 > 其他分享 >基于LNMP架构部署NextCloud私有云盘

基于LNMP架构部署NextCloud私有云盘

时间:2022-12-30 16:04:20浏览次数:41  
标签:nginx 云盘 LNMP header add always root localhost NextCloud

一、NextCloud介绍

1、简介

Nextcloud是一款开源免费的私有云存储网盘项目,可以让你快速便捷地搭建一套属于自己或团队的云同步网盘,从而实现跨平台跨设备文件同步、共享、版本控制、团队协作等功能。它的客户端覆盖了Windows、Mac、Android、iOS、Linux 等各种平台,也提供了网页端以及 WebDAV接口,所以你几乎可以在各种设备上方便地访问你的云盘。

Nextcloud也提供了许多应用安装,包括但不限于Markdown在线编辑、OnlyOffice(需另外部署服务端)、思维导图、日历等,你可以自行选择以丰富个人网盘的功能。

Nextcloud的服务端部署方式有很多种,本文采用基于LNMP环境源码安装。

2、Nextcloud部署

#本文采用的LNMP环境可参考我另一篇文章部署(LNMP环境部署

1)下载Nextcloud安装包

[root@localhost ~]# wget https://download.nextcloud.com/server/releases/nextcloud-18.0.1.tar.bz2

2)解压Nextcloud安装包

[root@localhost ~]# tar xf nextcloud-18.0.1.tar.bz2

3)拷贝Nextcloud到发布目录

[root@localhost ~]# mv nextcloud /usr/local/nginx/html

4)编辑Nginx.conf配置文件

[root@localhost ~]# vim /usr/local/nginx/conf/nginx.conf

#配置内容如下

  1. #定义Nginx运行的用户和用户组
  2. user www www;
  3. #启动进程,通常设置成和cpu的数量相等
  4. worker_processes auto;
  5. #定义最大打开文件数
  6. worker_rlimit_nofile 10240;
  7. #定义PID文件
  8. pid logs/nginx.pid;
  9. events {
  10. #epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能
  11. use epoll;
  12. #单个后台worker process进程的最大并发链接数 (最大连接数=连接数*进程数)
  13. worker_connections 10240;
  14. #尽可能多的接受请求
  15. multi_accept on;
  16. }
  17. http {
  18. #设定mime类型,类型由mime.type文件定义
  19. include mime.types;
  20. default_type application/octet-stream;
  21. #设定日志格式
  22. log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  23. '$status $body_bytes_sent "$http_referer" '
  24. '"$http_user_agent" "$http_x_forwarded_for"';
  25. #定义访问日志存放路径
  26. access_log logs/access.log main;
  27. #定义错误日志存放路径
  28. error_loglogs/error.log warn;
  29. #limit_req_zone定义在http块中,$binary_remote_addr表示保存客户端IP地址的二进制形式。Zone定义IP状态及URL访问频率的共享内存区域,zone=keyword标识区域的名字,以及冒号后面跟区域大小。16000个IP地址的状态信息约1MB,区域可以存储160000个IP地址Rate定义最大请求速率。速率不能超过每秒20个请求。
  30. limit_req_zone $binary_remote_addr zone=mylimit:10m rate=20r/s;
  31. #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用必须设为 on
  32. sendfile on;
  33. #防止网络阻塞
  34. tcp_nopush on;
  35. #keepalive超时时间,客户端到服务器端的连接持续有效时间,当出现对服务器的后继请求时,keepalive-timeout功能可避免建立或重新建立连接。(节省服务器资源、CPU、内存、网卡)
  36. keepalive_timeout 120;
  37. #提高数据的实时响应性
  38. tcp_nodelay on;
  39. #隐藏版本号
  40. #server_tokens off;
  41. #开启gzip压缩
  42. gzip on;
  43. #设置允许压缩的页面最小字节数
  44. gzip_min_length 1k;
  45. #设置系统获取几个单位的缓存用于存储gzip的压缩结果数据流。例如 4 4k 代表以4k为单位,按照原始数据大小以4k为单位的4倍申请内存。4 8k 代表以8k为单位,按照原始数据大小以8k为单位的4倍申请内存
  46. gzip_buffers 4 64k;
  47. #设置压缩响应所需的最小http协议版本
  48. gzip_http_version 1.1;
  49. #压缩级别大小,最大为9,值越小,压缩后比例越小,CPU处理更快,值越大,消耗CPU比较高。
  50. gzip_comp_level 4;
  51. #设置匹配MIME类型进行压缩
  52. gzip_types text/plain application/x-javascript text/css application/xml;
  53. #给CDN和代理服务器使用,针对相同url,可以根据头信息返回压缩和非压缩副本
  54. gzip_vary on;
  55. #允许客户端请求的最大单文件字节数
  56. client_max_body_size 10m;
  57. #缓冲区代理缓冲用户端请求的最大字节数
  58. client_body_buffer_size 128k;
  59. #nginx跟后端服务器连接超时时间(代理连接超时)
  60. proxy_connect_timeout 90;
  61. #后端服务器数据回传时间(代理发送超时)
  62. proxy_send_timeout 90;
  63. #连接成功后,后端服务器响应时间(代理接收超时)
  64. proxy_read_timeout 90;
  65. #设置代理服务器(nginx)保存用户头信息的缓冲区大小
  66. proxy_buffer_size 4k;
  67. #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
  68. proxy_buffers 4 32k;
  69. #高负荷下缓冲大小(proxy_buffers*2)
  70. proxy_busy_buffers_size 64k;
  71. #设定请求缓冲
  72. large_client_header_buffers 4 4k;
  73. #客户端请求头部的缓冲区大小,这个可以根据你的系统分页大小来设置,一般一个请求的头部大小不会超过1k,不过由于一般系统分页都要大于1k,所以这里设置为分页大小。分页大小可以用命令getconf PAGESIZE取得。
  74. client_header_buffer_size 4k;
  75. #这个将为打开文件指定缓存,默认是没有启用的,max指定缓存数量,建议和打开文件数一致,inactive是指经过多长时间文件没被请求后删除缓存
  76. open_file_cache max=102400 inactive=20s;
  77. #这个是指多长时间检查一次缓存的有效信息
  78. open_file_cache_valid 30s;
  79. #open_file_cache指令中的inactive参数时间内文件的最少使用次数,如果超过这个数字,文件描述符一直是在缓存中打开的
  80. open_file_cache_min_uses 1;
  81. #定义引用配置文件路径
  82. include domains/*.conf;
  83. }

5)编辑Nginx.conf配置文件

[root@localhost ~]# mkdir /usr/local/nginx/conf/domains

[root@localhost ~]# vim /usr/local/nginx/conf/domains/nextcloud.conf

  1. server {
  2. listen 80;
  3. server_name localhost;
  4. root html/nextcloud;
  5. access_log logs/access_nextcloud.log;
  6. error_log logs/error_nextcloud.log;
  7. add_header Referrer-Policy "no-referrer" always;
  8. add_header X-Content-Type-Options "nosniff" always;
  9. add_header X-Download-Options "noopen" always;
  10. add_header X-Frame-Options "SAMEORIGIN" always;
  11. add_header X-Permitted-Cross-Domain-Policies "none" always;
  12. add_header X-Robots-Tag "none" always;
  13. add_header X-XSS-Protection "1; mode=block" always;
  14. fastcgi_hide_header X-Powered-By;
  15. location ~ ^\/(?:index|remote|public|cron|core\/ajax\/update|status|ocs\/v[12]|updater\/.+|oc[ms]-provider\/.+)\.php(?:$|\/) {
  16. fastcgi_split_path_info ^(.+?\.php)(\/.*|)$;
  17. set $path_info $fastcgi_path_info;
  18. try_files $fastcgi_script_name =404;
  19. include fastcgi_params;
  20. fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  21. fastcgi_param PATH_INFO $path_info;
  22. fastcgi_param modHeadersAvailable true;
  23. fastcgi_param front_controller_active true;
  24. fastcgi_intercept_errors on;
  25. fastcgi_request_buffering off;
  26. fastcgi_pass 127.0.0.1:9000; #自定义
  27. }
  28. rewrite /.well-known/carddav /remote.php/dav permanent;
  29. rewrite /.well-known/caldav /remote.php/dav permanent;
  30. location / {
  31. rewrite ^ /index.php;
  32. }
  33. location ~ \.(?:png|html|ttf|ico|jpg|jpeg|bcmap)$ {
  34. try_files $uri /index.php$request_uri;
  35. access_log off;
  36. }
  37. location ~ ^\/(?:updater|oc[ms]-provider)(?:$|\/) {
  38. try_files $uri/ =404;
  39. index index.php;
  40. }
  41. location ~ ^\/(?:\.|autotest|occ|issue|indie|db_|console) {
  42. deny all;
  43. }
  44. location ~ ^\/(?:build|tests|config|lib|3rdparty|templates|data)\/ {
  45. deny all;
  46. }
  47. location ~ \.(?:css|js|woff2?|svg|gif|map)$ {
  48. try_files $uri /index.php$request_uri;
  49. add_header Cache-Control "public, max-age=15778463";
  50. add_header Referrer-Policy "no-referrer" always;
  51. add_header X-Content-Type-Options "nosniff" always;
  52. add_header X-Download-Options "noopen" always;
  53. add_header X-Frame-Options "SAMEORIGIN" always;
  54. add_header X-Permitted-Cross-Domain-Policies "none" always;
  55. add_header X-Robots-Tag "none" always;
  56. add_header X-XSS-Protection "1; mode=block" always;
  57. access_log off;
  58. }
  59. }

6)重启Nginx服务

[root@localhost ~]# /usr/local/nginx/sbin/nginx -t

[root@localhost ~]# /usr/local/nginx/sbin/nginx -s reload

7)创建Nextcloud数据库

[root@localhost ~]# mysql

mysql> create database nextcloud charset=utf8;

mysql> show grant on nextcloud.* to nextcloud@’localhost’ identified by‘123456’;

mysql> flush privileges;

8)创建NextCloud 数据存储目录、并为其设置权限

[root@localhost ~]# mkdir -p /usr/local/nginx/html/nextcloud/data

[root@localhost ~]# chown -R www.www /usr/local/nginx/html/nextcloud

9)确认所有服务都已全部启动

[root@localhost ~]# netstat -lntup

Active Internet connections (only servers)

Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program nam  

tcp        0      0 127.0.0.1:9000          0.0.0.0:*               LISTEN      679/php-fpm: master

tcp        0      0 0.0.0.0:3306         0.0.0.0:*               LISTEN      32182/mysqld       

tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      16792/nginx: worker

二、Nextcloud使用

1)初始化 NextCloud

提示:在浏览器中、输入服务器IP(192.168.0.117)即可出现如下界面

基于LNMP架构部署NextCloud私有云盘_php

2)按照提示输入相关信息

基于LNMP架构部署NextCloud私有云盘_缓存_02

点击安装完成即可

3)安装完成后,会出现以下界面

基于LNMP架构部署NextCloud私有云盘_nginx_03

至此,NextCloud私有网盘部署成功。

  • 编号6369,输入编号直达本文

标签:nginx,云盘,LNMP,header,add,always,root,localhost,NextCloud
From: https://blog.51cto.com/u_12018693/5980574

相关文章

  • LNMP环境自动化安装脚本
    一、脚本的环境介绍此脚本运行在RHEL(CentOS)6.4版本及以上运行此脚本需注意:1、主机需要能够上网2、需了解软件之间的相互依赖性。二、脚本的介绍脚本是由函数组成,每一个函数......
  • LNMP环境搭建Zabbix监控平台自动化安装脚本
    此脚本是LNMP环境搭建Zabbix监控平台自动化安装脚本,有需要朋友可以参考,脚本内容如下:系统环境:CentOS7.4软件版本:Nginx:1.16.1Mysql:5.7.29PHP:7.3.7Zabbix:4.4.3[root@localhost......
  • LNMP架构环境之PHP环境部署
    1)使用第三方扩展源安装php7.1#1)配置PHP安装源yum -yinstallepel-releasewget​​https://mirror.webtatic.com/yum/el7/webtatic-release.rpm​​--no-check-cert......
  • docker部署lnmp
    一、构建自定义docker网络12345systemctlstopfirewalldsystemctldisablefirewalldsetenforce0 dockernetworkcreate--subnet=172.18.0.0/16......
  • LNMP架构环境之Nginx项目1:搭建游戏网站
    1)配置站点目录cd/usr/share/nginx/rm-frhtml/通过SCP工具将gamme.zip上传到/usr/share/nginx/html/目录下#上传游戏程序unzipgame.zipcd /usr/share/nginx/sbin/2)......
  • LNMP架构环境之Nginx安装部署
    1.搭建准备#0)操作系统版本cat/etc/redhat-release#1)关闭selinux:setenforce0#临时关闭selinuxgetenforce#查看临时关闭情况sed-i's#SELINUX=enforcing#......
  • 第四章 docker 命令部署lnmp(link方式)
    docker-cli部署DNMP(docker+nginx+mysql(MariaDB)+PHP-FPM复查完成环境部署root@docker-debian:~#mkdir-p/opt/cli-lnmp/mysqlroot@docker-debian:~#mk......
  • 编译安装LNMP
    ......
  • vlc播放阿里云盘视频,可通过此方法解决网页无法读取视频内嵌字幕的问题
    1、在点击视频文件前,打开f12获取阿里云盘视频链接,复制download_url:  2、拼接vlc播放命令:./vlc.exe--http-referrer="https://www.aliyundrive.com/""第一步中的do......
  • Windows for Docker 搭建LNMP开发环境
    转载至《Docker-Windows上搭建LNMP环境》1windows安装DockerDesktop下载地址注:请仔细查看安装环境要求,否则容易做无用功Hyper-v如果开启的话电脑有装VMware的话会V......