搭建Nextcloud

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 安装 私有云盘,mysql nginx redis php等组件
                     Nextcloud搭建

第一步 install start download
cd /usr/loacal/src
wget https://download.nextcloud.com/server/releases/nextcloud-13.0.2.tar.bz2
tar -jxf nextcloud-13.0.2.tar.bz2
mkdir -p /data/www
mv nextcloud /data/www
chown -R nginx. /data/www/nextcloud
useradd -s /sbin/nologin/ nginx -M
第二步骤 安装nginx
安装依赖
yum install gcc--c++ pcre pcre-devel zlib zlib-devel op
enssl openssl-devel -y
编译
./configure --prefix=/usr/local/nginx --pid-path
=/var/run/nginx/nginx.pid --lock-path=/var/lock/nginx.lock --error-log-path=/va
r/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --with-http_gzi
p_static_module --http-client-body-temp-path=/var/temp/nginx/client --http-prox
y-temp-path=/var/temp/nginx/proxy --http-fastcgi-temp-path=/var/temp/nginx/fast
cgi --http-uwsgi-temp-path=/var/temp/nginx/uwsgi --http-scgi-temp-path=/var/tem
--with-http_ssl_module
创建nginx temp目录
mkdir -p /var/temp/nginx
make install

启动 nginx
/usr/local/nginx/sbin/nginx
第三步install mariadb
yum install mariadb mariadb-server -y
vim /etc/my.cnf
[client]
default-character-set=utf8mb64
[mysql]
default-character-set=utf8mb64
[mysqld]
character-set-server=utf8mb64
collection-server=utf8mb64_unicode_cli
innodb_large_prefix=ON
innodb_file_format=Barracuda
innodb_file_per_table=ON
innodb_file_per_table=1
default-storage-engine = INNODB
初始化设置
/usr/bin/mysql_install_db --user=mysql --datadir=/var/lib/mysql
开启mysql服务
systemctl restart mariadb
创建数据库
create database nextcloud CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
授权操作
grant all privileges on nextcloud.* to "nextcloud"@"%" identified by "nextcloud";
grant all privileges on nextcloud.* to "nextcloud"@"localhost" identified by "nextcloud";
刷新权限
flush privileges;
第四步安装php相关
wget https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
wget https://rpms.remirepo.net/enterprise/remi-release-7.rpm
rpm -Uvh remi-release-7.rpm epel-release-latest-7.noarch.rpm
subscription-manager repos --enable=rhel-6-server-optional-rpms
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
yum -y install php70w-fpm php70w-cli php70w-opcache php70w-gd php70w-mcrypt php70w-mysql php70w-pear php70w-xml php70w-mbstring php70w-pdo php70w-json php70w-pecl-apcu php70w-pecl-apcu-devel
验证php7的版本
php -v
配置php-fpm
sed -i "/^user =/s/apache/nginx/g" /etc/php-fpm.d/www.conf

sed -i '/^ugroup =/s/apache/nginx/g' /etc/php-fpm.d/www.conf

更改授权用户

mkdir -p /var/lib/php/session
chown nginx:nginx -R /var/lib/php/session/
最后 nginx的配置

vim vhost/*.conf
upstream php-handler {

    server 127.0.0.1:9000;
    }
server {
    listen       80;
    server_name  localhost;
    add_header Referrer-Policy "no-referrer" always;
    add_header X-Frame-Options "SAMEORIGIN" always;
    add_header X-Permitted-Cross-Domain-Policies "none" always;
    add_header X-Robots-Tag "none" always;
    add_header X-XSS-Protection "1; mode=block" always;
    # Remove X-Powered-By, which is an information leak
    fastcgi_hide_header X-Powered-By;
    root /data/www/nextcloud;

    location = /robots.txt {
        allow all;
        log_not_found off;
        access_log off;
    }

    location = /.well-known/carddav {
      return 301 $scheme://$host:$server_port/remote.php/dav;
    }
    location = /.well-known/caldav {
      return 301 $scheme://$host:$server_port/remote.php/dav;
    }




    location / {
         rewrite ^ /index.php;
    }

    location ~ ^\/(?:build|tests|config|lib|3rdparty|templates|data)\/ {
        deny all;
    }
    location ~ ^\/(?:\.|autotest|occ|issue|indie|db_|console) {
        deny all;
    }                                                                                                                      
                                                                                                                           
    error_page   500 502 503 504  /50x.html;                                                                               
    location = /50x.html {                                                                                                 
        root   html;                                                                                                       
    }                                                                                                                      
                                                                                                                           
                                                                                                                           
        root /data/www/nextcloud;                                                                                          
        fastcgi_pass 127.0.0.1:9000;                                                                                       
        fastcgi_index index.php;                                                                                           
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;                                                  
        fastcgi_split_path_info ^(.+?\.php)(\/.*|)$;                                                                       
        fastcgi_param PATH_INFO $fastcgi_path_info;                                                                        
        include fastcgi_params;                                                                                            
    }                                                                                                                      
                                                                                                                           
#    location ~ \.php$ {                                                                                                   
#        if (!-e $request_filename) {                                                                                      
#               rewrite ^/(.*)$ /index.php/$1 last;                                                                        
#        }                                                                                                                 
#        root           /usr/local/nginx/html/nextcloud;                                                                   
#        fastcgi_pass   127.0.0.1:9000;                                                                                    
#        fastcgi_index  index.php;                                                                                         
#        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;                                               
#        include        fastcgi_params;                                                                                    
#    }                                                                                                                     
     location ~ ^\/(?:updater|oc[ms]-provider)(?:$|\/) {                                                                   
          try_files $uri/ =404;                                                                                            
          index index.php;                                                                                                 
        add_header Cache-Control "public, max-age=15778463";                                                               
        # 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;" always;                      
        #                                                                                                                  
        # WARNING: Only add the preload option once you read about                                                         
        # the consequences in https://hstspreload.org/. This option                                                        
        # will add the domain to a hardcoded list that is shipped                                                          
        # in all major browsers and getting removed from this list                                                         
        # could take several months.                                                                                       
        add_header Referrer-Policy "no-referrer" always;                                                                   
        add_header X-Content-Type-Options "nosniff" always;                                                                
        add_header X-Download-Options "noopen" always;
        add_header X-Frame-Options "SAMEORIGIN" always;                                                                    
        add_header X-Permitted-Cross-Domain-Policies "none" always;                                                        
        add_header X-Robots-Tag "none" always;                                                                             
        add_header X-XSS-Protection "1; mode=block" always;                                                                
                                                                                                                           
        # Optional: Don't log access to assets                                                                             
        access_log off;                                                                                                    
     }                                                                                                                     
    location ~ \.(?:png|html|ttf|ico|jpg|jpeg|bcmap|mp4|webm)$ {                                                           
        try_files $uri /index.php$request_uri;                                                                             
        # Optional: Don't log access to other assets                                                                       
        access_log off;                                                                                                    
    }                                                                                                                      
                                                                                                                           
    # set max upload size                                                                                                  
    client_max_body_size 512M;                                                                                             
    fastcgi_buffers 64 4K;                                                                                                 
    # Enable gzip but do not remove ETag headers                                                                           
    gzip on;                                                                                                               
    gzip_vary on;                                                                                                          
    gzip_comp_level 4;                                                                                                     
    gzip_min_length 256;                                                                                                   
    gzip_proxied expired no-cache no-store private no_last_modified no_etag auth;                                          
    gzip_types application/atom+xml application/javascript application/json application/ld+json application/manifest+json application/rss+xml

application/vnd.geo+json application/vnd.ms-fontobject application/x-font-ttf application/x-web-app-manifest+json application/xhtml+xml applicat
ion/xml font/opentype image/bmp image/svg+xml image/x-icon text/cache-manifest text/css text/plain text/vcard text/vnd.rim.location.xloc text/vtt
text/x-component text/x-cross-domain-policy;
}
Systemctl restart mariadb
Systemctl start php-fpm
/usr/local/nginx/sbin/nginx -s reload

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
8月前
|
关系型数据库 MySQL 数据库
如何使用Docker部署开源CMF Drupal并结合cpolar内网穿透远程访问
如何使用Docker部署开源CMF Drupal并结合cpolar内网穿透远程访问
|
8月前
|
存储 Ubuntu 网络协议
Ubuntu本地部署Nextcloud并结合内网穿透实现远程访问搭建个人云盘
Ubuntu本地部署Nextcloud并结合内网穿透实现远程访问搭建个人云盘
454 1
|
24天前
|
Linux 网络虚拟化 Docker
新手向导:轻松掌握Docker搭建OpenVPN
OpenVPN 是一个开源的VPN软件包,支持多种操作系统和平台。它包含社区版(免费但需具备Linux命令
537 2
|
6月前
|
关系型数据库 Linux 数据库
如何在Linux云服务器上通过Docker Compose部署安装Halo,搭建个人博客网站?
本文指导用户如何在Linux服务器上使用Docker Compose部署Halo博客系统。首先确保拥有Linux服务器并安装Docker及Docker Compose。接着创建文件夹(例如`~/halo`),用于存放所有Halo相关数据。可以选择不同的Halo Docker镜像源,推荐使用具体版本而非`latest`标签以避免误操作。示例中提供了三种`docker-compose.yaml`配置方法:Halo+PostgreSQL、Halo+MySQL以及使用默认的H2数据库。每种配置都包括网络设置、健康检查和环境变量。
272 1
|
8月前
|
网络协议 网络安全 数据安全/隐私保护
SiteGround搭建WordPress
本文将带你快速使用SiteGround搭建WordPress网站,与使用VPS搭建WordPress相比,使用SiteGround明显更加轻松,因为它无需写代码就能实现。本教程教程内容涵盖了购买域名、SiteGround服务器购买、域名DNS解析配置,以及SSL证书生成,帮助你迅速建立一个完整可用的WordPress网站。
334 0
SiteGround搭建WordPress
|
弹性计算 关系型数据库 应用服务中间件
Wordpress 安装部署
简单几个步骤即可使用 ECS、RDS 进行 wordpress 安装,完成内容站点的部署。
195 0
|
Kubernetes 数据可视化 数据库
docker搭建图形化界面portainer1.24.2,快速搭建wordpress5.7.2站点
docker搭建图形化界面portainer1.24.2,快速搭建wordpress5.7.2站点
400 0
docker搭建图形化界面portainer1.24.2,快速搭建wordpress5.7.2站点
|
弹性计算 Ubuntu Unix
安装 NextCloud 网盘程序| 学习笔记
快速学习安装 NextCloud 网盘程序。
安装 NextCloud 网盘程序| 学习笔记
|
弹性计算 网络协议 数据库
搭建WordPress心得!
小白搭建简单的WordPress用了3天。。
161 0
搭建WordPress心得!
|
SQL 开发框架 搜索推荐
lamp源码搭建详解及wordpress搭建
Linux下LAMP( Linux+ Apache+My SQL/ MariaDB+PerI /PHP/ Python)是一组用来搭建动态网站的开源软件架构,本身是各自独立的软件服务,放在一起使用,拥有了越来越兼容成大的Web应用程序平台。
372 0
lamp源码搭建详解及wordpress搭建