利用NextCloud配置私有云
来源:互联网 发布:汽车内饰件图解知乎 编辑:程序博客网 时间:2024/05/22 06:37
利用NextCloud配置私有云
- 利用NextCloud配置私有云
- 安装MariaDB
- 为NextCloud创建数据库和用户
- 安装PHP和相关模块
- 下载NextCloud
- 安装配置Nginx
- 完成安装
NextCloud (https://nextcloud.com/) 是开源云盘服务器,此处利用 LEMP 搭建 NextCloud 运行环境-MariaDB, PHP-FPM 和 Nginx (Ubuntu 16.04)
1. 安装MariaDB
Ubuntu 16.04 安装 MariaDB
更新升级系统:
$ sudo apt update$ sudo apt upgrade
安装MariaDB:
$ sudo apt install mariadb-server
启动MariaDB服务:
$ sudo systemctl start mysql
查看状态:
$ sudo systemctl status mysql
执行初始化安全脚本,默认root密码为空,设置root密码和其他选项:
$ sudo mysql_secure_installation
2. 为NextCloud创建数据库和用户
创建数据库nextcloud;用户名nextcloud,密码XXXXXXXX
$ sudo mysql -u root -pMariaDB [(none)]> CREATE DATABASE nextcloud;MariaDB [(none)]> GRANT ALL PRIVILEGES ON nextcloud.* TO 'nextcloud'@'localhost' IDENTIFIED BY 'XXXXXXXX';MariaDB [(none)]> FLUSH PRIVILEGES;MariaDB [(none)]> \q
3. 安装PHP和相关模块
$ sudo apt-get -y install php-fpm php-cli php-json php-curl php-imap php-gd php-mysql php-xml php-zip php-intl php-mcrypt php-imagick php-mbstring
配置PHP:
$ sudo sed -i "s/memory_limit = .*/memory_limit = 512M/" /etc/php/7.0/fpm/php.ini$ sudo sed -i "s/;date.timezone.*/date.timezone = UTC/" /etc/php/7.0/fpm/php.ini$ sudo sed -i "s/;cgi.fix_pathinfo=1/cgi.fix_pathinfo=1/" /etc/php/7.0/fpm/php.ini$ sudo sed -i "s/upload_max_filesize = .*/upload_max_filesize = 200M/" /etc/php/7.0/fpm/php.ini$ sudo sed -i "s/post_max_size = .*/post_max_size = 200M/" /etc/php/7.0/fpm/php.ini
重启PHP-FPM:
$ sudo systemctl restart php7.0-fpm
4. 下载NextCloud
$ cd /tmp$ wget https://download.nextcloud.com/server/releases/nextcloud-12.0.0.zip
解压到 /var/www/ 目录并更改权限:
$ unzip nextcloud-12.0.0.zip$ sudo mkdir /var/www/$ sudo mv nextcloud /var/www/$ sudo chown -R www-data: /var/www/nextcloud
5. 安装配置Nginx
$ sudo apt-get install nginx nginx-extras
生成自签名证书:
$ sudo mkdir -p /etc/nginx/ssl$ cd /etc/nginx/ssl$ sudo openssl genrsa -des3 -passout pass:x -out nextcloud.pass.key 2048$ sudo openssl rsa -passin pass:x -in nextcloud.pass.key -out nextcloud.key$ sudo rm nextcloud.pass.key$ sudo openssl req -new -key nextcloud.key -out nextcloud.csr$ sudo openssl x509 -req -days 365 -in nextcloud.csr -signkey nextcloud.key -out nextcloud.crt
也可使用免费的 let encrypt,创建Nginx server block文件:
$ sudo vim /etc/nginx/sites-available/nextcloud
server { listen 80; server_name pan.csxiaoyao.com; return 301 https: //$server_name$request_uri;}server { listen 443 ssl http2; server_name pan.csxiaoyao.com; root / var / www / nextcloud; ssl on; ssl_certificate / etc / nginx / ssl / nextcloud.crt; ssl_certificate_key / etc / nginx / ssl / nextcloud.key; ssl_session_timeout 5m; ssl_ciphers 'AES128+EECDH:AES128+EDH:!aNULL'; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_prefer_server_ciphers on; 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; access_log / var / log / nginx / nextcloud.access.log; error_log / var / log / nginx / nextcloud.error.log; location = /robots.txt { allow all; log_not_found off; access_log off; } location = /.well - known / carddav { return 301 $scheme: //$host/remote.php/dav; } location = /.well-known/caldav { return 301 $scheme: //$host/remote.php/dav; } client_max_body_size 512M; fastcgi_buffers 64 4K; gzip 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( ? : $ | /) { include fastcgi_params; fastcgi_split_path_info ^(.+.php)(/. + ) $; 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 unix: /var/run / php / php7.0 - fpm.sock; fastcgi_intercept_errors on; fastcgi_request_buffering off; } location~ ^ /(?:updater|ocs-provider)(?:$|/) { try_files $uri / = 404; index index.php; } location~ * .( ? : css | js) $ { try_files $uri / index.php$uri$is_args$args; add_header Cache - Control "public, max-age=7200"; 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 ~* .(?:svg|gif|png|html|ttf|woff|ico|jpg|jpeg)$ { try_files $uri /index.php$uri$is_args$args; access_log off; } location ~ /.ht { deny all; }}
创建链接:
$ sudo ln -s /etc/nginx/sites-available/nextcloud /etc/nginx/sites-enabled/nextcloud
测试Nginx配置文件:
$ sudo nginx -t
重启nginx:
$ sudo systemctl restart nginx
6. 完成安装
浏览器访问 https://pan.csxiaoyao.com,设置管理员账户和数据库
阅读全文
0 0
- 利用NextCloud配置私有云
- 部署Nextcloud私有云
- 【技术干货】下一代私有云盘 NextCloud 的安装配置
- 编译安装环境部署Nextcloud私有云
- 阿里云Ubuntu16.04搭建LAMP+私有云nextcloud
- 树莓派使用owncloud或者nextcloud建立私有云
- docker+nextcloud搭建个人云存储系统
- 利用百度网盘配置私有Git服务
- 利用 QGA 来助力 OpenStack 私有云
- 利用 Serving 搭建 TensorFlow 私有云服务
- nextcloud——搭建自己的云盘
- Ubuntu12.04下配置OwnCloud私有云
- 如何利用 BTSync 在VPS上搭建私有云储存
- 利用反射测试私有方法
- 利用dropbox建立私有Repo
- 利用反射调用私有方法
- tomcat配置私有数据源
- docker 私有仓库配置
- bzoj 1069: [SCOI2007]最大土地面积(旋转卡壳)
- linux和window 双系统文件修改
- python 基础脚本练习
- MacOS上添加到某网络的路由
- Android--Android6.0版的Notification配置
- 利用NextCloud配置私有云
- 搬货物
- python练习1
- 找了很久的低功耗蓝牙程序开发,终于在国外找到了部分资料
- javascript的数据类型与复制模式
- VMware Player安装Ubuntu12.04后黑屏的问题
- dedecms列表标签重点归纳
- 51Nod-1456-小K的技术
- bzoj 1024: [SCOI2009]生日快乐