INSTALANDO O NEXTCLOUD NO UBUNTU 16.04

INSTALANDO O NEXTCLOUD NO UBUNTU 16.04

Neste artigo, mostraremos como instalar o Nextcloud 9 em um Ubuntu 16.04 VPS com MariaDB, PHP-FPM 7.0 e Nginx. O Nextcloud é a sincronização de arquivos auto-hospedados de código aberto e o aplicativo de compartilhamento forked do ownCloud . Este guia deve funcionar em outros sistemas Linux VPS também, mas foi testado e escrito para um Ubuntu 16.04 VPS .

Faça login no seu VPS via SSH com seu usuário root

ssh user@vps_IP

Atualizar o sistema e instalar os pacotes necessários

[user]$ sudo apt-get update && sudo apt-get -y upgrade
[user]$ sudo apt-get install software-properties-common nano wget

Instalar o MariaDB 10.1

Para adicionar o repositório MariaDB à sua lista de fontes e instalar o último servidor do MariaDB 10.1, execute os seguintes comandos:

[user]$ sudo apt-key adv --recv-keys --keyserver hkp://keyserver.ubuntu.com:80 0xF1656F24C74CD1D8
[user]$ sudo add-apt-repository 'deb [arch=amd64,i386] http://ftp.osuosl.org/pub/mariadb/repo/10.1/ubuntu xenial main'
[user]$ sudo apt-get update
[user]$ sudo apt-get install -y mariadb-server

Quando a instalação estiver concluída, execute o seguinte comando para proteger a instalação:

[user]$ mysql_secure_installation

Desative o log binário do MariaDB comentando as seguintes linhas

[user]$ sudo nano /etc/mysql/my.cnf
#log_bin                = /var/log/mysql/mariadb-bin
#log_bin_index          = /var/log/mysql/mariadb-bin.index

Reiniciar o serviço

[user]$ sudo service mysql restart

Em seguida, precisamos criar um banco de dados para a instalação do Nextcloud.

[user]$ mysql -uroot -p
MariaDB [(none)]> CREATE DATABASE nextcloud;
MariaDB [(none)]> GRANT ALL PRIVILEGES ON nextcloud.* TO 'nextcloud'@'localhost' IDENTIFIED BY 'strong_password';
MariaDB [(none)]> FLUSH PRIVILEGES;
MariaDB [(none)]> \q

Instalar PHP e módulos PHP necessários

Para instalar a versão estável mais recente do PHP versão 7.0 e todos os módulos necessários, execute:

[user]$ 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

Os seguintes comandos definirão o limite de memória PHP para 512MB, alteram os valores de upload_max_filesize e post_max_size para 200M e definem o fuso horário para UTC.

[user]$ sed -i "s/memory_limit = .*/memory_limit = 512M/" /etc/php/7.0/fpm/php.ini
[user]$ sed -i "s/;date.timezone.*/date.timezone = UTC/" /etc/php/7.0/fpm/php.ini
[user]$ sed -i "s/;cgi.fix_pathinfo=1/cgi.fix_pathinfo=1/" /etc/php/7.0/fpm/php.ini
[user]$ sed -i "s/upload_max_filesize = .*/upload_max_filesize = 200M/" /etc/php/7.0/fpm/php.ini
[user]$ sed -i "s/post_max_size = .*/post_max_size = 200M/" /etc/php/7.0/fpm/php.ini

Adicione as seguintes variáveis ​​de ambiente no final do arquivo de pool PHP-FPM:

[user]$ sudo nano /etc/php/7.0/fpm/pool.d/www.conf
env[HOSTNAME] = $HOSTNAME
env[PATH] = /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
env[TMP] = /tmp
env[TMPDIR] = /tmp
env[TEMP] = /tmp

Reinicie o PHP-FPM:

[user]$ sudo service php7.0-fpm restart

Faça o download e extraia o Nextcloud 9

Vamos instalar o Nextcloud no/var/www/nextcloud diretório. Faça o download da última versão do Nextcloud no site da Nextcloud:

[user]$ wget https://download.nextcloud.com/server/releases/nextcloud-9.0.52.zip
[user]$ unzip nextcloud-9.0.52.zip
[user]$ sudo mkdir /var/www/
[user]$ sudo mv nextcloud /var/www/
[user]$ rm -f nextcloud-9.0.52.zip
[user]$ sudo chown -R www-data: /var/www/nextcloud

Instalar e configurar o Nginx

Para instalar a versão estável mais recente do Nginx disponível nos repositórios do Ubuntu, execute:

nginx cache purge

O pacote nginx-extras fornece uma versão do nginx com os módulos padrão, além de recursos extras e módulos como o módulo.nginx cache purge

Gerar um certificado auto assinado ssl:

[user]$ sudo mkdir -p /etc/nginx/ssl
[user]$ cd /etc/nginx/ssl
[user]$ sudo openssl genrsa -des3 -passout pass:x -out nextcloud.pass.key 2048
[user]$ sudo openssl rsa -passin pass:x -in nextcloud.pass.key -out nextcloud.key
[user]$ sudo rm nextcloud.pass.key
[user]$ sudo openssl req -new -key nextcloud.key -out nextcloud.csr
[user]$ sudo openssl x509 -req -days 365 -in nextcloud.csr -signkey nextcloud.key -out nextcloud.crt

Se você não deseja receber avisos associados a certificados SSL auto-assinados, você pode adquirir um certificado SSL confiável conosco .

Em seguida, crie um novo bloco de servidor Nginx:

[user]$ sudo nano /etc/nginx/sites-available/nextcloud
server {
    listen 80;
    server_name my.nextcloud.com;
    return 301 https://$server_name$request_uri;
}
server {
    listen 443 ssl http2;
    server_name my.nextcloud.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;
    }

}

Ative o bloco do servidor criando um link simbólico:

[user]$ sudo ln -s /etc/nginx/sites-available/nextcloud /etc/nginx/sites-enabled/nextcloud

Teste a configuração do Nginx e reinicie o nginx:

[user]$ sudo nginx -t
[user]$ sudo service nginx restart

Instalar o Nextcloud 9

Abra https://my.nextcloud.com/install.php no seu navegador da Web favorito e você deverá ver a tela de instalação do Nextcloud 9. Nesta página, você precisará digitar os detalhes do banco de dados que criou anteriormente, Nextcloud 9 detalhes do administrador e, finalmente, clique no botão Instalar.

É isso aí. Você instalou o Nextcloud 9 no Ubuntu 16.04 VPS com sucesso. Para obter mais informações sobre como gerenciar a instalação do Nextcloud 9, consulte a documentação oficial do Nextcloud 9.

Leave a Reply

Your email address will not be published.