Cómo instalar Grav CMS con Nginx en Debian 9

Cómo instalar Grav CMS con Nginx en Debian 9

Grav es una plataforma web rápida, simple y flexible basada en archivos. Sigue principios similares a otras plataformas CMS de archivo plano, pero tiene una filosofía de diseño diferente a la de la mayoría. Grav viene con un poderoso sistema de administración de paquetes que permite una instalación y actualización simples de complementos y temas, así como una actualización simple de Grav.

La arquitectura subyacente de Grav está diseñada para usar tecnologías bien establecidas y de primera clase para garantizar que Grav sea fácil de usar y fácil de ampliar. Algunas de estas tecnologías clave incluyen:

  • Twig Templating: para un control potente de la interfaz de usuario
  • Markdown: para una fácil creación de contenido
  • YAML: para una configuración sencilla
  • Parsedown: para soporte rápido de Markdown y Markdown Extra
  • Doctrine Cache: capa para el rendimiento
  • Contenedor de inyección de dependencia Pimple: para extensibilidad y mantenibilidad
  • Symfony Event Dispatcher: para el manejo de eventos de complementos
  • Consola Symfony: para interfaz CLI
  • Gregwar Image Library: para la manipulación dinámica de imágenes

En esta guía, lo guiaremos paso a paso a través del proceso de instalación de Grav CMS en el sistema operativo Debian 9 utilizando Nginx como servidor web y acme.sh y Let’s Encrypt para HTTPS.

Requisitos

  • Servidor web (Apache, Nginx, LiteSpeed, Lightly o IIS). En esta guía, usaremos NGINX.
  • PHP 7.1.3 o superior con las siguientes extensiones de PHP: curl, ctype, dom, gd, json, mbstring, openssl, session, simplexml, xml, zip, apcu (opcional), opcache (opcional).
  • Un sistema operativo que ejecuta Debian 9.
  • Un usuario no root con privilegios sudo.

Pasos iniciales

Compruebe su versión de Debian:

lsb_release -ds
# Debian GNU/Linux 9.9 (stretch)

Configurar la zona horaria:

sudo dpkg-reconfigure tzdata

Actualice los paquetes de su sistema operativo (software). Este es un primer paso importante porque garantiza que tenga las últimas actualizaciones y correcciones de seguridad para los paquetes de software predeterminados de su sistema operativo:

sudo apt update && sudo apt upgrade -y

Instale algunos paquetes esenciales que son necesarios para la administración básica del sistema operativo Debian:

sudo apt install -y curl wget vim git unzip socat apt-transport-https

Paso 1 – Instalar PHP y extensiones de PHP

Grav CMS requiere PHP versión 7.1 o superior. Debian tiene la versión 7 de PHP en el repositorio predeterminado, por lo que deberá usar un repositorio de terceros para instalar una versión más nueva.

sudo apt install apt-transport-https lsb-release ca-certificates
sudo wget -O /etc/apt/trusted.gpg.d/php.gpg https://packages.sury.org/php/apt.gpg
echo "deb https://packages.sury.org/php/ $(lsb_release -sc) main" | sudo tee /etc/apt/sources.list.d/php.list
sudo apt update

Instale PHP 7.2, así como las extensiones de PHP necesarias:

sudo apt install -y php7.2 php7.2-cli php7.2-fpm php7.2-common php7.2-curl php7.2-gd php7.2-json php7.2-mbstring php7.2-xml php7.2-zip php7.2-opcache php-apcu

Compruebe la versión de PHP:

php --version# PHP 7.2.18-1+0~20190503103213.21+stretch~1.gbp101320 (cli) (built: May  3 2019 10:32:13) ( NTS )
# Copyright (c) 1997-2018 The PHP Group
# Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies
# with Zend OPcache v7.2.18-1+0~20190503103213.21+stretch~1.gbp101320, Copyright (c) 1999-2018, by Zend Technologies

El servicio PHP-FPM se inicia y habilita automáticamente al reiniciar en el sistema Debian 9, por lo que no es necesario iniciarlo y habilitarlo manualmente. Podemos pasar al siguiente paso, que es la configuración de SSL.

Paso 2: instale el cliente Acme.sh y obtenga el certificado Let’s Encrypt (opcional)

No es necesario proteger su sitio web con HTTPS, pero es una buena práctica para proteger el tráfico de su sitio. Para obtener el certificado TLS de Let’s Encrypt, utilizaremos el cliente Acme.sh. Acme.sh es un software de shell Unix puro para obtener certificados TLS de Let’s Encrypt sin dependencias.

Descargue e instale Acme.sh:

sudo mkdir /etc/letsencrypt
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh 
sudo ./acme.sh --install --home /etc/letsencrypt --accountemail [email protected]
cd ~

Compruebe la versión de Acme.sh:

/etc/letsencrypt/acme.sh --version
# v2.8.0

Obtener RSA y ECC/ECDSA certificados para su dominio/nombre de host:

# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --standalone --home /etc/letsencrypt -d example.com --keylength 2048
# ECDSA
sudo /etc/letsencrypt/acme.sh --issue --standalone --home /etc/letsencrypt -d example.com --keylength ec-256

Después de ejecutar los comandos anteriores, sus certificados y claves estarán en:

  • Para RSA: directorio /etc/letsencrypt/example.com.
  • Para ECC/ECDSA: directorio /etc/letsencrypt/example.com_ecc.

Paso 3: instalar y configurar NGINX

Instale el servidor web NGINX:

sudo apt install -y nginx

Compruebe la versión de NGINX:

nginx -v
# nginx version: nginx/1.10.3

Ejecute sudo vim /etc/nginx/sites-available/grav.conf y complete el archivo con la siguiente configuración:

server {
  
  listen 80;

  server_name example.com;
  root /var/www/grav;
  
  index index.html index.php;
  
  location / {
    try_files $uri $uri/ /index.php?$query_string;
  }
  
  location ~* /(\.git|cache|bin|logs|backup|tests)/.*$ { return 403; }
  location ~* /(system|vendor)/.*\.(txt|xml|md|html|yaml|yml|php|pl|py|cgi|twig|sh|bat)$ { return 403; }
  location ~* /user/.*\.(txt|md|yaml|yml|php|pl|py|cgi|twig|sh|bat)$ { return 403; }
  location ~ /(LICENSE\.txt|composer\.lock|composer\.json|nginx\.conf|web\.config|htaccess\.txt|\.htaccess) { return 403; }

  location ~ \.php$ {
    fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
    fastcgi_split_path_info ^(.+\.php)(/.+)$;
    fastcgi_index index.php;
    include fastcgi_params;
    fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name;
  }

}

Active la nueva configuración de grav.conf vinculando el archivo al directorio habilitado para sitios.

sudo ln -s /etc/nginx/sites-available/grav.conf /etc/nginx/sites-enabled

Verifique la configuración de NGINX para errores de sintaxis:

sudo nginx -t

Recargar servicio NGINX:

sudo systemctl reload nginx.service

Paso 4 – Instalar Grav CMS

Cree un directorio raíz de documentos donde Grav debería residir:

sudo mkdir -p /var/www/grav

Cambie la propiedad del directorio /var/www/grav a {su_usuario}. Reemplace {su_usuario} en el siguiente comando con el nombre de usuario con el que está actualmente conectado a Debian.:

sudo chown -R {your_user}:{your_user} /var/www/grav

Navegue al directorio raíz del documento: Anuncio

cd /var/www/grav

Descarga la última versión de la página oficial y extrae el archivo zip:

wget https://getgrav.org/download/core/grav-admin/1.6.9
unzip 1.6.9
mv grav-admin/* . && mv grav-admin/.* .
rm -rf grav-admin 1.6.9

NOTA: Actualice la URL de descarga si hay una versión más reciente.

Cambie la propiedad del directorio /var/www/grav a www-data:

sudo chown -R www-data:www-data /var/www/grav

Paso 5: completa la configuración de Grav

Abra su sitio en un navegador web y debería ver una página que le pide que cree una cuenta de administrador de Grav. Cree uno y continúe haciendo clic en el botón «Crear usuario»:

Eso es todo. Su instalación de Grav está completa.

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *