GNU/Linux >> Tutoriales Linux >  >> Debian

Cómo instalar Grav CMS con Nginx en Debian 9

Grav es una plataforma web basada en archivos rápida, simple y flexible. 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
  • Dispatcher de eventos de Symfony:para el manejo de eventos de complementos
  • Consola Symfony:para interfaz CLI
  • Biblioteca de imágenes Gregwar: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 Grav CMS en el sistema operativo Debian 9 usando 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 PHP: curl, ctype, dom, gd, json, mbstring, openssl, session, simplexml, xml, zip, apcu(opcional), opcache(opcional).

Requisitos

  • 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 la versión de PHP 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 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 asegurar 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.

Descarga e instala 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 ~

Comprobar la versión 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 teclas estará en:

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

Paso 3:instalar y configurar NGINX

Instale el servidor web NGINX:

sudo apt install -y nginx

Comprueba 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 el nuevo grav.conf configuración vinculando el archivo a sites-enabled directorio.

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

Comprueba la configuración de NGINX para ver si hay 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 en el que Grav deba residir:

sudo mkdir -p /var/www/grav

Cambiar la propiedad de /var/www/grav directorio a {su_usuario}. Reemplace {su_usuario} en el siguiente comando con el nombre de usuario con el que ha iniciado sesión actualmente en Debian.:

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

Navegue al directorio raíz del documento:

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.

Cambiar la propiedad del /var/www/grav directorio 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. Tu instalación de Grav está completa.

Enlaces

  • https://getgrav.org/
  • https://github.com/getgrav/grav

Debian
  1. Cómo instalar Nginx en Debian 9

  2. Cómo instalar Pagekit CMS con Nginx en Fedora 29

  3. Cómo instalar Phorum con Nginx en Debian 9

  4. Cómo instalar Plone 4 CMS en Debian Wheezy con Nginx

  5. Cómo instalar Magento con Nginx en Debian 10

Cómo instalar Grav CMS con Nginx en Ubuntu 20.04

Cómo instalar Nginx con PHP + MySQL (LEMP) en Debian 9

Cómo instalar Bludit CMS con NGINX en Debian 9

Cómo instalar Pico CMS con Nginx en Debian 10

Cómo instalar Nginx en Debian 11

Cómo instalar Nginx con PHP-FPM en Debian 10