Requisits
Abans que comencis
Pas 1: instal·leu PHP, les extensions PHP necessàries, NGINX i MySQL
Pas 2: configureu NGINX
Pas 3: Baixeu i instal·leu Composer
Pas 4: Baixeu i instal·leu Fork CMS mitjançant Composer
Fork és un CMS de codi obert escrit en PHP. El codi font de Fork està allotjat a GitHub . Aquesta guia us mostrarà com instal·lar Fork CMS en una instància nova de CentOS 7.4 Vultr.
Requisits
- PHP 7.1 o superior.
- MySQL 5.0 o superior.
- NGINX o Apache 2.0 amb
.htaccess, mod rewrite, mod expires(opcional però recomanat) i mod deflate(opcional) activats.
Abans que comencis
Comproveu la versió de CentOS.
cat /etc/centos-release
# CentOS Linux release 7.4.1708 (Core)
Creeu un non-rootcompte d'usuari nou amb sudoaccés i canvieu-hi.
useradd -c "John Doe" johndoe && passwd johndoe
usermod -aG wheel johndoe
su - johndoe
NOTA : Substituïu-lo johndoepel vostre nom d'usuari .
Configura la zona horària.
timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'
Assegureu-vos que el vostre sistema estigui actualitzat.
sudo yum update -y
Instal·leu els paquets necessaris i útils.
sudo yum install -y wget vim unzip bash-completion
Desactiva SELinux.
sudo setenforce 0
Pas 1: instal·leu PHP, les extensions PHP necessàries, NGINX i MySQL
CentOS no proporciona la darrera versió de PHP als seus repositoris de programari predeterminats. Haurem d'afegir un repositori Webtatic YUM. Per saber com fer-ho, podeu seguir aquesta guia de Vultr .
Baixeu i instal·leu PHP 7.2 i les extensions PHP necessàries.
sudo yum install -y php72w-cli php72w-fpm php72w-common php72w-mbstring php72w-gd php72w-intl php72w-mysql php72w-xml
Comproveu la versió de PHP.
php --version
PHP 7.2.2 (cli) (built: Feb 4 2018 10:14:07) ( NTS )
Copyright (c) 1997-2018 The PHP Group
Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies
Instal·leu NGINX.
sudo vim /etc/yum.repos.d/nginx_mainline.repo
# Copy/paste this to the /etc/yum.repos.d/nginx_mainline.repo file
[nginx]
name=nginx repo
baseurl=https://nginx.org/packages/mainline/centos/7/$basearch/
gpgcheck=1
enabled=1
wget https://nginx.org/keys/nginx_signing.key
sudo rpm --import nginx_signing.key
rm nginx_signing.key
sudo yum install -y nginx
Comproveu la versió de NGINX.
sudo nginx -v
Inicieu i activeu NGINX.
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
Instal·leu MariaDB.
sudo vim /etc/yum.repos.d/MariaDB.repo
# Copy/paste this to the /etc/yum.repos.d/MariaDB.repo file
[mariadb]
name = MariaDB
baseurl = https://yum.mariadb.org/10.2/centos7-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1
sudo yum install -y MariaDB-server MariaDB-client
Comproveu la versió de MariaDB.
mysql --version
# mysql Ver 15.1 Distrib 10.2.13-MariaDB, for Linux (x86_64) using readline 5.1
Inicieu i activeu MariaDB.
sudo systemctl enable mariadb.service
sudo systemctl start mariadb.service
Executeu l' mysql_secure_installationscript per millorar la seguretat de la vostra instal·lació de MariaDB.
sudo mysql_secure_installation
Inicieu sessió a MariaDB com a usuari root.
mysql -u root -p
# Enter password:
Creeu una base de dades i un usuari MariaDB nous i recordeu les credencials.
create database dbname;
grant all on dbname.* to 'username' identified by 'password';
Sortiu de MySQL.
exit
Executeu-lo sudo vi /etc/nginx/conf.d/fork.confi ompliu-lo amb el següent.
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 127.0.0.1:9000; # 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 resum dels canvis que fareu és el següent.
- Canvieu el valor de la
rootdirectiva per apuntar a la ubicació correcta del vostre lloc web, com ara /var/www/fork.
- Canvieu el valor de la
server_namedirectiva perquè apunti al vostre nom de domini o adreça IP.
- Assegureu-vos de comprovar si
fastcgi_passestà configurat correctament.
Proveu la configuració de NGINX.
sudo nginx -t
Torna a carregar NGINX.
sudo systemctl reload nginx.service
Pas 3: Baixeu i instal·leu Composer
Descarrega dependències de Composer.
sudo yum install -y curl git unzip
Baixeu i instal·leu Composer , el gestor de dependències de 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
Comproveu la versió de Composer.
composer --version
# Composer version 1.6.3 2018-01-31 16:28:17
Pas 4: Baixeu i instal·leu Fork CMS mitjançant Composer
Creeu un directori arrel del document.
sudo mkdir -p /var/www/fork
Canvia la propietat del /var/www/forkdirectori a johndoe.
sudo chown -R johndoe:johndoe /var/www/fork
Baixeu la darrera versió estable de Fork CMS des de la línia d'ordres.
cd /var/www/fork
composer create-project forkcms/forkcms .
Canvia la propietat del /var/www/forkdirectori a nginx.
sudo chown -R nginx:nginx /var/www/fork
Executeu sudo vim /etc/php-fpm.d/www.confi configureu l'usuari i el grup a nginx.
sudo vim /etc/php-fpm.d/www.conf
# user = nginx
# group = nginx
Reinicieu php-fpm.service.
sudo systemctl restart php-fpm.service
Editeu el app/config/parameters.yml.distfitxer i configureu la informació de la base de dades.
sudo vim /var/www/fork/app/config/parameters_install.yml
Creeu un /var/lib/php/sessiondirectori i canvieu-ne la propietat a usuari nginx.
sudo mkdir -p /var/lib/php/session
sudo chown -R nginx:nginx /var/lib/php/session
Finalment, utilitzant el vostre navegador web preferit, obriu el vostre lloc i seguiu l' Fork CMSinstal·lador. Després de seguir l'instal·lador, hauríeu de tenir Fork en funcionament. Per accedir a l'àrea d'administració de Fork, només cal que afegiu l' /privateURL del vostre lloc.