Instalación
danger
No dude en probar Flarum en uno de nuestros foros de demostración. O bien, configure su propio foro en segundos en Free Flarum, un servicio comunitario gratuito no afiliado al equipo de Flarum.
#
Requisitos del ServidorAntes de instalar Flarum, es importante comprobar que tu servidor cumple los requisitos. Para ejecutar Flarum, necesitarás:
- Apache (con mod_rewrite activado) o Nginx.
- PHP 7.3+ con las siguientes extensiones: curl, dom, gd, json, mbstring, openssl, pdo_mysql, tokenizer, zip
- MySQL 5.6+ o MariaDB 10.0.5+
- Acceso a SSH (línea de comandos) para ejecutar Composer
¿Prueba rápida?
En este momento, no es posible instalar Flarum descargando un archivo ZIP y subiendo los archivos a su servidor web. Esto se debe a que Flarum utiliza un sistema de gestión de dependencias llamado Composer que necesita ejecutarse en la línea de comandos.
Esto no significa necesariamente que necesites un VPS. Algunos hosts compartidos te dan acceso SSH, a través del cual deberías ser capaz de instalar Composer y Flarum sin problemas.
#
InstalandoFlarum utiliza Composer para gestionar sus dependencias y extensiones. Antes de instalar Flarum, necesitarás instalar Composer en tu máquina. Después, ejecuta este comando en una ubicación vacía en la que quieras que se instale Flarum:
composer create-project flarum/flarum .
Mientras se ejecuta este comando, puede configurar su servidor web. Tendrás que asegurarte de que tu webroot está configurado en /ruta/para/su/foro/public
, y configurar el URL Rewriting según las instrucciones siguientes.
Cuando todo esté listo, navega a tu foro en un navegador web y sigue las instrucciones para completar la instalación.
#
URL Rewriting#
ApacheFlarum incluye un archivo .htaccess
en el directorio public
- asegúrese de que ha sido descargado correctamente. Flarum no funcionará correctamente si mod_rewrite
no está habilitado o .htaccess
no está permitido. Asegúrate de comprobar con tu proveedor de hosting (o tu VPS) que estas características están habilitadas. Si gestionas tu propio servidor, puede que tengas que añadir lo siguiente a la configuración de tu sitio para habilitar los archivos .htaccess
:
<Directory "/ruta/para/flarum/public"> AllowOverride All</Directory>
Esto asegura que las sobreescrituras de htaccess están permitidas para que Flarum pueda reescribir las URLs correctamente.
Los métodos para habilitar mod_rewrite
varían dependiendo de su sistema operativo. Puedes activarlo ejecutando sudo a2enmod rewrite
en Ubuntu. En CentOS está activado por defecto. No te olvides de reiniciar Apache después de hacer las modificaciones.
#
NginxFlarum incluye un archivo .nginx.conf
- asegúrate de que se ha descargado correctamente. Entonces, asumiendo que tienes un sitio PHP configurado dentro de Nginx, añade lo siguiente al bloque de configuración de tu servidor:
include /ruta/para/flarum/.nginx.conf;
#
CaddyCaddy requiere una configuración muy sencilla para que Flarum funcione correctamente. Tenga en cuenta que debe reemplazar la URL con la suya propia y la ruta con la ruta a su propia carpeta public
. Si está usando una versión diferente de PHP, también necesitará cambiar la ruta fastcgi
para que apunte a su socket o URL de instalación de PHP correcta.
www.ejemplo.com { root * /var/www/flarum/public php_fastcgi unix//var/run/php/php7.4-fpm.sock header /assets { +Cache-Control "public, must-revalidate, proxy-revalidate" +Cache-Control "max-age=25000" Pragma "public" } file_server}
#
Propiedad de la CarpetaDurante la instalación, Flarum puede solicitar que se permita la escritura en ciertos directorios. Modern operating systems are generally multi-user, meaning that the user you log in as is not the same as the user FLarum is running as. The user that Flarum is running as MUST have read + write access to:
- Finalmente, edite el
site.php
y actualice las rutas en las siguientes líneas para reflejar su nueva estructura de directorios: - The
storage
subdirectory, so Flarum can edit logs and store cached data. - The
assets
subdirectory, so that logos and avatars can be uploaded to the filesystem.
If Flarum requests write access to both the directory and its contents, you need to add the -R
flag so that the permissions are updated for all the files and folders within the directory:
There are several commands you'll need to run in order to set up file permissions. Please note that if your install doesn't show warnings after executing just some of these, you don't need to run the rest.
First, you'll need to allow write access to the directory. On Linux:
chmod 775 -R /ruta/al/directorio
If after completing these steps, Flarum continues to request that you change the permissions you may need to check that your files are owned by the correct group and user. Por defecto, en la mayoría de las distribuciones de Linux www-data
es el grupo y el usuario bajo el que operan tanto PHP como el servidor web. You'll need to look into the specifics of your distro and web server setup to make sure. Puede cambiar la propiedad de la carpeta en la mayoría de los sistemas operativos Linux ejecutando chown -R www-data:www-data nombrecarpeta/
.
chmod 775 -R /ruta/al/directorio
Si Flarum solicita acceso de escritura tanto al directorio como a su contenido, es necesario añadir la etiqueta -R
para que los permisos se actualicen para todos los archivos y carpetas dentro del directorio:
Additionally, you'll need to ensure that your CLI user (the one you're logged into the terminal as) has ownership, so that you can install extensions and manage the Flarum installation via CLI. To do this, add your current user (whoami
) to the web server group (usually www-data
) via usermod -a -G www-data YOUR_USERNAME
. You will likely need to log out and back in for this change to take effect.
Finally, if that doesn't work, you might need to configure SELinux to allow the web server to write to the directory. To do so, run:
chcon -R -t httpd_sys_rw_content_t /path/to/directory
Para saber más sobre estos comandos, así como sobre los permisos y la propiedad de los archivos en Linux, lea este tutorial. Si está configurando Flarum en Windows, puede encontrar útiles las respuestas a esta pregunta de Super User.
Si Flarum solicita acceso de escritura tanto al directorio como a su contenido, es necesario añadir la etiqueta -R
para que los permisos se actualicen para todos los archivos y carpetas dentro del directorio:
Si después de completar estos pasos, Flarum continúa solicitando que cambie los permisos, puede que necesite comprobar que sus archivos son propiedad del grupo y usuario correctos.
:::
Never use permission 777
:::
#
Personalización de las RutasPor defecto, la estructura de directorios de Flarum incluye un directorio public
que contiene sólo archivos de acceso público. Esta es una buena práctica de seguridad, asegurando que todos los archivos sensibles del código fuente son completamente inaccesibles desde la raíz de la web.
Nunca utilice el permiso 777
Simplemente mueve todos los archivos dentro del directorio public
(incluyendo .htaccess
) al directorio desde el que quieres servir a Flarum. Luego edita .htaccess
y descomenta las líneas 9-15 para proteger los recursos sensibles. Para Nginx, descomente las líneas 8-11 de .nginx.conf
.
También tendrá que editar el archivo index.php
y cambiar la siguiente línea:
$site = require './site.php';
Finalmente, edite el site.php
y actualice las rutas en las siguientes líneas para reflejar su nueva estructura de directorios:
'base' => __DIR__,'public' => __DIR__,'storage' => __DIR__.'/storage',
Sin embargo, si desea alojar Flarum en un subdirectorio (como susitioweb.com/forum
), o si su anfitrión no le da control sobre su raíz web (está atado a algo como public_html
o htdocs
), puede configurar Flarum sin el directorio public
.
#
Importar datosSi tienes una comunidad existente y no quieres empezar de cero, puedes importar tus datos existentes a Flarum. Aunque todavía no hay importadores oficiales, la comunidad ha hecho varios importadores no oficiales:
Estos pueden ser utilizados para otro software de foro también mediante la migración a phpBB primero, y luego a Flarum. Tenga en cuenta que no podemos garantizar que estos funcionen ni podemos ofrecer soporte para ellos.