2020-11-30

本文详细介绍了Nginx的模块配置,包括目录索引、访问限制、访问控制、状态模块、连接限制和请求限制。还探讨了Nginx的location配置,以及LNMP架构的工作方式,包括静态和动态请求的处理流程。此外,文章还涵盖了LNMP架构的搭建步骤,涉及Nginx、PHP、MySQL的安装和配置,并展示了如何通过Nginx与PHP的关联处理动态请求。最后,提到了WordPress博客的搭建过程。
摘要由CSDN通过智能技术生成

一、nginx模块

1.目录索引模块

vim /etc/nginx/conf.d/www.autoindex.com.conf
server {
listen 80;
server_name www.autoindex.com;
charset utf8;
location / {
root /code/autoindex;
index index.html;
}
location /download {
root /code/autoindex;
autoindex on;
}
}

2.访问限制模块

1)语法
Syntax: allow address | CIDR | unix: | all;
Default: —
Context: http, server, location, limit_except
Syntax: deny address | CIDR | unix: | all;
Default: —
Context: http, server, location, limit_except

2)配置
允许10.0.0.1访问,拒绝所有
vim /etc/nginx/conf.d/www.autoindex.com.conf
server {
listen 80;
server_name www.autoindex.com;
charset utf8;
access_log /var/log/nginx/www.autoindex.com.log main;
location / {
root /code/autoindex;
index index.html;
location /download {
root /code/autoindex;
allow 10.0.0.1;
deny all;
}
}

3.访问控制模块

1)语法
Syntax: auth_basic string | off;
Default: auth_basic off;
Context: http, server, location, limit_except
Syntax: auth_basic_user_file file;
Default: —
Context: http, server, location, limit_except

2)配置密码文件
htpasswd -c /etc/nginx/auth_basic lhd
New password:
Re-type new password:
Adding password for user lhd

3)配置
vim /etc/nginx/conf.d/www.autoindex.com.conf
server {
listen 80;
server_name www.autoindex.com;
charset utf8;

location / {
root /code/autoindex;
index index.html;
}
location /download {
root /code/autoindex;
auth_basic “请输入用户名和密码:”;
auth_basic_user_file /etc/nginx/auth_basic;
}
}

4.nginx状态模块

1)语法
Syntax: stub_status;
Default: —
Context: server, location

2)配置
vim /etc/nginx/conf.d/www.autoindex.com.conf
server {
listen 80;
server_name www.autoindex.com;
charset utf8;
location / {
root /code/autoindex;
index index.html;
}
location = /basic_status {
stub_status;
}
}

3)页面
Active connections: 1
server accepts handled requests
1 1 1
Reading: 0 Writing: 1 Waiting: 0

4)监控网站的PV
curl -s http://www.autoindex.com/basic_status | awk ‘NR==3 {print $3}’

5.连接限制模块

ngx_http_limit_conn_module
1)语法
#设置限制的空间
Syntax: limit_conn_zone key zone=name:size;
Default: —
Context: http
limit_conn_zone #设置空间的模块
key #指定空间存储的内容
zone #指定空间
=name #空间名字
:size; #空间的大小
#调用限制的空间
Syntax: limit_conn zone number;
Default: —
Context: http, server, location
limit_conn #调用空间的模块
zone #空间的名字
number; #指定可以同时连接的次数

2)配置
vim /etc/nginx/conf.d/www.autoindex.com.conf
limit_conn_zone $remote_addr zone=conn_zone:10m;
server {
listen 80;
server_name www.autoindex.com;
charset utf8;;
limit_conn conn_zone 1;

location / {
root /code/autoindex;
index index.html;
}
}

6.请求限制模块

1)语法
#设置空间的语法
Syntax: limit_req_zone key zone=name:size rate=rate [sync];
Default: —
Context: http
limit_req_zone #设置空间的模块
key #空间存储的内容
zone #指定空间
=name #空间的名字
:size #空间的大小
rate=rate [sync]; #读写速率
#调用的语法
Syntax: limit_req zone=name [burst=number] [nodelay | delay=number];
Default: —
Context: http, server, location
limit_req #调用控件模块
zone=name #指定空间=空间的名字
[burst=number] #允许多请求几次
[nodelay | delay=number]; #延时

2)配置
[root@web01 ~]# vim /etc/nginx/conf.d/www.autoindex.com.conf
limit_conn_zone $remote_addr zone=conn_zone:10m;
limit_req_zone $remote_addr zone=req_zone:10m rate=1r/s;
server {
listen 80;
server_name www.autoindex.com;
charset utf8;
limit_conn conn_zone 1;
limit_req zone=req_zone;
#limit_req zone=req_zone burst=5 nodelay;
location / {
root /code/autoindex;
index index.html;
}
}

3)测试
ab -n 20000 -c 20 http://www.autoindex.com/index.html

二、nginx的location配置

1.语法
Syntax: location [ = | ~ | ~* | ^~ ] uri { … }
location @name { … }
Default: —
Context: server, location

2.location匹配符

在这里插入图片描述

3.Location应用场景
#通用匹配,任何请求都会匹配到
location / {

}
严格区分大小写,匹配以.php结尾的都走这个location
location ~ .php$ {

}
严格区分大小写,匹配以.jsp结尾的都走这个location
location ~ .jsp$ {

}
#不区分大小写匹配,只要用户访问.jpg,gif,png,js,css 都走这条location
location ~* .*.(jpg|gif|png|js|css)$ {

}

三、LNMP架构

1.简介
LNMP是一套技术的组合,L=Linux、N=Nginx、M=MySQL、P=PHP
不仅仅只有这些服务,还有很多
redis\elasticsearch\kibana\logstash\zabbix\git\jenkins\kafka\hbase\hadoop\spark\flink

2.LNMP架构工作方式
首先Nginx服务是不能处理动态请求,那么当用户发起动态请求时, Nginx又是如何进行处理的。

1.静态请求:请求的内容是静态文件就是静态请求

1)静态文件:文件上传到服务器,永远不会改变的文件就是静态文件

2)html就是一个标准的静态文件

2.动态请求:请求的内容是动态的就是动态请求

1)不是真实存在服务器上的内容,是通过数据库或者其他服务拼凑成的数据
当用户发起http请求,请求会被Nginx处理,如果是静态资源请求Nginx则直接返回,如果是动态请求Nginx则通过
fastcgi协议转交给后端的PHP程序处理,具体如下图所示

3.访问流程
1.浏览器输入域名,浏览器会拿着域名取DNS服务器解析

2.DNS服务器会将域名解析成IP

3.浏览器会去与IP对应服务器建立TCP\IP连接

4.连接建立完成,会向服务器发起请求,请求nginx

5.nginx会判断请求是动态的还是静态的
#静态请求
location .jpg$ {
root /code;
}
#动态请求
location .php$ {
fastcgi_pass 127.0.0.1:9000;
… …
}

6.如果是静态请求,nginx去code目录获取,直接返回

7.如果是动态请求,nginx会通过fastcgi协议连接PHP服务的php-fpm管理进程

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)配置官方源
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
yum install -y nginx

3)配置nginx
vim /etc/nginx/nginx.conf
user www;

4)创建用户
groupadd www -g 666
useradd www -u 666 -g 666 -s /sbin/nologin -M

5)验证启动nginx
systemctl start nginx
ps -ef | grep nginx

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)配置php
vim /etc/php-fpm.d/www.conf
user = www
group = www

3)验证启动
systemctl start php-fpm
ps -ef | grep php-fpm

3.搭建交作业页面
1)配置nginx
vim /etc/nginx/conf.d/default.conf
server {
listen 80;
server_name linux.zuoye.com;
location / {
root /code/zuoye;
index index.html;
}
}

2)创建站点目录
mkdir /code/zuoye -p

3)上传解压代码

4)修改代码中上传作业位置
vim /code/zuoye/upload_file.php
$wen="/code/zuoye/upload";

5)授权
chown -R www.www /code/

6)重启服务
systemctl restart nginx

7)配置hosts访问测试
#配置hosts
10.0.0.7 linux.zuoye.com
#访问
http://linux.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 /code/zuoye;
index index.html;
}
location ~* .php$ {
fastcgi_pass localhost:9000;
fastcgi_param SCRIPT_FILENAME /code/zuoye/$fastcgi_script_name;
include fastcgi_params;
}
}

3)访问页面测试
1.访问页面
http://linux.zuoye.com/
2.上传图片文件
成功
3.上传一个大文件
失败,413报错,说文件过大
#解决:修改配置文件上传文件大小配置
[root@web01 ~]# vim /etc/nginx/nginx.conf
http {
… …
client_max_body_size 200m;
… …
}
[root@web01 ~]# systemctl restart nginx
[root@web01 ~]# vim /etc/php.ini
upload_max_filesize = 200M
post_max_size = 200M
[root@web01 ~]# systemctl restart php-fpm
4.重新上传文件测试
成功

5.搭建mariadb
1)安装
yum install -y mariadb-server

2)验证启动
systemctl start mariadb-server
ps -ef | grep mariadb

3)设置数据库密码
mysqladmin -uroot password ‘123’
mysql -uroot -p123

6.测试PHP和mariadb关联
1)编写php测试连接数据库的代码
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..."; ?>

2)访问测试
http://linux.zuoye.com/test.php

五、搭建wordpress博客

1.上传解压代码
tar xf wordpress-5.0.3-zh_CN.tar.gz

2.授权
chown -R www.www wordpress

3.配置nginx
vim /etc/nginx/conf.d/linux.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;
}
}

4.重启访问
systemctl restart nginx
配置hosts
10.0.0.7 linux.wp.com
访问
http://linux.wp.com/

5.创建数据库
create database wordpress;

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值