LNMP架构搭建 --01

一、LNMP架构
1.简介
LNMP是一套技术的组合,L=Linux、N=Nginx、M~=mysql、P~=php等等 --> #最基本架构
不仅仅只有这些服务,还有很多
redis\ELK\kibana\logstash\zabbix\git\jenkins\kafka\等等
2.LNMP架构工作方式
先Nginx服务是不能处理动态请求,那么当用户发起动态请求时, Nginx又是如何进行处理的。
             ### 很多web服务不能执行动态请求
	1.静态请求:请求的内容是静态文件就是静态请求
		1.1 静态文件:文件上传到服务器,永远不会改变的文件就是静态文件
		1.2 html就是一个标准的静态文件
	2.动态请求:请求的内容是动态的就是动态请求
		1.不是真实存在服务器上的内容,是通过数据库或者其他服务拼凑成的数据

当用户发起http请求,请求会被Nginx处理,如果是静态资源请求Nginx则直接返回,如果是动态请求Nginx则通过fastcgi协议转交给后端的PHP程序处理,具体如下图所示

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-q07zJebE-1617288697185)(C:\Users\17155\Desktop\下载图片\1617274763491.png)]

3.访问流程
1.浏览器输入域名,浏览器会拿着域名取DNS服务器解析
2.DNS服务器会将域名解析成IP
3.浏览器会去与IP对应服务器建立TCP\IP连接
4.连接建立完成,会向服务器发起请求,请求nginx
5.nginx会判断请求是动态的还是静态的   ### 向后会动静分离
	#静态请求
	location \.jpg$ {
        root /mm;
	}
	#动态请求
	location \.php$ {
        fastcgi_pass 127.0.0.1:9000;
        ... ...
	}
6.如果是静态请求,nginx去mm目录获取,直接返回
7.如果是动态请求,nginx会通过fastcgi协议连接PHP服务的php-fpm管理进程

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xqJqQzZq-1617288697195)(C:\Users\17155\Desktop\下载图片\1617275810831.png)]

8.php-fpm管理进程会下发工作给 wrapper工作进程
9.wrapper工作进程判断是不是简单的php内容
10.如果只是php内容则使用php解析器解析后直接返回
11.如果还需要读取数据库,wrapper工作进程会去数据库读取数据,再返回数据
12.数据流转过程:
	1.请求:浏览器 > 负载均衡 > nginx > php-fpm > wrapper > mysql
	2.响应:mysql > wrapper > 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 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 -s /sbin/nologin -M
# 5.启动nginx
[root@web01 ~]# systemctl start nginx
[root@web01 yum.repos.d]# 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
root       9953      1  0 11:17 ?        00:00:00 nginx: master process /usr/sbin/nginx -c /etc/nginx/nginx.conf
www        9954   9953  0 11:17 ?        00:00:00 nginx: worker process
2.搭建php
## 1、安装方式一(不推荐)
# rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
# rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

[root@nginx ~]# yum remove php-mysql-5.4 php php-fpm php-common   ### 切记切记

#配置第三方源
[root@nginx ~]# 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

[root@nginx ~]# 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

## 2、安装方式二(推荐)
1.上传包
[root@web01 ~]# rz
[root@web01 ~]# ll
-rw-r--r--. 1 root root 19889622 Nov 22 15:52 php.tar.gz

2.解压包
[root@web01 ~]# tar xf php.tar.gz

3.本地安装php的rpm包
[root@web01 ~]# yum localinstall -y *.rpm

4.配置php
[root@web01 ~]# vim /etc/php-fpm.d/www.conf 
user = www
group = www

5.启动服务		
[root@web01 ~]# systemctl start php-fpm
[root@web01 ~]# systemctl enable php-fpm
Created symlink from /etc/systemd/system/multi-user.target.wants/php-fpm.service to /usr/lib/systemd/system/php-fpm.service

6.验证启动
[root@web01 ~]# ps -ef | grep php-fpm
root       3350      1  0 20:34 ?        00:00:00 php-fpm: master process (/etc/php-fpm.conf)
www        3351   3350  0 20:34 ?        00:00:00 php-fpm: pool www
www        3352   3350  0 20:34 ?        00:00:00 php-fpm: pool www
www        3353   3350  0 20:34 ?        00:00:00 php-fpm: pool www
www        3354   3350  0 20:34 ?        00:00:00 php-fpm: pool www
www        3355   3350  0 20:34 ?        00:00:00 php-fpm: pool www
root       3439   2182  0 20:35 pts/1    00:00:00 grep --color=auto php-fpm
3.搭建交作业页面
1.配置nginx
[root@web01 zuoye]# cat /etc/nginx/conf.d/default.conf 
server {
    listen 80;
    server_name linux12.zuoye.com;

    location / {
        root /mm/zuoye;
	index index.html;
    }
}

2.创建站点目录
[root@web01 ~]# mkdir -p /mm/zuoye

3)上传代码
[root@web01 ~]# cd /mm/zuoye/
[root@web01 zuoye]# rz
[root@web01 zuoye]# ll
-rw-r--r--. 1 root root 26995 Nov 22 16:47 kaoshi.zip
[root@web01 zy]# ll
total 80
-rw-r--r-- 1 root root 38772 Apr 27  2018 bg.jpg
-rw-r--r-- 1 root root  2633 May  4  2018 index.html
-rw-r--r-- 1 root root    52 May 10  2018 info.php
-rw-r--r-- 1 root root 26995 Apr  1 19:33 kaoshi.zip
-rw-r--r-- 1 root root  1192 Jan 10  2020 upload_file.php

4.修改代码中上传作业位置
[root@web01 ~]# vim /mm/zuoye/upload_file.php
$wen="/mm/zuoye/upload";

5.授权
[root@web01 zuoye]# chown -R www.www /mm/

6)重启服务
[root@web01 ~]# systemctl restart nginx
1
7)配置hosts访问测试
#配置hosts
10.0.0.7 linux12.zuoye.com

#访问
http://linux12.zuoye.com/

#测试
上传代码出错,报错405,因为nginx没办法处理php代码程序
4.关联nginx与php
1.关联语法
#fastcgi_pass,nginx连接php的代理协议
Syntax:	fastcgi_pass address;
Default:	—
Context:	location, if in location

#指定请求的文件
Syntax:	fastcgi_param parameter value [if_not_empty];
Default:	—
Context:	http, server, location

#指定默认的php页面
Syntax:	fastcgi_index name;
Default:	—
Context:	http, server, location

2.配置
[root@web01 ~]# vim /etc/nginx/conf.d/default.conf 
server {
    listen 80;
    server_name linux.zuoye.com;

    location / {
        root /mm/zy;
        index index.html;
    }

    location ~* \.php$ {
        fastcgi_pass localhost:9000;
        fastcgi_param SCRIPT_FILENAME /mm/zuoye/$fastcgi_script_name;
        include fastcgi_params;  ##文件地址cat /etc/nginx/fastcgi_params
    }
}

3.访问页面测试

1.访问页面
http://linux12.zuoye.com/

2.上传图片文件

格式:5_nfs.jpg

成功

3.上传一个大文件

失败,413报错,说文件过大

#解决:修改配置文件上传文件大小配置
	[root@web01 ~]# vim /etc/nginx/nginx.conf
	http {
		... ...
		client_max_body_size 2g;
		... ...
	}
	[root@web01 ~]# systemctl restart nginx
	
	[root@web01 ~]# vim /etc/php.ini
	upload_max_filesize = 2G
	post_max_size = 2G
	[root@web01 ~]# systemctl restart php-fpm

4.重新上传文件测试
成功
5.搭建mariadb
1、安装
[root@web01 ~]# yum install -y mariadb-server
2、启动服务
[root@web01 ~]# systemctl start mariadb
root@web01 upload]# systemctl enable mariadb
Created symlink from /etc/systemd/system/multi-user.target.wants/mariadb.service to /usr/lib/systemd/system/mariadb.service.
3、验证启动
[root@web01 upload]#  ps -ef | grep mariadb
mysql      9251   9084  0 21:55 ?        00:00:00 /usr/libexec/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib64/mysql/plugin --log-error=/var/log/mariadb/mariadb.log --pid-file=/var/run/mariadb/mariadb.pid --socket=/var/lib/mysql/mysql.sock
root       9344   2182  0 21:56 pts/1    00:00:00 grep --color=auto mariadb

4、连接
[root@web01 ~]# mysql
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 2
Server version: 5.5.68-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_sche ma |
| test               |
+--------------------+
4 rows in set (0.00 sec)

5、设置数据库密码
[root@web01 ~]# mysqladmin -uroot password '123'

## 直接输入mysql错误,必须输入密码
[root@web01 upload]# mysql
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)

#使用密码连接数据库
[root@web01 ~]# mysql -uroot -p123
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 5
Server version: 5.5.68-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)]>
6.测试PHP和mariadb关联
1.编写php测试连接数据库的代码
[root@web01 ~]# vim /code/zuoye/test.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://linux12.zuoye.com/test.php  ###关闭数据库就不可以访问了systemctl stop mariadb
7.搭建wordpress博客
1.上传代码
[root@web01 mm]# rz
[root@web01 mm]# ll
-rw-r--r--. 1 root root 11098483 Sep 12 17:52 wordpress-5.0.3-zh_CN.tar.gz

2.解压代码
[root@web01 mm]# tar xf wordpress-5.0.3-zh_CN.tar.gz
1
3.授权
[root@web01 mm]# chown -R www.www wordpress
1
4.配置nginx
[root@web01 mm]# vim /etc/nginx/conf.d/linux12.wp.com.conf
server {
    listen 80;
    server_name linux.wp.com;

    location / {
        root /code/wordpress;
        index index.php;
    }

    location ~* \.php$ {
        fastcgi_pass 127.0.0.1:9000;
        fastcgi_param SCRIPT_FILENAME /code/wordpress/$fastcgi_script_name;
        include fastcgi_params;
    }
}

5.重启访问

#检查配置
[root@web01 mm]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

#重启
[root@web01 mm]# systemctl restart nginx

6.访问测试

#配置本地hosts  ctrl +r  drivers /etc/hosts

#配置hosts
10.0.0.7 linux12.wp.com

#访问
    http://linux12.wp.com/

7.创建数据库
[root@web01 mm]# mysql -uroot -p123

MariaDB [(none)]> create database wordpress;
Query OK, 1 row affected (0.00 sec)

MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
| wordpress          |
+--------------------+
5 rows in set (0.00 sec)
博客 http://linux12.wp.com/

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DuaE9CxO-1617288697196)(C:\Users\17155\Desktop\下载图片\1617287812316.png)]
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FikL-09-19

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值