Guida-Istallazione server web LAMP php 7.x e phpmyadmin in Centos 7

Istallare i prerequisiti minimi per sviluppare siti web in PHP (7.0, 7.1 7.2 and 7.3), creare un blog con WordPress 5, Drupal, Joomla, avviare un’attività di eCommerce con Magento oppure OpenCart o istallare servizi web come GLPI 9.2 9.3 e 9.4 o servizi che richiedono prestazioni elevate e versioni di php aggiornate, nella piccola guida passo-passo vedremo come preparare tutto quanto ed installare Apache HTTP Server, MySQL e PHP (7.0, 7.1 7.2 and 7.3) su un pc Linux. Lo scopo è presentare la procedura nel modo più semplice possibile, senza perdersi in micro-configurazioni inizialmente superflue, ma anche senza dare nulla per scontato. Ebbene: siamo dunque pronti ad installare e configurare Apache, PHP (7.0, 7.1 7.2 and 7.3) e MySQL partendo da zero.

1 Note preliminari

In questo tutorial ho impostato sul mio server “server1” come hostname e ip 192.168.1.100 sulla scheda di rete . Queste impostazioni potrebbero essere diverse per te, quindi devi sostituirle se necessario.

Ho aggiunto i repository EPEL repo per istallare l’ultima versione di phpMyAdmin iniziamo dai primi comandi:

rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY*
yum -y install epel-release

2 Installare MySQL / MariaDB

MariaDB è una piattaforma MySQL dello sviluppatore MySQL originale Monty Widenius. MariaDB è compatibile con MySQL e ho scelto di utilizzare MariaDB qui anziché MySQL. Esegui questo comando per installare MariaDB con yum:

yum -y install mariadb-server mariadb

Quindi creiamo i collegamenti di avvio del sistema per MySQL (in modo che MySQL si avvii automaticamente all’avvio del sistema) e avvii il server MySQL:

systemctl start mariadb.service
systemctl enable mariadb.service

Settare la passwords per MySQL root account:

mysql_secure_installation
[root@server1 ~]# mysql_secure_installation

NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MariaDB
      SERVERS IN PRODUCTION USE!  PLEASE READ EACH STEP CAREFULLY!

In order to log into MariaDB to secure it, we'll need the current
password for the root user.  If you've just installed MariaDB, and
you haven't set the root password yet, the password will be blank,
so you should just press enter here.

Enter current password for root (enter for none): <--ENTER
OK, successfully used password, moving on...

Setting the root password ensures that nobody can log into the MariaDB
root user without the proper authorisation.

Set root password? [Y/n] 
New password: <--yourmariadbpassword
Re-enter new password: <--yourmariadbpassword
Password updated successfully!
Reloading privilege tables..
 ... Success!


By default, a MariaDB installation has an anonymous user, allowing anyone
to log into MariaDB without having to have a user account created for
them.  This is intended only for testing, and to make the installation
go a bit smoother.  You should remove them before moving into a
production environment.

Remove anonymous users? [Y/n] <--ENTER
 ... Success!

Normally, root should only be allowed to connect from 'localhost'.  This
ensures that someone cannot guess at the root password from the network.

Disallow root login remotely? [Y/n] <--ENTER
 ... Success!

By default, MariaDB comes with a database named 'test' that anyone can
access.  This is also intended only for testing, and should be removed
before moving into a production environment.

Remove test database and access to it? [Y/n] <--ENTER
 - Dropping test database...
 ... Success!
 - Removing privileges on test database...
 ... Success!

Reloading the privilege tables will ensure that all changes made so far
will take effect immediately.

Reload privilege tables now? [Y/n] <--ENTER
 ... Success!

Cleaning up...

All done!  If you've completed all of the above steps, your MariaDB
installation should now be secure.

Thanks for using MariaDB!
[root@server1 ~]#

3 Installare Apache

CentOS 7 viene fornito con Apache 2.4. Apache è direttamente disponibile come pacchetto CentOS 7, quindi possiamo installarlo in questo modo:

yum -y install httpd

Ora configura il tuo sistema per avviare Apache all’avvio …

systemctl start httpd.service
systemctl enable httpd.service

Per poter accedere al server web dall’esterno, dobbiamo aprire le porte HTTP (80) e HTTPS (443) nel firewall. Il firewall predefinito su CentOS è firewalld che può essere configurato con il comando firewalld-cmd.

firewall-cmd --permanent --zone=public --add-service=http 
firewall-cmd --permanent --zone=public --add-service=https
firewall-cmd --reload

Ora indirizza il tuo browser all’indirizzo IP del tuo server, nel mio caso http://192.168.1.100, e dovresti vedere la pagina di Apache:

4 Installare PHP

La versione PHP fornita con CentOS come predefinito è piuttosto vecchia (PHP 5.4). Quindi ti mostrerò in questo capitolo alcune opzioni per installare versioni PHP più recenti come PHP 7.0 o 7.1 dal repository Remi.

Aggiungi il repository Remi CentOS.

rpm -Uvh http://rpms.remirepo.net/enterprise/remi-release-7.rpm

o istallare il repository con il seguente comando

 yum install http://rpms.remirepo.net/enterprise/remi-release-7.rpm

Installa yum-utils in quanto abbiamo bisogno dell’utilità yum-config-manager.

yum -y install yum-utils

and run yum update

yum update

Ora devi scegliere quale versione di PHP vuoi usare sul server. Se ti piace usare PHP 5.4, vai al capitolo 4.1. Per installare PHP 7.0, segui i comandi nel capitolo 4.2, per PHP 7.1 capitolo 4.3 e per PHP 7.1, usa invece il capitolo 4.4. Segui solo uno dei capitoli 4.x e non tutti, dato che puoi utilizzare una sola versione PHP alla volta con Ap_pod mod_php.

4.1 Installare PHP 5.4

Per istallare PHP 5.4, esegui questo comando:

yum -y install php

4.2 Installare PHP 7.0

Possiamo installare PHP 7.0 e il modulo Apache PHP 7.0 come segue:

yum-config-manager --enable remi-php70
yum -y install php php-opcache

4.3 Installare PHP 7.1

Se invece vuoi usare PHP 7.1 usa:

yum-config-manager --enable remi-php71
yum -y install php php-opcache

4.4 Installare PHP 7.2

Se invece vuoi usare PHP 7.2 usa:

yum-config-manager --enable remi-php72
yum -y install php php-opcache

4.5 Installare PHP 7.3

Se invece vuoi usare PHP 7.3 usa:

yum-config-manager --enable remi-php73
yum -y install php php-opcache

Dobbiamo riavviare Apache per applicare le modifiche:

 systemctl restart httpd.service

5 Test di PHP / Ottenere dettagli sull’installazione di PHP

La radice del documento del sito Web predefinito è / var / www / html. Creeremo un piccolo file PHP (info.php) in quella directory e lo chiameremo in un browser per testare l’installazione di PHP. Il file mostrerà molti dettagli utili sulla nostra installazione di PHP, come la versione PHP installata.

vi /var/www/html/info.php
<?php 
phpinfo();

Ora chiamiamo quel file in un browser (ad esempio http://192.168.1.100/info.php):


Come vedete, PHP 7.2 funziona e sta funzionando attraverso Apache 2.0 Handler, come mostrato nella riga API del server. Se scorri verso il basso, vedrai tutti i moduli che sono già abilitati in PHP. *Ma MySQL non è elencato lì, il che significa che non abbiamo ancora il supporto MySQL in PHP.

6 Ottenere supporto MySQL in PHP

Per ottenere supporto MySQL in PHP, possiamo installare il pacchetto php-mysqlnd. È una buona idea installare alcuni altri moduli PHP e potrebbero essere necessari per le tue applicazioni. Puoi cercare i moduli PHP5 disponibili in questo modo:

yum search php

Scegli quelli che ti servono e installali in questo modo:

yum -y install php-mysqlnd php-pdo

Nel prossimo passaggio installerò alcuni moduli PHP comuni richiesti dai sistemi CMS come WordPress, Joomla, GLPI e Drupal:

yum -y install php-gd php-ldap php-imap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-soap curl curl-devel

Ora riavvia il server Web Apache:

 systemctl restart httpd.service

Ora ricaricare http://192.168.1.100/info.php nel browser e scorrere di nuovo fino alla sezione dei moduli. Ora dovresti trovare molti nuovi moduli come l’arricciatura ecc.

Se non hai più bisogno dell’output di informazioni php, elimina quel file per motivi di sicurezza.

rm /var/www/html/info.php

7 Istallare phpMyAdmin

phpMyAdmin è un’interfaccia web attraverso la quale puoi gestire i tuoi database MySQL.
phpMyAdmin può ora essere installato come segue:

yum -y install phpMyAdmin


Ora configuriamo phpMyAdmin. Modifichiamo la configurazione di Apache in modo che phpMyAdmin permetta connessioni non solo da localhost (commentando la sezione <RequireAny> e aggiungendo la riga ‘Require all granted’ line’):

vi /etc/httpd/conf.d/phpMyAdmin.conf
[...]
Alias /phpMyAdmin /usr/share/phpMyAdmin Alias /phpmyadmin /usr/share/phpMyAdmin <Directory /usr/share/phpMyAdmin/>
AddDefaultCharset UTF-8

<IfModule mod_authz_core.c>
# Apache 2.4
# <RequireAny>
# Require ip 127.0.0.1
# Require ip ::1
# </RequireAny>
Require all granted

</IfModule>
<IfModule !mod_authz_core.c>
# Apache 2.2
Order Deny,Allow
Deny from All
Allow from 127.0.0.1
Allow from ::1
</IfModule>
</Directory>
<Directory /usr/share/phpMyAdmin/> Options none AllowOverride Limit Require all granted </Directory>

[...]

Successivamente, cambiamo l’autenticazione in phpMyAdmin da cookie a http:

vi /etc/phpMyAdmin/config.inc.php
[...]
$cfg['Servers'][$i]['auth_type']     = 'http';    // Authentication method (config, http or cookie based)?
[...]

Riavvia Apache:

systemctl restart  httpd.service

Successivamente, puoi accedere a phpMyAdmin sotto http://192.168.1.100/phpmyadmin/:

Nel caso specifico di alcuni software web si consiglia di istallare questi componenti utili dal repository EPEL

yum install php-opcache 
yum install php-pecl-apcu
yum install php-ldap
yum install php-imap
yum install php-pecl-zendopcache.x86_64
yum install php-pecl-apcu-bc
yum install php-xmlrpc
yum install php-pear-CAS.noarch -y ;

Adesso bisogna modificare il file httpd.conf

Prima di utilizzare un file .htaccess, è necessario aggiornare l’impostazione AllowOverride per poter sovrascrivere le direttive di Apache.

sudo vi /etc/httpd/conf/httpd.conf

Individua la sezione <Directory /var/www/html> e modifica la direttiva AllowOverride da None a All: /etc/httpd/conf/httpd.conf

. . .
<Directory /var/www/html>
. . .
 # 
 # AllowOverride controls what directives may be placed in .htaccess files.
 # It can be "All", "None", or any combination of the keywords:
 # Options FileInfo AuthConfig Limit
 #
 AllowOverride All
. . .
</Directory>
. . .

Mentre per modificare gli upload, il timeout e timezone da php modificare il file vi /etc/php.ini nella sezione size mb

per il timeout php max_execution_time 3000

Mentre per il timezone php corretto modificare la seguente riga

[Date] 
; Defines the default timezone used by the date functions
; http://www.php.net/manual/en/datetime.configuration.php#ini.date.timezone
date.timezone = Europe/Rome

Salvare e uscire dal file e quindi riavviare Apache per applicare la modifica:

sudo systemctl restart httpd

Salvare e uscire dal file e quindi riavviare Apache per applicare la modifica:

sudo systemctl restart httpd
Torna su