Fork è un CMS open source scritto in PHP. Il codice sorgente di Fork è ospitato su GitHub . Questa guida ti mostrerà come installare Fork CMS su una nuova istanza di Fedora 28 Vultr.
Requisiti
- PHP 7.1 o versioni successive.
- MySQL 5.0 o versioni successive.
- Nginx o Apache 2.0 con
.htaccess
, mod rewrite
, mod expires
(facoltativo ma consigliato) e mod deflate
(opzionale) abilitati.
Prima di iniziare
Controlla la versione di Fedora.
cat /etc/fedora-release
# Fedora release 28 (Twenty Eight)
Crea un nuovo account utente non root con sudo
accesso e passa ad esso. Sostituisci johndoe
con il tuo nome utente.
useradd -c "John Doe" johndoe && passwd johndoe
usermod -aG wheel johndoe
su - johndoe
Imposta il fuso orario.
timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'
Assicurati che il tuo sistema sia aggiornato.
sudo dnf check-upgrade || sudo dnf upgrade -y
Installa i pacchetti necessari e utili.
sudo dnf install -y wget vim unzip bash-completion
Per semplicità, disabilitare SELinux e Firewall.
sudo setenforce 0
sudo systemctl stop firewalld
sudo systemctl disable firewalld
Passaggio 1: installa PHP, estensioni PHP richieste, Nginx e MySQL
Scarica e installa PHP e le estensioni PHP richieste.
sudo dnf install -y php-cli php-fpm php-common php-mbstring php-gd php-intl php-mysqlnd php-xml php-json
Controlla la versione di PHP.
php --version
# PHP 7.2.6 (cli) (built: May 22 2018 16:22:08) ( NTS )
# Copyright (c) 1997-2018 The PHP Group
# Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies
Installa Nginx.
sudo dnf install -y nginx
Controlla la versione di Nginx.
nginx -v
# nginx version: nginx/1.12.1
Avvia e abilita Nginx.
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
Installa MariaDB.
sudo dnf install -y mariadb-server
Controlla la versione di MariaDB.
mysql --version
# mysql Ver 15.1 Distrib 10.2.15-MariaDB, for Linux (x86_64) using readline 5.1
Avviare e abilitare MariaDB.
sudo systemctl enable mariadb.service
sudo systemctl start mariadb.service
Esegui lo mysql_secure_installation
script per migliorare la sicurezza dell'installazione di MariaDB.
sudo mysql_secure_installation
Accedi a MariaDB come utente root.
mysql -u root -p
# Enter password:
Creare un nuovo database e utente MariaDB e ricordare le credenziali.
create database dbname;
grant all on dbname.* to 'username' identified by 'password';
Esci da MySQL.
exit
Esegui sudo vi /etc/nginx/conf.d/fork.conf
e popola con il seguente.
server {
listen 80;
root /var/www/fork;
index index.php index.html;
server_name example.com;
location / {
# Checks whether the requested url exists as a file $uri or directory $uri/ in the root, else redirect to /index.php.
try_files $uri $uri/ @redirects;
}
location @redirects {
rewrite ^ /index.php;
}
location ~ \.php$ {
try_files $uri =404;
include fastcgi_params;
fastcgi_pass unix:/run/php-fpm/www.sock; # Make sure to doublecheck this!
fastcgi_index index.php;
fastcgi_read_timeout 60;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
# Don't pollute the logs with common requests
location = /robots.txt { access_log off; log_not_found off; }
location = /favicon.ico { access_log off; log_not_found off; }
# As Fork CMS has the app_root as doc_root, we need to restrict access to a few things for security purposes!
location ~* ^/(composer\..*|vendor\/.*|Procfile$|\.git\/.*|src\/Console.*|.*\.gitignore|\.editorconfig|\.travis.yml|autoload\.php|bower\.json|phpunit\.xml\.dist|.*\.md|app\/logs\/.*|app\/config\/.*|src\/Frontend\/Cache\/CompiledTemplates.*|src\/Frontend\/Cache\/Locale\/.*\.php|src\/Frontend\/Cache\/Navigation\/.*\.php|src\/Frontend\/Cache\/Search\/.*|src\/Backend\/Cache\/CompiledTemplates\/.*|src\/Backend\/Cache\/Locale\/.*\.php)$ {
deny all;
access_log off;
log_not_found off;
}
# Deny access to dot-files.
location ~ /\. {
deny all;
access_log off;
log_not_found off;
}
}
Un riepilogo delle modifiche che verranno apportate è il seguente.
- Modifica il valore della
root
direttiva in modo che punti alla posizione corretta del tuo sito Web, ad esempio /var/www/fork
.
- Modifica il valore della
server_name
direttiva in modo che punti al tuo nome di dominio o indirizzo IP.
- Assicurati di controllare se
fastcgi_pass
è impostato correttamente.
Prova la configurazione di Nginx.
sudo nginx -t
Ricarica Nginx.
sudo systemctl reload nginx.service
Passaggio 3: scaricare e installare Composer
Scarica le dipendenze di Composer.
sudo dnf install -y curl git unzip
Scarica e installa Composer, il gestore delle dipendenze per PHP.
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
php -r "if (hash_file('SHA384', 'composer-setup.php') === '544e09ee996cdf60ece3804abc52599c22b1f40f4323403c44d44fdfdd586475ca9813a858088ffbc1f233e9b180f061') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"
php composer-setup.php
php -r "unlink('composer-setup.php');"
sudo mv composer.phar /usr/local/bin/composer
Controlla la versione di Composer.
composer --version
# Composer version 1.6.5 2018-05-04 11:44:59
Passaggio 4: scaricare e installare Fork CMS tramite Composer
Creare una directory radice del documento.
sudo mkdir -p /var/www/fork
Cambia la proprietà della /var/www/fork
directory in johndoe
.
sudo chown -R johndoe:johndoe /var/www/fork
Scarica l'ultima versione stabile di Fork CMS dalla riga di comando.
cd /var/www/fork
composer create-project forkcms/forkcms .
Cambia la proprietà della /var/www/fork
directory in nginx
.
sudo chown -R nginx:nginx /var/www/fork
Esegui sudo vim /etc/php-fpm.d/www.conf
e imposta l'utente e il gruppo su nginx
.
sudo vim /etc/php-fpm.d/www.conf
# user = nginx
# group = nginx
Riavvia php-fpm.service
.
sudo systemctl restart php-fpm.service
Modifica il app/config/parameters.yml.dist
file e imposta le informazioni sul database.
sudo vim /var/www/fork/app/config/parameters_install.yml
Crea una /var/lib/php/session
directory e cambia la sua proprietà per l'utente nginx
.
sudo mkdir -p /var/lib/php/session
sudo chown -R nginx:nginx /var/lib/php/session
Infine, utilizzando il tuo browser Web preferito, apri il tuo sito e segui il programma di Fork CMS
installazione. Dopo aver seguito il programma di installazione, avrai un'istanza Fork attiva e funzionante. Per accedere all'area di amministrazione di Fork basta aggiungere /private
l'URL del sito.