Zoeken op website

Lighttpd installeren met PHP en MariaDB op CentOS/RHEL 8/7


Lighttpd is een open-source, veilige, snelle, flexibele en meer geoptimaliseerde webserver die is ontworpen voor snelheidskritische omgevingen met minder geheugengebruik in vergelijking met andere webservers.

Het kan tot 10.000 verbindingen parallel op één server verwerken met effectief beheer van de CPU-belasting en wordt geleverd met een geavanceerde functieset zoals FastCGI, SCGI, Auth, Output-Compression, URL-Rewriting en nog veel meer.

Lighttpd is een uitstekende oplossing voor elke Linux-server, vanwege de snelle io-infrastructuur waarmee we meerdere malen betere prestaties kunnen opschalen met dezelfde hardware dan met andere alternatieve webservers.

In deze tutorial leggen we uit hoe je Lighttpd installeert met PHP, PHP-FPM, en MariaDB op CentOS/RHEL 8/7 distributies met hostnaam linux-console.net en IP-adres 192.168.0.103.

Stap 1: Installeer Lighttpd-webserver

1. Om Lighttpd te installeren, moet je eerst je systeemsoftwarepakketten en beschikbare opslagplaatsen bijwerken met behulp van de volgende yum-opdracht.

yum -y update

2. Vervolgens moet u de EPEL-repository op uw systeem inschakelen en softwarepakketten bijwerken met behulp van de volgende opdrachten.

yum -y install epel-release
yum -y update

3. Nadat u de EPEL-repository heeft ingeschakeld, kunt u nu Lighttpd installeren door de volgende opdracht uit te voeren.

yum install lighttpd

4. Zodra de Lighttpd-pakketten zijn geïnstalleerd, kunt u de service starten en inschakelen om automatisch te starten tijdens het opstarten. Zorg ervoor dat u de status verifieert met de volgende opdrachten.

systemctl start lighttpd
systemctl enable lighttpd
systemctl status lighttpd

5. Controleer nu de versie van Lighttpd die op uw systeem is geïnstalleerd met behulp van de volgende opdracht.

lighttpd -v

lighttpd/1.4.55 (ssl) - a light and fast webserver

6. Nu moet u HTTP- en HTTPS-verkeer op uw firewall toestaan.

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

7. Open nu uw browser en wijs naar de volgende URL om uw Lighttpd webserver te zien werken.

http://Your-Domain.com
OR
http://Your-IP-addr

De standaard documenthoofdmap voor Lighttpd is /var/www/lighttpd/ en het hoofdconfiguratiebestand bevindt zich onder /etc/lighttpd/lighttpd.conf.

Stap 2: MariaDB installeren als MySQL in CentOS 7

8. Installeer vervolgens MySQL-ondersteuning voor Lighttpd met behulp van de volgende opdrachten.

yum -y install mariadb mariadb-server

9. Zodra de installatie is voltooid, start, activeert en verifieert u de status van MariaDB met behulp van de volgende opdrachten.

systemctl start mariadb.service
systemctl enable mariadb.service
systemctl status mariadb.service

10. Ten slotte moet u uw MariaDB-installatie beveiligen door de volgende opdracht te geven.

mysql_secure_installation

U krijgt een aantal verschillende vragen over uw MariaDB-installatie en hoe u deze wilt beveiligen. U kunt het root-gebruikerswachtwoord van de database wijzigen, de testdatabase uitschakelen, anonieme gebruikers uitschakelen en root-aanmelding op afstand uitschakelen.

Voorbeelduitvoer
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 authorization. Set root password? [Y/n] y New password: Re-enter new password: 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] y ... 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] y ... 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] y - 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] y ... 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!

11. Probeer verbinding te maken met de MySQL-server en bekijk de bestaande databases op uw databaseserver met de volgende opdrachten op de terminal.

mysql -u root -p
Voorbeelduitvoer
Enter password: 
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 10
Server version: 5.5.60-MariaDB MariaDB Server

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
+--------------------+
3 rows in set (0.00 sec)

MariaDB [(none)]>

Stap 3: PHP en PHP-FPM installeren met FastCGI op CentOS 7

12. Om PHP-FPM met FastCGI-ondersteuning in te schakelen, moet je eerst PHP installeren, samen met de benodigde extensies met behulp van de volgende opdracht.

yum -y install php php-mysqlnd php-pdo php-gd php-mbstring

13. Nadat PHP is geïnstalleerd, schakelt u nu PHP-FPM en FastCGI ondersteuning in voor Lighttpd >, hiervoor moet u deze pakketten ook installeren.

yum -y install php-fpm lighttpd-fastcgi

14. Open nu een bestand met de naam /etc/php-fpm.d/www.conf.

vi /etc/php-fpm.d/www.conf

Stel de gebruiker en groep in op Lighttpd.

; Unix user/group of processes
; Note: The user is mandatory. If the group is not set, the default user's group
;       will be used.
; RPM: apache Choosed to be able to access some dir as httpd
user = lighttpd
; RPM: Keep a group allowed to write in log dir.
group = lighttpd

Bovendien gebruikt PHP-FPM standaard de /var/run/php/php7.0-fpm.sock socket. U moet PHP-FPM maken om een TCP-verbinding te gebruiken. Laat de listen regel er als volgt uitzien:

;listen = /var/run/php/php7.0-fpm.sock
listen = 127.0.0.1:9000 

15. Start nu de PHP-FPM service en zorg ervoor dat deze automatisch wordt gestart tijdens het opstarten met behulp van de volgende opdrachten.

systemctl start php-fpm.service
systemctl enable php-fpm.service

Stap 4: PHP en PHP-FPM inschakelen met FastCGI in Lighttpd

16. Hier moeten we drie bestanden /etc/php.ini, /etc/lighttpd/modules.conf en aanpassen /etc/lighttpd/conf.d/fastcgi.conf om PHP-ondersteuning voor Lighttpd in te schakelen.

Open het eerste bestand /etc/php.ini.

vi /etc/php.ini

Verwijder het commentaar op de volgende regel met de tekst regel cgi.fix_pathinfo=1.

; cgi.fix_pathinfo provides *real* PATH_INFO/PATH_TRANSLATED support for CGI.  PHP's
; previous behaviour was to set PATH_TRANSLATED to SCRIPT_FILENAME, and to not grok
; what PATH_INFO is.  For more information on PATH_INFO, see the cgi specs.  Setting
; this to 1 will cause PHP CGI to fix its paths to conform to the spec.  A setting
; of zero causes PHP to behave as before.  Default is 1.  You should fix your scripts
; to use SCRIPT_FILENAME rather than PATH_TRANSLATED.
; http://php.net/cgi.fix-pathinfo
cgi.fix_pathinfo=1

Open vervolgens het tweede bestand met de naam /etc/lighttpd/modules.conf.

vi /etc/lighttpd/modules.conf

Verwijder het commentaar op de volgende regel die zegt: include “conf.d/fastcgi.conf”.

##
## FastCGI (mod_fastcgi)
##
include "conf.d/fastcgi.conf"

Open vervolgens het derde bestand met de naam /etc/lighttpd/conf.d/fastcgi.conf.

vi /etc/lighttpd/conf.d/fastcgi.conf

Voeg nu de volgende container onderaan het bestand toe en sla deze op.

fastcgi.server += ( ".php" =>
        ((
                "host" => "127.0.0.1",
                "port" => "9000",
                "broken-scriptfilename" => "enable"
        ))
)

Start de Lighttpd-service opnieuw om de wijzigingen weer te geven en schakel PHP-ondersteuning in.

systemctl restart lighttpd

Stap 5: PHP en PHP-FPM testen met FastCGI-ondersteuning in Lighttpd

17. Zoals we hierboven zeiden, is de standaarddocumentroot voor Lighttpd /var/www/lighttpd/. Dus hier zullen we een phpinfo.php bestand in deze map aanmaken.

vi /var/www/lighttpd/info.php

Voeg er de volgende regels aan toe. Dit kleine stukje code geeft informatie weer over de PHP-installatie en hun versies.

<?php
phpinfo();
?>

18. Open uw browser en navigeer naar de volgende links.

http://Your-Domain.com/info.php
OR
http://Your-IP-addr/info.php

U zult werkinformatie zien van PHP, PHP-FPM, en MySQL met veel andere modules die al zijn ingeschakeld.