LNMP架構搭建
阿新 • • 發佈:2020-09-07
1.LNMP工作流程
首先Nginx服務是不能處理動態請求,那麼當用戶發起動態請求時, Nginx又是如何進行處理的。
1.靜態請求:請求靜態檔案的請求
靜態檔案:
1)上傳時什麼樣子,檢視時就是什麼樣子
2)html的頁面都是靜態的
2.動態請求:請求動態內容,帶引數的請求
1)伺服器上並不是真實存在的,需要都資料庫等服務上去獲取資料,組成的頁面
當用戶發起http請求,請求會被Nginx處理,如果是靜態資源請求Nginx則直接返回,如果是動態請求Nginx則通過fastcgi協議轉交給後端的PHP程式處理
2.訪問流程
1.瀏覽器輸入域名,瀏覽器拿著域名去本地hosts檔案解析,然後再去DNS伺服器解析
2.本地hosts檔案或者DNS伺服器解析域名為IP
3.瀏覽器去請求該IP對應的web伺服器
4.瀏覽器請求nginx
5.nginx判斷請求是動態請求還是靜態請求
#靜態請求
location / {
root /code;
index index.html;
}
location ~* \.(jpg|png|mp4)$ {
root /code/pic;
}
#動態請求
location ~* \.php$ {
fastcgi_pass 127.0.0.1:9000;
... ...
}
6.如果是靜態請求,nginx直接返回內容
7.如果是動態內容,nginx會通過fastcgi協議找php-fpm管理程序
8.php-fpm管理程序會去下發工作給wrapper工作程序
9.wrapper工作程序判斷是不是php檔案
10.如果只是php檔案,可以直接解析然後返回結果
11.如果還需要讀取資料庫,wrapper程序會去讀取資料庫資料,然後返回資料
12.資料流轉:
1)請求:瀏覽器-->負載均衡-->nginx-->php-fpm-->wrapper-->mysql
2)響應:mysql-->wrappe-->php-fpm-->nginx-->負載均衡-->瀏覽器
二、LNMP搭建
1.安裝nginx
1)配置官方源
[root@web01 ~]# vim /etc/yum.repos.d/nginx.repo [nginx-stable] name=nginx stable repo baseurl=http://nginx.org/packages/centos/7/$basearch/ gpgcheck=1 enabled=1 gpgkey=https://nginx.org/keys/nginx_signing.key module_hotfixes=true
2)安裝nginx
[root@web01 ~]# yum install -y gcc gcc-c++ autoconf pcre pcre-devel make automake wget httpd-tools vim tree [root@web01 ~]# yum install -y nginx
3)配置nginx
[root@web01 ~]# vim /etc/nginx/nginx.conf user www;
4)新增使用者
[root@web01 ~]# groupadd www -g 666 [root@web01 ~]# useradd www -u 666 -g 666
5)啟動服務
[root@web01 ~]# systemctl start nginx [root@web01 ~]# systemctl enable nginx Created symlink from /etc/systemd/system/multi-user.target.wants/nginx.service to /usr/lib/systemd/system/nginx.service.
6)驗證
[root@web01 ~]# ps -ef | grep nginx
2.安裝php (7版本)
安裝方式一(容易出錯):
1)配置第三方源
[root@web01 ~]# vim /etc/yum.repos.d/php.repo [php-webtatic] name = PHP Repository baseurl = http://us-east.repo.webtatic.com/yum/el7/x86_64/ gpgcheck = 0
2)解除安裝舊版本
[root@web01 ~]# yum remove php-mysql-5.4 php php-fpm php-common
3)安裝php
[root@web01 ~]# yum -y install php71w php71w-cli php71w-common php71w-devel php71w-embedded php71w-gd php71w-mcrypt php71w-mbstring php71w-pdo php71w-xml php71w-fpm php71w-mysqlnd php71w-opcache php71w-pecl-memcached php71w-pecl-redis php71w-pecl-mongodb
安裝方式二:
1)上傳程式碼包
#建立存放服務包的目錄 [root@web01 ~]# mkdir /package [root@web01 ~]# cd /package/ #上傳包 [root@web01 /package]# rz php.tar.gz #解壓包 [root@web01 /package]# tar xf php.tar.gz #安裝所有rpm包 [root@web01 /package]# yum localinstall -y *.rpm
2)配置PHP
[root@web01 /package]# vim /etc/php-fpm.d/www.conf user = www group = www
3)啟動服務
[root@web01 /package]# systemctl start php-fpm [root@web01 /package]# systemctl enable php-fpm
4)驗證啟動
[root@web01 /package]# ps -ef | grep php [root@web01 /package]# netstat -lntp tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 7748/php-fpm: master
3.搭建交作業頁面
1)配置nginx
[root@web01 /package]# vim /etc/nginx/conf.d/default.conf server { listen 80; server_name www.zuoye.com; location / { root /code/zuoye; index index.html; } }
2)建立站點目錄
[root@web01 /package]# mkdir /code/zuoye -p
3)上傳程式碼
[root@web01 /package]# cd /code/zuoye/ [root@web01 /code/zuoye]# rz kaoshi.zip [root@web01 /code/zuoye]# yum install -y unzip [root@web01 /code/zuoye]# unzip kaoshi.zip #授權 [root@web01 /code/zuoye]# chown -R www.www /code/
4)修改交作業程式碼
[root@web01 /code/zuoye]# vim upload_file.php $wen="/code/zuoye/upload";
5)訪問測試
[root@web01 /code/zuoye]# systemctl restart nginx #配置本地hosts檔案 10.0.0.7 www.zuoye.com #訪問www.zuoye.com
6)問題
#報錯405,原因是nginx作為web伺服器沒有辦法處理post請求,我們要用php的程式碼,需要關聯nginx和php
4.關聯nginx和PHP
1)關聯語法
#fastcgi_pass,進行連線PHP Syntax: fastcgi_pass address; Default: — Context: location, if in location #預設php頁面 Syntax: fastcgi_index name; Default: — Context: http, server, location #請求的檔案 Syntax: fastcgi_param parameter value [if_not_empty]; Default: — Context: http, server, location
2)配置
[root@web01 /code/zuoye]# vim /etc/nginx/conf.d/default.conf server { listen 80; server_name www.zuoye.com; location / { root /code/zuoye; index index.html; } location ~* \.php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_param SCRIPT_FILENAME /code/zuoye/$fastcgi_script_name; include fastcgi_params; } }
3)訪問頁面測試
#訪問http://www.zuoye.com/ 1.上傳檔案成功 2.413報錯:檔案過大,解決方式 #修改nginx上傳檔案大小 [root@web01 /code/zuoye]# vim /etc/nginx/nginx.conf http { ... ... client_max_body_size 100M; ... ... } [root@web01 /code/zuoye]# systemctl restart nginx #修改php上傳檔案大小 [root@web01 /code/zuoye]# vim /etc/php.ini post_max_size = 100M upload_max_filesize = 100M [root@web01 /code/zuoye]# systemctl restart php-fpm
5.搭建mariadb
1)安裝
[root@web01 /code/zuoye]# yum install -y mariadb-server
2)啟動服務
[root@web01 /code/zuoye]# systemctl start mariadb [root@web01 /code/zuoye]# systemctl enable mariadb
3)驗證
[root@web01 /code/zuoye]# netstat -lntp tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 9887/mysqld
4)連線
[root@web01 /code/zuoye]# mysql Welcome to the MariaDB monitor. Commands end with ; or \g. Your MariaDB connection id is 2 Server version: 5.5.65-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 | | test | +--------------------+ 4 rows in set (0.00 sec)
5)設定資料庫密碼
#設定密碼 [root@web01 /code/zuoye]# mysqladmin -u root password "123" #使用密碼連線 [root@web01 /code/zuoye]# mysql -u root -p Enter password:
6.關聯php和MySQL
1)編寫php測試連線資料庫程式碼
[root@web01 /code/zuoye]# vim php_mysql.php <?php $servername = "localhost"; $username = "root"; $password = "123"; // 建立連線 $conn = mysqli_connect($servername, $username, $password); // 檢測連線 if (!$conn) { die("Connection failed: " . mysqli_connect_error()); } echo "小哥哥,php可以連線MySQL..."; ?> <img style='width:100%;height:100%;' src=https://blog.driverzeng.com/zenglaoshi/php_mysql.png>
2)訪問
http://www.zuoye.com/php_mysql.php
三、LNMP架構搭建wordpress
1.上傳程式碼
[root@web01 /code/zuoye]# cd /code/ [root@web01 /code]# rz wordpress-5.0.3-zh_CN.tar.gz
2.解壓程式碼包
[root@web01 /code]# tar xf wordpress-5.0.3-zh_CN.tar.gz [root@web01 /code]# ll total 10844 drwxr-xr-x 5 1006 1006 4096 Jan 11 2019 wordpress #授權 [root@web01 /code]# chown -R www.www /code/
3.配置nginx
[root@web01 /code]# vim /etc/nginx/conf.d/linux.blog.com.conf server { listen 80; server_name linux.blog.com; location / { root /code/wordpress; index index.php; } location ~* \.php$ { root /code/wordpress; fastcgi_pass 127.0.0.1:9000; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; }
}
4.重啟訪問
#重啟nginx [root@web01 /code]# systemctl restart nginx #配置本地hosts 10.0.0.7 linux.blog.com #訪問 http://linux.blog.com
5.建立資料庫
[root@web01 /code]# mysql -uroot -p123 Welcome to the MariaDB monitor. Commands end with ; or \g. Your MariaDB connection id is 3 Server version: 5.5.65-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)]> create database blog; Query OK, 1 row affected (0.00 sec) MariaDB [(none)]> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | blog | | mysql | | performance_schema | | test | +--------------------+ 5 rows in set (0.00 sec)
四、LNMP搭建知乎
1.上傳程式碼
[root@web01 /code]# rz WeCenter_3-2-1.zip
2.解壓
[root@web01 /code]# unzip WeCenter_3-2-1.zip [root@web01 /code]# mv WeCenter_3-2-1 zhihu #授權 [root@web01 /code]# chown -R www.www /code/
3.配置
[root@web01 /code]# vim /etc/nginx/conf.d/linux.zh.com.conf server { listen 80; server_name linux.zh.com; location / { root /code/zhihu; index index.php; } location ~* \.php$ { root /code/zhihu; fastcgi_pass 127.0.0.1:9000; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } }
4.重啟訪問
[root@web01 /code]# systemctl restart nginx #配置本地hosts
5.建立資料庫
[root@web01 /code]# mysql -uroot -p123 Welcome to the MariaDB monitor. Commands end with ; or \g. Your MariaDB connection id is 131 Server version: 5.5.65-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)]> create database zh; Query OK, 1 row affected (0.00 sec) MariaDB [(none)]> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | blog | | mysql | | performance_schema | | test | | zh | +--------------------+ 6 rows in set (0.00 sec)