Heim > Artikel > Betrieb und Instandhaltung > So installieren Sie die LEMP-Umgebung für den Nginx-Server in Ubuntu
Vorbereitung
Ubuntu 16.04-Serverversion installieren
Schritt 1: Nginx-Server installieren
1. Nginx ist ein fortschrittliches, ressourcenoptimiertes Webserverprogramm, das zum Anzeigen von Webseiten für Besucher im Internet verwendet wird. Wir beginnen mit der Installation des Nginx-Servers und beziehen mit dem Befehl apt das Nginx-Programm aus dem offiziellen Software-Repository von Ubuntu.
$ sudo apt-get install nginx
Installieren Sie nginx
2 auf Ubuntu 16.04 und geben Sie dann die Befehle netstat und systemctl ein, um zu bestätigen, dass der Nginx-Prozess gestartet und an Port 80 gebunden wurde.
$ netstat -tlpn
Überprüfen Sie die Nginx-Netzwerk-Port-Verbindung.
$ sudo systemctl status nginx.service
Überprüfen Sie den Nginx-Dienststatus.
Wenn Sie bestätigen, dass der Dienstprozess gestartet wurde, können Sie einen Browser öffnen und über das http-Protokoll auf die IP-Adresse Ihres Servers zugreifen oder Domänenname, durchsuchen Sie die Standardwebseite von Nginx.
http://ip-address
Schritt 2: Nginx-http/2.0-Protokoll aktivieren
3. Die Unterstützung für das http/2.0-Protokoll ist standardmäßig in der Nginx-Binärdatei der neuesten Version von Ubuntu 16.04 enthalten. Es kann nur über SSL verbunden werden wird garantiert geladen. Die Geschwindigkeit von Webseiten wurde erheblich verbessert.
Um dieses Protokoll von Nginx zu aktivieren, suchen Sie zunächst die von Nginx bereitgestellte Website-Konfigurationsdatei und geben Sie den folgenden Befehl ein, um die Konfigurationsdatei zu sichern.
$ cd /etc/nginx/sites-available/ $ sudo mv default default.backup
Nginx-Website-Konfigurationsdatei sichern
4. Erstellen Sie dann mit einem Texteditor eine Standarddatei und geben Sie den folgenden Inhalt ein:
server { listen 443 ssl http2 default_server; listen [::]:443 ssl http2 default_server; root /var/www/html; index index.html index.htm index.php; server_name 192.168.1.13; location / { try_files $uri $uri/ =404; } ssl_certificate /etc/nginx/ssl/nginx.crt; ssl_certificate_key /etc/nginx/ssl/nginx.key; ssl_protocols tlsv1 tlsv1.1 tlsv1.2; ssl_prefer_server_ciphers on; ssl_ciphers eecdh+chacha20:eecdh+aes128:rsa+aes128:eecdh+aes256:rsa+aes256:eecdh+3des:rsa+3des:!md5; ssl_dhparam /etc/nginx/ssl/dhparam.pem; ssl_session_cache shared:ssl:20m; ssl_session_timeout 180m; resolver 8.8.8.8 8.8.4.4; add_header strict-transport-security "max-age=31536000; #includesubdomains" always; location ~ \.php$ { include snippets/fastcgi-php.conf; fastcgi_pass unix:/run/php/php7.0-fpm.sock; } location ~ /\.ht { deny all; } } server { listen 80; listen [::]:80; server_name 192.168.1.13; return 301 https://$server_name$request_uri; }
Nginx-HTTP-2-Protokoll aktivieren
Der obige Konfigurationsausschnitt gilt für all ssl Fügen Sie dem Listening-Befehl den Parameter http2 hinzu, um http/2.0 zu aktivieren.
Der letzte Abschnitt, der oben zur Serverkonfiguration hinzugefügt wurde, wird verwendet, um den gesamten Nicht-SSL-Verkehr auf den SSL/TLS-Standardhost umzuleiten. Ersetzen Sie dann den Optionsparameter server_name durch die IP-Adresse oder den DNS-Eintrag Ihres Hosts (vorzugsweise den FQDN-Namen).
5. Nachdem Sie die obigen Schritte zum Bearbeiten der Standardkonfigurationsdatei von nginx ausgeführt haben, verwenden Sie die folgenden Befehle, um das SSL-Zertifikat und den SSL-Schlüssel zu generieren und anzuzeigen.
Schließen Sie die Zertifikatserstellung mit Ihren benutzerdefinierten Einstellungen ab. Beachten Sie, dass der allgemeine Name so eingestellt ist, dass er mit Ihrem DNS-FQDN-Eintrag oder Ihrer Server-IP-Adresse übereinstimmt.
$ sudo mkdir /etc/nginx/ssl $ sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/nginx/ssl/nginx.key -out /etc/nginx/ssl/nginx.crt $ ls /etc/nginx/ssl/
Generieren Sie das SSL-Zertifikat und den Schlüssel von nginx
6. Verwenden Sie einen starken DHCP-Verschlüsselungsalgorithmus, indem Sie den folgenden Befehl eingeben, der die durch die vorherige Konfigurationsdatei ssl_dhparam konfigurierte Datei ändert.
$ sudo openssl dhparam -out /etc/nginx/ssl/dhparam.pem 2048
Diffie-Hellman-Schlüssel erstellen
7 Überprüfen Sie nach der Generierung des Diffie-Hellman-Schlüssels, ob die Nginx-Konfigurationsdatei korrekt ist und vom Nginx-Netzwerkdienstprogramm angewendet werden kann. Führen Sie dann den folgenden Befehl aus, um den Daemon neu zu starten und alle Änderungen zu beobachten.
$ sudo nginx -t $ sudo systemctl restart nginx.service
Überprüfen Sie die Nginx-Konfiguration
8. Geben Sie den folgenden Befehl ein, um zu testen, ob Nginx das http/2.0-Protokoll verwendet. Wenn Sie im Protokoll h2 sehen, bedeutet dies, dass Nginx erfolgreich für die Verwendung des http/2.0-Protokolls konfiguriert wurde. Alle aktuellen Browser unterstützen dieses Protokoll standardmäßig.
$ openssl s_client -connect localhost:443 -nextprotoneg ''
Testen Sie das Nginx-HTTP-2.0-Protokoll. fastcgi kann durch die Installation des PHP-FPM-Binärpakets aus dem offiziellen Ubuntu-Repository erhalten werden.
9. Geben Sie den folgenden Befehl in Ihre Serverkonsole ein, um PHP7.0 und das Erweiterungspaket zu erhalten, das PHP die Kommunikation mit dem Nginx-Netzwerkdienstprozess ermöglicht.
$ sudo apt install php7.0 php7.0-fpmInstallieren Sie PHP 7 und PHP-FPM
10. Wenn der PHP7.0-Interpreter erfolgreich installiert wurde, geben Sie den folgenden Befehl ein, um den PHP7.0-FPM-Daemon zu starten oder zu überprüfen:
$ sudo systemctl start php7.0-fpm $ sudo systemctl status php7.0-fpm
开启、验证 php-fpm 服务
11、 当前的 nginx 配置文件已经配置了使用 php fpm 来提供动态内容。
下面给出的这部分服务器配置让 nginx 能够使用 php 解释器,所以不需要对 nginx 配置文件作别的修改。
location ~ \.php$ { include snippets/fastcgi-php.conf; fastcgi_pass unix:/run/php/php7.0-fpm.sock; }
下面是的截图是 nginx 默认配置文件的内容。你可能需要对其中的代码进行修改或者取消注释。
启用 php fastcgi
12、 要测试启用了 php-fpm 的 nginx 服务器,用下面的命令创建一个 php 测试配置文件 info.php。接着用 http://ip_or domain/info.php 这个网址来查看配置。
$ sudo su -c 'echo "<?php phpinfo(); ?>" |tee /var/www/html/info.php'
创建 php info 文件
检查 php fastcgi 的信息
检查服务器是否宣告支持 http/2.0 协议,定位到 php 变量区域中的 $_server[‘server_protocol'] 就像下面这张截图一样。
检查 http2.0 协议信息
13、 为了安装其它的 php7.0 模块,使用 apt search php7.0 命令查找 php 的模块然后安装。
如果你想要 安装 wordpress 或者别的 cms,需要安装以下的 php 模块,这些模块迟早有用。
$ sudo apt install php7.0-mcrypt php7.0-mbstring
安装 php 7 模块
14、 要注册这些额外的 php 模块,输入下面的命令重启 php-fpm 守护进程。
$ sudo systemctl restart php7.0-fpm.service
第 4 步:安装 mariadb 数据库
15、 最后,我们需要 mariadb 数据库来存储、管理网站数据,才算完成 lemp 的搭建。
运行下面的命令安装 mariadb 数据库管理系统,重启 php-fpm 服务以便使用 mysql 模块与数据库通信。
$ sudo apt install mariadb-server mariadb-client php7.0-mysql $ sudo systemctl restart php7.0-fpm.service
安装 mariadb
16、 为了安全加固 mariadb,运行来自 ubuntu 软件仓库中的二进制包提供的安全脚本,这会询问你设置一个 root 密码,移除匿名用户,禁用 root 用户远程登录,移除测试数据库。
输入下面的命令运行脚本,并且确认所有的选择。参照下面的截图。
$ sudo mysql_secure_installation
mariadb 的安全安装
17、 配置 mariadb 以便普通用户能够不使用系统的 sudo 权限来访问数据库。用 root 用户权限打开 mysql 命令行界面,运行下面的命令:
$ sudo mysql mariadb> use mysql; mariadb> update user set plugin='‘ where user='root'; mariadb> flush privileges; mariadb> exit
mariadb 的用户权限
最后通过执行以下命令登录到 mariadb 数据库,就可以不需要 root 权限而执行任意数据库内的命令:
$ mysql -u root -p -e 'show databases'
查看 mariadb 数据库
Das obige ist der detaillierte Inhalt vonSo installieren Sie die LEMP-Umgebung für den Nginx-Server in Ubuntu. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!