Nginx 安装
Nginx版本和安装方式
Nginx版本 Mainline version 主要开发版本,一般为奇数版本号,比如1.19
Stable version 当前最新稳定版,一般为偶数版本,如:1.20
Legacy versions 旧的稳定版,一般为偶数版本,如:1.18
Nginx安装可以使用yum或源码安装,但是推荐使用源码编译安装
yum的版本比较旧
编译安装可以更方便自定义相关路径
使用源码编译可以自定义相关功能,更方便业务的上的使用
Nginx 编译安装
官方源码包下载地址
下载依赖项
dnf install gcc pcre-devel zlib-devel openssl-devel -y
解压nginx
tar zxf nginx-1.24.0.tar.gz
useradd -s /sbin/nologin -M nginx
进入解压后的nginx目录
data:image/s3,"s3://crabby-images/87359/87359079e471adce770642eb876201d59986617c" alt=""
检查环境,包括依赖项以及指定配置参数
[root@Nginx nginx-1.24.0]# ./configure --prefix=/usr/local/nginx \
--user=nginx \ # 指定nginx运行用户
--group=nginx \ # 指定nginx运行组
--with-http_ssl_module \ # 支持https://
--with-http_v2_module \ # 支持http版本2
--with-http_realip_module \ # 支持ip透传
--with-http_stub_status_module \ # 支持状态页面
--with-http_gzip_static_module \ # 支持压缩
--with-pcre \ # 支持正则
--with-stream \ # 支持tcp反向代理
--with-stream_ssl_module \ # 支持tcp的ssl加密
--with-stream_realip_module # 支持tcp的透传ip
[root@Nginx nginx-1.24.0]# make && make install
检查完毕没有报错后就make && make install
、
nginx完成安装以后,有四个主要的目录
[root@Nginx nginx-1.24.0]# ls /usr/local/nginx/
conf html logs sbin
conf:保存nginx所有的配置文件,其中nginx.conf是nginx服务器的最核心最主要的配置文件,其他
的.conf则是用来配置nginx相关的功能的,例如fastcgi功能使用的是fastcgi.conf和fastcgi_params
两个文件,配置文件一般都有一个样板配置文件,是以.default为后缀,使用时可将其复制并将default后缀
去掉即可。
html目录中保存了nginx服务器的web文件,但是可以更改为其他目录保存web文件,另外还有一个50x的web
文件是默认的错误页面提示页面。
logs:用来保存nginx服务器的访问日志错误日志等日志,logs目录可以放在其他路径,比
如/var/logs/nginx里面。
sbin:保存nginx二进制启动脚本,可以接受不同的参数以实现不同的功能。
如果检查失败想要重做就make clean
移除nginx
data:image/s3,"s3://crabby-images/6bb41/6bb41993b4a67f85be10a5ca3bb76b2d2f9df476" alt=""
验证版本及编译参数
[root@Nginx ~]# vim ~/.bash_profile
export PATH=$PATH:/usr/local/nginx/sbin
[root@Nginx ~]# source ~/.bash_profile
[root@Nginx ~]# nginx -V
nginx version: nginx/1.24.0
built by gcc 11.4.1 20231218 (Red Hat 11.4.1-3) (GCC)
built with OpenSSL 3.0.7 1 Nov 2022
TLS SNI support enabled
configure arguments: --group=nginx --with-http_ssl_module --with-http_v2_module -
-with-http_realip_module --with-http_stub_status_module --withhttp_gzip_static_module
--with-pcre --with-stream --with-stream_ssl_module --
with-stream_realip_module
把nginx添加进环境变量中
data:image/s3,"s3://crabby-images/16469/1646938bf202acdad7764292d5ca92f737a71f2d" alt=""
data:image/s3,"s3://crabby-images/cabf1/cabf12a3d1c99d5814b169d02e32b456007eec2b" alt=""
data:image/s3,"s3://crabby-images/a9a14/a9a1498a17b779dd2bdeaaeb077a0a26613010db" alt=""
然后在网页访问ip会查看到nginx
data:image/s3,"s3://crabby-images/70981/709810b90808cc106f8ba1f71ca6511b0813f5bd" alt=""
Nginx 启动文件
让我们能够使用systemctl命令来管理nginx
[root@Nginx ~]# vim /lib/systemd/system/nginx.service
[Unit]
Description=The NGINX HTTP and reverse proxy server
After=syslog.target network-online.target remote-fs.target nss-lookup.target
Wants=network-online.target
[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStartPre=/usr/local/nginx/sbin/nginx -t
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
[root@Nginx ~]# systemctl daemon-reload
[root@Nginx ~]# systemctl start nginx
data:image/s3,"s3://crabby-images/930d0/930d0ec9cc81850688a53207febfabce10168301" alt=""
data:image/s3,"s3://crabby-images/fa523/fa523c90598fed3ef3315e968c1a3b12c462eabf" alt=""
如果没办法启动nginx,请杀掉nginx的进程
killall -9 nginx
平滑升级和回滚
有时候我们需要对Nginx版本进行升级以满足对其功能的需求,例如添加新模块,需要新功能,而此时 Nginx又在跑着业务无法停掉,这时我们就可能选择平滑升级
平滑升级流程
data:image/s3,"s3://crabby-images/0f44d/0f44d7533d30712dfd66771482c9d7da7d51cdba" alt=""
- 将旧Nginx二进制文件换成新Nginx程序文件(注意先备份)
- 向master进程发送USR2信号
- master进程修改pid文件名加上后缀.oldbin,成为nginx.pid.oldbin
- master进程用新Nginx文件启动新master进程成为旧master的子进程,系统中将有新旧两个Nginx主
- 进程共同提供Web服务,当前新的请求仍然由旧Nginx的worker进程进行处理,将新生成的master进
- 程的PID存放至新生成的pid文件nginx.pid
- 向旧的Nginx服务进程发送WINCH信号,使旧的Nginx worker进程平滑停止
- 向旧master进程发送QUIT信号,关闭老master,并删除Nginx.pid.oldbin文件
- 如果发现升级有问题,可以回滚∶向老master发送HUP,向新master发送QUIT
平滑升级和回滚案例
平滑升级
解压nginx1.26版本,所有需要的东西我都放在了开头的资源里面
[root@Nginx nginx]# tar zxf nginx-1.26.1.tar.gz
[root@Nginx nginx]# cd nginx-1.26.1/
#开始编译新版本
[root@Nginx nginx-1.26.1]# ./configure --with-http_ssl_module --withhttp_v2_module
--with-http_realip_module --with-http_stub_status_module --withhttp_gzip_static_module
--with-pcre --with-stream --with-stream_ssl_module --
with-stream_realip_module
#只要make无需要make install
[root@Nginx nginx-1.26.1]# make
#查看两个版本
[root@Nginx nginx-1.26.1]# ll objs/nginx /usr/local/nginx/sbin/nginx
-rwxr-xr-x 1 root root 1239416 Jul 18 15:08 objs/nginx
-rwxr-xr-x 1 root root 5671488 Jul 18 11:41 /usr/local/nginx/sbin/nginx
#把之前的旧版的nginx命令备份
[root@Nginx ~]# cd /usr/local/nginx/sbin/
[root@Nginx sbin]# cp nginx nginx.24
#把新版本的nginx命令复制过去
[root@Nginx sbin]# \cp -f /root/nginx/nginx-1.26.1/objs/nginx
/usr/local/nginx/sbin
#检测一下有没有问题
[root@Nginx sbin]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@Nginx sbin]# kill -USR2 48732 #nginx worker ID
#USR2 平滑升级可执行程序,将存储有旧版本主进程PID的文件重命名为nginx.pid.oldbin,并启动新的
nginx
#此时两个master的进程都在运行,只是旧的master不在监听,由新的master监听80
#此时Nginx开启一个新的master进程,这个master进程会生成新的worker进程,这就是升级后的Nginx进
程,此时老的进程不会自动退出,但是当接收到新的请求不作处理而是交给新的进程处理。
[root@Nginx sbin]# ps aux | grep nginx
root 48732 0.0 0.1 9868 2436 ? Ss 14:17 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
nobody 48733 0.0 0.2 14200 4868 ? S 14:17 0:00 nginx: worker
process
root 52075 0.0 0.3 9876 6528 ? S 15:41 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
nobody 52076 0.0 0.2 14208 4868 ? S 15:41 0:00 nginx: worker
process
[root@Nginx sbin]# curl -I localhost
HTTP/1.1 200 OK
Server: nginx/1.24.0 ##依旧是旧版本生生效
Date: Thu, 18 Jul 2024 07:45:58 GMT
Content-Type: text/html
Content-Length: 615
Last-Modified: Thu, 18 Jul 2024 03:41:13 GMT
Connection: keep-alive
ETag: "66988ed9-267"
Accept-Ranges: bytes
#回收旧版本
[root@Nginx sbin]# kill -WINCH 48732
[root@Nginx sbin]# ps aux | grep nginx
root 48732 0.0 0.1 9868 2436 ? Ss 14:17 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
root 52075 0.0 0.3 9876 6528 ? S 15:41 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
nobody 52076 0.0 0.2 14208 4868 ? S 15:41 0:00 nginx: worker
process
#检测版本信息
[root@Nginx sbin]# curl -I localhost
HTTP/1.1 200 OK
Server: nginx/1.26.1 #新版本生效
Date: Thu, 18 Jul 2024 07:59:45 GMT
Content-Type: text/html
Content-Length: 615
Last-Modified: Thu, 18 Jul 2024 03:41:13 GMT
Connection: keep-alive
ETag: "66988ed9-267"
Accept-Ranges: bytes
#回滚
#如果升级的版本发现问题需要回滚,可以重新拉起旧版本的worker
[root@Nginx sbin]# cp nginx nginx.26
[root@Nginx sbin]# ls
nginx nginx.24 nginx.26
[root@Nginx sbin]# mv nginx.24 nginx
mv: overwrite 'nginx'? y
[root@Nginx sbin]# kill -HUP 48732
[root@Nginx sbin]# ps aux | grep nginx
root 48732 0.0 0.1 9868 2436 ? Ss 14:17 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
root 52075 0.0 0.3 9876 6528 ? S 15:41 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
nobody 52076 0.0 0.2 14208 5124 ? S 15:41 0:00 nginx: worker
process
nobody 52130 0.0 0.2 14200 4868 ? S 16:30 0:00 nginx: worker
process
[root@Nginx sbin]# kill -WINCH 52075
[root@Nginx sbin]# ps aux | grep nginx
root 48732 0.0 0.1 9868 2436 ? Ss 14:17 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
root 52075 0.0 0.3 9876 6528 ? S 15:41 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
nobody 52130 0.0 0.2 14200 4868 ? S 16:30 0:00 nginx: worker
process
root 52137 0.0 0.1 221664 2176 pts/0 S+ 16:31 0:00 grep --
color=auto nginx
[root@Nginx sbin]# curl -I localhost
HTTP/1.1 200 OK
Server: nginx/1.24.0 ##版本回滚完成
Date: Thu, 18 Jul 2024 08:31:51 GMT
Content-Type: text/html
Content-Length: 615
Last-Modified: Thu, 18 Jul 2024 03:41:13 GMT
Connection: keep-alive
ETag: "66988ed9-267"
Accept-Ranges: bytes
查看当前使用的nginx版本
data:image/s3,"s3://crabby-images/fc0ca/fc0cabe7642105daccf55d0a3fb309aec7487348" alt=""
把echo...这个软件包放到/root下并且解压
data:image/s3,"s3://crabby-images/03499/034998ed5bdbdca0ad19895cc21b27c4e78caa8c" alt=""
检测环境
data:image/s3,"s3://crabby-images/03af0/03af0917f8f4e8a041d48ace92099bf8f2f393c5" alt=""
检查完环境后只做make
data:image/s3,"s3://crabby-images/1076f/1076f1b2d44b6a7587172a39dbd44d61ec44b1b4" alt=""
#查看两个版本
[root@Nginx nginx-1.26.1]# ll objs/nginx /usr/local/nginx/sbin/nginx
-rwxr-xr-x 1 root root 1239416 Jul 18 15:08 objs/nginx
-rwxr-xr-x 1 root root 5671488 Jul 18 11:41 /usr/local/nginx/sbin/nginx
data:image/s3,"s3://crabby-images/762da/762da2ba80629c1a5e9816c495fa582242f6e1c6" alt=""
#把之前的旧版的nginx命令备份
data:image/s3,"s3://crabby-images/c01c7/c01c77bd64700a7f842afb99a166a5f3c4d9486f" alt=""
#把新版本的nginx命令复制过去
data:image/s3,"s3://crabby-images/0dd26/0dd268f90fc397964b66d0d031d1a4a2b36e670f" alt=""
data:image/s3,"s3://crabby-images/7c93b/7c93be9a0caac91fe12dda5540f6d1eb0a22d1c2" alt=""
#USR2 平滑升级可执行程序,将存储有旧版本主进程PID的文件重命名为nginx.pid.oldbin,并启动新的
nginx
#此时两个master的进程都在运行,只是旧的master不在监听,由新的master监听80
#此时Nginx开启一个新的master进程,这个master进程会生成新的worker进程,这就是升级后的Nginx进
程,此时老的进程不会自动退出,但是当接收到新的请求不作处理而是交给新的进程处理。
这个时候查看版本还是24
data:image/s3,"s3://crabby-images/9f7a9/9f7a92a8bc42fa476869a459c0bdb65ba9f34f85" alt=""
回收旧版本
data:image/s3,"s3://crabby-images/9d149/9d1495fb1d46ac1885b37b915ecfeb4cf3226427" alt=""
检测版本信息变成26了
data:image/s3,"s3://crabby-images/32695/32695473fbc5760ba4e1493e84d68792e4f80370" alt=""
回滚
如果升级的版本发现问题需要回滚,可以重新拉起旧版本的worker
[root@Nginx sbin]# cp nginx nginx.26
[root@Nginx sbin]# ls
nginx nginx.24 nginx.26
[root@Nginx sbin]# mv nginx.24 nginx
mv: overwrite 'nginx'? y
[root@Nginx sbin]# kill -HUP 48732
[root@Nginx sbin]# ps aux | grep nginx
root 48732 0.0 0.1 9868 2436 ? Ss 14:17 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
root 52075 0.0 0.3 9876 6528 ? S 15:41 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
nobody 52076 0.0 0.2 14208 5124 ? S 15:41 0:00 nginx: worker
process
nobody 52130 0.0 0.2 14200 4868 ? S 16:30 0:00 nginx: worker
process
[root@Nginx sbin]# kill -WINCH 52075
[root@Nginx sbin]# ps aux | grep nginx
root 48732 0.0 0.1 9868 2436 ? Ss 14:17 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
root 52075 0.0 0.3 9876 6528 ? S 15:41 0:00 nginx: master
process /usr/local/nginx/sbin/nginx
nobody 52130 0.0 0.2 14200 4868 ? S 16:30 0:00 nginx: worker
process
root 52137 0.0 0.1 221664 2176 pts/0 S+ 16:31 0:00 grep --
color=auto nginx
[root@Nginx sbin]# curl -I localhost
HTTP/1.1 200 OK
Server: nginx/1.24.0 ##版本回滚完成
Date: Thu, 18 Jul 2024 08:31:51 GMT
Content-Type: text/html
Content-Length: 615
Last-Modified: Thu, 18 Jul 2024 03:41:13 GMT
Connection: keep-alive
ETag: "66988ed9-267"
Accept-Ranges: bytes
激活老版本
data:image/s3,"s3://crabby-images/66bbc/66bbc71f9feab677b8f5c3b64453294726c6b6f0" alt=""
回收新的
data:image/s3,"s3://crabby-images/b404c/b404cd829d70284bbf26992040784fb4a1636e9c" alt=""
data:image/s3,"s3://crabby-images/d07dc/d07dc475430dc8fb2dddbf3fe7f58177e2ed0987" alt=""
出现24就是回滚成功了
Nginx 核心配置详解
Nginx的配置文件的组成部分:
-
主配置文件:nginx.conf
-
子配置文件: include conf.d/*.conf
-
fastcgi, uwsgi,scgi 等协议相关的配置文件
-
mime.types:支持的mime类型,MIME(Multipurpose Internet Mail Extensions)多用途互联网邮
-
件扩展类型,MIME消息能包含文本、图像、音频、视频以及其他应用程序专用的数据,是设定某
-
种扩展名的文件用一种应用程序来打开的方式类型,当该扩展名文件被访问的时候,浏览器会自动
-
使用指定应用程序来打开。多用于指定一些客户端自定义的文件名,以及一些媒体文件打开方式。
#全局配置端,对全局生效,主要设置nginx的启动用户/组,启动的工作进程数量,工作模式,Nginx的PID路
径,日志路径等。
user nginx nginx;
worker_processes 1; #启动工作进程数数量
events { #events #设置快,主要影响nginx服务器与用户的网络连接,比如是否允许同时接受多
个网络连接,使用哪种事件驱动模型 #处理请求,每个工作进程可以同时支持的
最大连接数,是否开启对多工作进程下的网络连接进行序列化等。
worker_connections 1024; #设置单个nginx工作进程可以接受的最大并发,作为web服务器
的时候最大并发数为 #worker_connections *
worker_processes,作为反向代理的时候为
#(worker_connections * worker_processes)/2
}
http { #http块是Nginx服务器配置中的重要部分,缓存、代理和日志格
式定义等绝大多数功能和第三方模块都 #可以在这设置,http块可
以包含多个server块,而一个server块中又可以包含多个location块,
#server块可以配置文件引入、MIME-Type定义、日志自定义、是
否启用sendfile、连接超时时间和 #单个链接的请求上限等。
include mime.types;
default_type application/octet-stream;
sendfile on; #作为web服务器的时候打开sendfile加快静态文件传输,指定是
否使用
#sendfile系统调用来传输文件
#sendfile系统调用在两个文件描述符之间直接传递数据(完全在
内核中操作)
#从而避免了数据在内核缓冲区和用户缓冲区之间的拷贝,操作效率
很高,被称之为零拷贝,
#硬盘 >> kernel buffer (快速拷贝到kernelsocket
buffer) >>协议栈。keepalive_timeout 65; #长连接超时时间,单位是秒 server { #设置一个虚拟机主机,可以包含自己的全局快,同时也可以包含多
个location模块
#比如本虚拟机监听的端口、本虚拟机的名称和IP配置,多个
server 可以使用一个端口比如都使用 #80端口提供web服务listen 80; #配置server监听的端口
server_name localhost; #本server的名称,当访问此名称的时候nginx会调用当前serevr
内部的配置进程匹配。location / { #location其实是server的一个指令,为nginx服务器提供比较
多而且灵活的指令
#都是在location中体现的,主要是基于nginx接受到的请求字符
串
#对用户请求的UIL进行匹配,并对特定的指令进行处理
#包括地址重定向、数据缓存和应答控制等功能都是在这部分实现
#另外很多第三方模块的配置也是在location模块中配置。root html; #相当于默认页面的目录名称,默认是安装目录的相对路径,可以使
用绝对路径配置。
index index.html index.htm; #默认的页面文件名称
}
error_page 500 502 503 504 /50x.html; #错误页面的文件名称
location = /50x.html { #location处理对应的不同错误码的页面定
义到/50x.html
#这个跟对应其server中定义的目录下。
root html; #定义默认页面所在的目录
}
}#和邮件相关的配置
#mail {...
} mail 协议相关配置段
#tcp代理配置,1.9版本以上支持
#stream {...
} stream 服务器相关配置段
#导入其他路径的配置文件
#include /apps/nginx/conf.d/*.conf
}
实现 nginx 的高并发配置
data:image/s3,"s3://crabby-images/5b520/5b520f765c331d14c1654ec56f08f40c5d44eefe" alt=""
data:image/s3,"s3://crabby-images/1389b/1389bf46e7915971a6c07cece87447fd9495db6f" alt=""
data:image/s3,"s3://crabby-images/04101/04101e7d54237edcd543dd76f185ed369aad43a2" alt=""
data:image/s3,"s3://crabby-images/cfd1e/cfd1e749dfad3043740f9ce2e71e70414c323786" alt=""
内置变量
没有echo模块是编译的时候没有这个模块
data:image/s3,"s3://crabby-images/9d534/9d5347d326f4a0a53331dfb73685941e7994c5e1" alt=""
要切换到26版本
在windows上编写本地解析
data:image/s3,"s3://crabby-images/02a02/02a02916b6f42cc4756db64c3ff4d40409813955" alt=""
data:image/s3,"s3://crabby-images/2beb7/2beb741b41539dde69073e86ad465820bcb07fa6" alt=""
重载服务
nginx -reload
测试
data:image/s3,"s3://crabby-images/50f35/50f35359789932f1eaef10fe846ed1d112f6f990" alt=""
$remote_port; #客户端请求Nginx服务器时随机打开的端口,这是每个客户端自己的端口
data:image/s3,"s3://crabby-images/0e2be/0e2bec5656ba3ae3e3d6b509e637435a59b25352" alt=""
nginx -s reload
data:image/s3,"s3://crabby-images/9afa4/9afa4bef0acf76648c572fc0cb1100aec0fffe68" alt=""
$args; #变量中存放了URL中的所有参数 #例如:https://search.jd.com/Search?keyword=手机\&enc=utf-8 #返回结果为: keyword=手机&enc=utf-8
data:image/s3,"s3://crabby-images/368cc/368cc6cb3b623386c64a77b206e3f9c2217b7d97" alt=""
不加参数第二个变量为空
data:image/s3,"s3://crabby-images/b5498/b5498e57936164af77c236ef1ae54ce4f715bd57" alt=""
加参数
data:image/s3,"s3://crabby-images/e691a/e691af6cc5a7b3bbac80e2a23c4d2998118a038e" alt=""
$is_args #如果有参数为? 否则为空
data:image/s3,"s3://crabby-images/2345e/2345e8bf72646f89b657a62b9b9659c0c12101f2" alt=""
有参数
data:image/s3,"s3://crabby-images/0a7ae/0a7ae37620b97d1ef7339d578063f07f03a6d8f8" alt=""
没有参数,第二个第三个都为空
data:image/s3,"s3://crabby-images/edd93/edd93e6fa93830a488e5ce90e0c3f4e96fa00fd8" alt=""
$document_root;
#保存了针对当前资源的请求的系统根目录,例如:/webdata/nginx/timinglee.org/lee
data:image/s3,"s3://crabby-images/2be4a/2be4a70d6901b6e3d26630c7e77d9e0f1ae84a40" alt=""
data:image/s3,"s3://crabby-images/68b41/68b415717e60899f856177cb6b5f488f0780418b" alt=""
$document_uri;
#保存了当前请求中不包含参数的URI,注意是不包含请求的指令
#比如:http://lee.timinglee.org/var?\\id=11111会被定义为/var
#返回结果为:/var
data:image/s3,"s3://crabby-images/34488/3448893fe6554803c4c078017d1cf29958bb9f5a" alt=""
data:image/s3,"s3://crabby-images/7bb4b/7bb4bbf21034a6b14f15a4de6de59f4430d16ec0" alt=""
$host; #存放了请求的host名称
data:image/s3,"s3://crabby-images/a2fc5/a2fc5a30e763c3e480ba4b5a24da4493e3303d8e" alt=""
data:image/s3,"s3://crabby-images/30b6f/30b6f603c7da5713df84a73cb8bcb0241ba63bf6" alt=""
$remote_port;
#客户端请求Nginx服务器时随机打开的端口,这是每个客户端自己的端口
data:image/s3,"s3://crabby-images/4293c/4293ce60e46bec160718c12f21a44f2d23b64223" alt=""
data:image/s3,"s3://crabby-images/644c2/644c209a230938012120aa837b3462a9b1f84d99" alt=""
$remote_user;
#已经经过Auth Basic Module验证的用户名
data:image/s3,"s3://crabby-images/1c8ee/1c8ee8db096cd17594bd45b080e973c931982abc" alt=""
data:image/s3,"s3://crabby-images/08a42/08a4226776beb77b4aa6cd6888662f04f54f4b17" alt=""
data:image/s3,"s3://crabby-images/749a3/749a3c58f161207c6a1c960628b1db54e22e14d6" alt=""
$request_method;示例: #请求资源的方式,GET/PUT/DELETE等
data:image/s3,"s3://crabby-images/4f8dd/4f8dd4560710bae1ff9f319f52c13a3a3fe0b835" alt=""
data:image/s3,"s3://crabby-images/72e3d/72e3d9f49600ea7cf1dbc5ea7c19ab754ccdca3e" alt=""
$request_filename
; #当前请求的资源文件的磁盘路径,由root或alias指令与URI请求生成的文件绝对路径,
#如:webdata/nginx/timinglee.org/lee/var/index.html
data:image/s3,"s3://crabby-images/9bcff/9bcffbe51e916b69aea67207c4be02c878199a63" alt=""
data:image/s3,"s3://crabby-images/bad05/bad059a40a83c4ad9e61383459747df9da72e1b2" alt=""
request*uri; #包含请求参数的原始URI,不包含主机名,相当于:document*uri?$args, #例如:/main/index.do?id=20190221&partner=search
data:image/s3,"s3://crabby-images/aad27/aad2789d74fccb859b2b7d42c6fde395b9999a3f" alt=""
data:image/s3,"s3://crabby-images/c8411/c8411e1f091907c0896b59aa17ded01ddd71a35b" alt=""
$scheme; #请求的协议,例如:http,https,ftp等
data:image/s3,"s3://crabby-images/274b4/274b4fc51d8c7954b2196f114fe8bf48260afee1" alt=""
data:image/s3,"s3://crabby-images/85114/85114f9f90735c7a5200f5fa9d4132c0d7f4bff7" alt=""
$server_protocol;
#保存了客户端请求资源使用的协议的版本,例如:HTTP/1.0,HTTP/1.1,HTTP/2.0等
data:image/s3,"s3://crabby-images/41aac/41aac42852d77d14da1bb16487a42214cbe18fc6" alt=""
data:image/s3,"s3://crabby-images/42566/42566ac02829108a2304022c77f92c9d9e016a0c" alt=""
data:image/s3,"s3://crabby-images/34cf1/34cf1f74fd90da00f56d31680e69b4b070c096fe" alt=""
data:image/s3,"s3://crabby-images/5c115/5c1159c7b7506d33ab27cf98c071797c145e7c7a" alt=""
$server_name; #虚拟主机的主机名
data:image/s3,"s3://crabby-images/e8270/e82704d6d1efda626222ca972cfc851177577ba4" alt=""
data:image/s3,"s3://crabby-images/b0f40/b0f4037bf72bee489437dcfb7a21d066ea9d4aea" alt=""
$server_port; #虚拟主机的端口号
data:image/s3,"s3://crabby-images/78581/78581f622707750678daa79fbbf8e4c6ea789eb3" alt=""
data:image/s3,"s3://crabby-images/83344/83344eafb031310860481d6ff0e985334a7a0e2d" alt=""
$httpuseragent; #客户端浏览器的详细信息
data:image/s3,"s3://crabby-images/c878d/c878d574f019458aed8081ea8c916e9040e7b3e0" alt=""
data:image/s3,"s3://crabby-images/e099d/e099de75d8e22670e408f67d2922d98a9a7463a4" alt=""
$http_cookie; #客户端的所有cookie信息
data:image/s3,"s3://crabby-images/627bb/627bb667b5b0095b779fdb901912e193f1c48694" alt=""
data:image/s3,"s3://crabby-images/17a14/17a140bde877ac178f5be780e8c8ecaaca983e86" alt=""
$cookie_ #name为任意请求报文首部字部cookie的key名
data:image/s3,"s3://crabby-images/ecf55/ecf5522cdbdb80070789f041e33fb186bfd882d4" alt=""
data:image/s3,"s3://crabby-images/6cf36/6cf3696ede0f294ac9454706d7fe81bf1b6a109d" alt=""
自定义变量
不能和内置变量写在一起
要另外写一个server
data:image/s3,"s3://crabby-images/ad8a4/ad8a4fc33277dc261d6fb9f4372c275715d1950f" alt=""
data:image/s3,"s3://crabby-images/ae65d/ae65d86b207958a1c6154fb4b9d894122a509fc5" alt=""
Nginx Rewrite 相关功能
Nginx服务器利用 ngx_http_rewrite_module 模块解析和处理rewrite请求
此功能依靠 PCRE(perl compatible regular expression),因此编译之前要安装PCRE库
rewrite是nginx服务器的重要功能之一,用于实现URL的重写,URL的重写是非常有用的功能
比如它可以在我们改变网站结构之后,不需要客户端修改原来的书签,也无需其他网站修改我们的
链接,就可以设置为访问
另外还可以在一定程度上提高网站的安全性
使用正则表达式对变量进行匹配,匹配成功时if指令认为条件为true,否则认为false,变量与表达式之间 使用以下符号链接:
= #比较变量和字符串是否相等,相等时if指令认为该条件为true,反之为false
!= #比较变量和字符串是否不相等,不相等时if指令认为条件为true,反之为false
~ #区分大小写字符,可以通过正则表达式匹配,满足匹配条件为真,不满足匹配条件为假
!~ #区分大小写字符,判断是否匹配,不满足匹配条件为真,满足匹配条件为假
~* #不区分大小写字符,可以通过正则表达式匹配,满足匹配条件为真,不满足匹配条件为假
!~* #不区分大小字符,判断是否匹配,满足匹配条件为假,不满足匹配条件为真
-f 和 !-f #判断请求的文件是否存在和是否不存在
-d 和 !-d #判断请求的目录是否存在和是否不存在
-x 和 !-x #判断文件是否可执行和是否不可执行
-e 和 !-e #判断请求的文件或目录是否存在和是否不存在(包括文件,目录,软链接)
#注意:
#如果$变量的值为空字符串或0,则if指令认为该条件为false,其他条件为true。
#nginx 1.0.1之前$变量的值如果以0开头的任意字符串会返回false
if判定
data:image/s3,"s3://crabby-images/1f3cc/1f3ccca1bbd24c462097ad0422215d4e14c860ad" alt=""
/test2不存在
data:image/s3,"s3://crabby-images/41bc4/41bc4a60597d95fb0af9a22faa812b877865d1e5" alt=""
注释掉409
data:image/s3,"s3://crabby-images/60021/600213b7291a871a6cea7372aea819562ca34553" alt=""
data:image/s3,"s3://crabby-images/54477/544778d2229f6e5db56b9e872d54ba207846de01" alt=""
创建目录和文件
data:image/s3,"s3://crabby-images/de157/de157d484b3d28538238217da9c7c9415d01bd59" alt=""
data:image/s3,"s3://crabby-images/2a61c/2a61ca8b09e2fb2d51d06573843c86fac13b9089" alt=""
data:image/s3,"s3://crabby-images/e780f/e780fd18ecf2701ec4aa6635d0cf55e4ebad925a" alt=""
set指令
data:image/s3,"s3://crabby-images/d204d/d204d99245fe2f463e25370c133d86777f411723" alt=""
data:image/s3,"s3://crabby-images/e2b2d/e2b2d5c43048b41e0b240e223a5b6913495781b8" alt=""
data:image/s3,"s3://crabby-images/98974/989747ef19f33ce06abf71363414449a13dff984" alt=""
测试结果
不指定浏览器
data:image/s3,"s3://crabby-images/08131/08131965bd2394d8d338ec82ac8246c9e441670d" alt=""
指定浏览器
data:image/s3,"s3://crabby-images/e4fca/e4fca1a2afe0e33bcf3688f25eed0a95aa246e74" alt=""
return
data:image/s3,"s3://crabby-images/c5fc4/c5fc49d4dc8c34be6b7c9973aad3af103eccbcff" alt=""
重载服务
不存在时
data:image/s3,"s3://crabby-images/d8b71/d8b71326c06112651fcb4bb01043762e1a468bd0" alt=""
存在时
data:image/s3,"s3://crabby-images/97271/97271dbceb6cbc81625dd205eb76b11442737424" alt=""
rewriter
301就是永久,302是临时
用curl -I测试
data:image/s3,"s3://crabby-images/ab4d3/ab4d380825c43d5b914012af32df2992f6d3ae9c" alt=""
注释掉rewriter
重载服务
#重启Nginx并访问域名 http://www.timinglee.org 进行测试
永久重定向
data:image/s3,"s3://crabby-images/144e7/144e773e912d9387fc3113382901d108fccd040b" alt=""
重定向成功了,但是curl无法进行重定向功能
data:image/s3,"s3://crabby-images/16d2b/16d2b940359fd7b89d302023c04aa8d0dbecc33d" alt=""
所以需要修改windws的本地解析加一条var.timinglee.org
data:image/s3,"s3://crabby-images/8ddec/8ddecea0e23ac43fa34e5fa0abe7beb57e3e54f4" alt=""
data:image/s3,"s3://crabby-images/69677/6967736f6fa371bfb363e89948b2eaef7824188e" alt=""
临时重定向
data:image/s3,"s3://crabby-images/ff54c/ff54cfd798f5bea4baec4fbf4662d76ba61fb431" alt=""
data:image/s3,"s3://crabby-images/d3048/d3048af9fb91dc767d78b70cb88331e82f0c0839" alt=""
break和last
data:image/s3,"s3://crabby-images/b5c69/b5c699ea227e9da901177bd5dab54ecaf244ef3a" alt=""
data:image/s3,"s3://crabby-images/f3a67/f3a677743f753910e4d3b1ac6912e0f539ee03be" alt=""
data:image/s3,"s3://crabby-images/6c329/6c329908fb66810ae9b39ea36b133079d54ea1d2" alt=""
data:image/s3,"s3://crabby-images/8a1f0/8a1f09483de6ea258fcf48f4102d8f9eb9c2d530" alt=""
data:image/s3,"s3://crabby-images/260f4/260f445b421a3143afbbded33743b6a489c5bb0c" alt=""
data:image/s3,"s3://crabby-images/b3d5f/b3d5fc4c638da15835180e620a60a86a948b366c" alt=""
data:image/s3,"s3://crabby-images/67b61/67b61f9a6262e210fdd9095e918c8a953566561d" alt=""
而last会跳出当前的location,执行后续的location
自动跳转https
设置密钥
data:image/s3,"s3://crabby-images/25528/25528f3e682ebde5c35148f7245b02e7049ba972" alt=""
data:image/s3,"s3://crabby-images/46b1d/46b1d1d123fc8643774363417afe962a44be8c03" alt=""
重载服务
测试 或者去浏览器查看证书
data:image/s3,"s3://crabby-images/ccc95/ccc953685ef90cbabdf0c8079d3e1fd9710193f9" alt=""
data:image/s3,"s3://crabby-images/e17a5/e17a5fb12bf802ac50d3e76edd8ec8d96a8602f7" alt=""
rewrite 案例: 判断文件是否存在
data:image/s3,"s3://crabby-images/ded70/ded70735a42a36707bcd0be0127f3606ff95d2ce" alt=""
随便输入一个不存在路径会自动导航到www.timinglee.org首页
data:image/s3,"s3://crabby-images/b59a5/b59a5bd5544dc79907abecd15759197d711cf957" alt=""
Nginx 防盗链
实现盗链
要另外开一台虚拟机
Nginx上创建images目录
data:image/s3,"s3://crabby-images/c3481/c34810154c674cb282e8f43fec45e80c275cb4d0" alt=""
data:image/s3,"s3://crabby-images/a12eb/a12eb947507f5cd667543b4028afe1bbdc764b17" alt=""
准备盗链web页面:
data:image/s3,"s3://crabby-images/6a28a/6a28a43473c95d077cea723b2623e0903e006a6f" alt=""
编写本地解析
data:image/s3,"s3://crabby-images/da496/da496cac7f64332be26203fb538a9daad28491e0" alt=""
在网页访问172.25.250.10然后查看日志
data:image/s3,"s3://crabby-images/a7264/a726481129da9dff4e53ebf2cf0fb99ea7b66554" alt=""
data:image/s3,"s3://crabby-images/db8c5/db8c57a2f6bd277a6a9326cbc31c2c4eb8349790" alt=""
实现防盗链
在100放入另一张图片到默认发布目录
data:image/s3,"s3://crabby-images/f8b23/f8b23193682eb8ff2bfa3e361eb7fdc1dd11cf99" alt=""
data:image/s3,"s3://crabby-images/2c24d/2c24d34b5a8959f4ef514c02f3f2393a1c6e76ff" alt=""
一张放默认发布目录,daolian一张放images目录
Nginx反向代理
实战案例: 反向代理单台 web 服务器
开一台10,一台20
data:image/s3,"s3://crabby-images/87fad/87fad0934965282fa70ff7c1a7a927eac390232a" alt=""
data:image/s3,"s3://crabby-images/65434/654341ed780bc9f62c75561c9adc1a3c1eea0bed" alt=""
data:image/s3,"s3://crabby-images/a7f36/a7f36cbb559a36ca152cbbe72b80b72c80dbc7c1" alt=""
只能写一个proxy
data:image/s3,"s3://crabby-images/03841/0384171c6c5d853f9ab98e3022da9b9d00115d11" alt=""
实战案例 : 指定 location 实现反向代理
data:image/s3,"s3://crabby-images/f9ab3/f9ab30b4f5a88ac4441a68ac0b9466676eb2d582" alt=""
重载服务
data:image/s3,"s3://crabby-images/2e473/2e4738b0314a768af2b571568f1d73f5cb1ef072" alt=""
改端口
data:image/s3,"s3://crabby-images/5ec5c/5ec5ce779fc1c50291deb6236971a8d1841daef0" alt=""
data:image/s3,"s3://crabby-images/d8d4d/d8d4d5247167ff6ba0d3b9b3e63c41f4089f0372" alt=""
data:image/s3,"s3://crabby-images/2f92f/2f92ff8927d4baaf25a461c08e14a3f0168be526" alt=""
动静分离
10上
data:image/s3,"s3://crabby-images/b7910/b7910f2f7b3987c898ae1d39e9407e62c3facdf4" alt=""
下载php
重启httpd
编辑php网页
data:image/s3,"s3://crabby-images/43285/432856b911618b0f2c46647f82f6760a6e2baaf4" alt=""
nginx上
data:image/s3,"s3://crabby-images/ed0ec/ed0ecbf360ca6e7de88cc764168f5c101ee555e1" alt=""
data:image/s3,"s3://crabby-images/822a3/822a35b24d766e69d2b2afbe021f53f5dc41acd6" alt=""
data:image/s3,"s3://crabby-images/f06ae/f06ae674c6f55ee41f9d2c4577ef07390453c96b" alt=""
反向代理示例: 缓存功能
缓存功能默认关闭状态,需要先动配置才能启用
proxy_cache zone_name | off; 默认off #指明调用的缓存,或关闭缓存机制;Context:http, server, location #zone_name 表示缓存的名称.需要由proxy_cache_path事先定义
proxy_cache_key string; #缓存中用于"键"的内容,默认值:proxy_cache_key schemeproxy_host$request_uri
proxy_cache_valid [code ...] time; #定义对特定响应码的响应内容的缓存时长,定义在http{...}中 示例: proxy_cache_valid 200 302 10m; proxy_cache_valid 404 1m;
data:image/s3,"s3://crabby-images/f0b6d/f0b6db429b16ef4985c15df1d265ec2778d27a27" alt=""
vhost
data:image/s3,"s3://crabby-images/776cc/776cc8d637dfec1566b165bf9a1f5de10496cd96" alt=""
重载服务
压测
data:image/s3,"s3://crabby-images/3896e/3896e9788493d145a5fd6a29d9fbcc2e7dfc24b7" alt=""
#验证缓存目录结构及文件大小
data:image/s3,"s3://crabby-images/1325d/1325d20c4098cdda52ed0ec9f9d5518fab5c493f" alt=""
http 反向代理负载均衡
后端多台 web服务器
data:image/s3,"s3://crabby-images/6ccf1/6ccf1ef77eca103a3897a23023a341ce0542ab9a" alt=""
data:image/s3,"s3://crabby-images/b05c9/b05c984978f5f7573ed8fb545a10852e253190f4" alt=""
要把之前配置的缓存服务配置也删掉
data:image/s3,"s3://crabby-images/907f3/907f3a506eff7f170efe294104d5e112265dda1f" alt=""
data:image/s3,"s3://crabby-images/e6515/e6515cc3de1126000eb40354aeaa5b1cc2dfc29e" alt=""
默认轮询
data:image/s3,"s3://crabby-images/8f42f/8f42f248a048a4b2930e4d53e5577691398655e7" alt=""
改变算法
同一个ip来的请求都转到同一个server上
data:image/s3,"s3://crabby-images/5e9b6/5e9b69602d7c22c198047161dcd6f7697f68a1e4" alt=""
data:image/s3,"s3://crabby-images/90cfd/90cfd4ece9bed004682bd87e9bc9499a9aab54bd" alt=""
uri的hash
data:image/s3,"s3://crabby-images/12efe/12efe509d1b691d4185e1288429cf0f3d28a1f71" alt=""
data:image/s3,"s3://crabby-images/827a4/827a4bc557e2a4f99a10b477b38de8a6cad14632" alt=""
data:image/s3,"s3://crabby-images/8fa0a/8fa0abb9b7d9b3d170dd553e3abfc2a6bde0706b" alt=""
cookie的hash
data:image/s3,"s3://crabby-images/7fe02/7fe02189ef6029f8fd04e9a0aad816c5ce5c96bc" alt=""
没有cookie时
轮询
data:image/s3,"s3://crabby-images/5c7dc/5c7dca2b12da895e716ffd8731e7c6df3b45d648" alt=""
有cookie
data:image/s3,"s3://crabby-images/e41c6/e41c613295649c64b49e6f0cae604f58e1a55aba" alt=""
Fastcgi
删掉原本的nginx
data:image/s3,"s3://crabby-images/52619/5261910643ea78d9736d77f349e279922cf42db1" alt=""
data:image/s3,"s3://crabby-images/07c20/07c2023c53cece19d406433f9c5edeb25b8ea33d" alt=""
data:image/s3,"s3://crabby-images/1319c/1319ce4fc489633e1cb4e110847af73202bdbf89" alt=""
解压这几个东西
tar -zvf
data:image/s3,"s3://crabby-images/a4ad1/a4ad12d290f8490e682bee191c4c1d981ac050ae" alt=""
下载依赖
yum install -y bzip2 systemd-devel libxml2-devel sqlite-devel
libpng-devel libcurl-devel oniguruma-devel
data:image/s3,"s3://crabby-images/a3a50/a3a503624a0f02e601c8d7789800b3b0deaf2d9a" alt=""
编译
data:image/s3,"s3://crabby-images/d4e91/d4e9187845aca409331eb24c77cb6cdc6628df8e" alt=""
make && make install
cgi就是把webserver的php请求转给能够处理这个php请求的应用
data:image/s3,"s3://crabby-images/c4e40/c4e4069c8586ce5a0d6271a81b177c8c5772a69c" alt=""
启动nginx
查看参数
data:image/s3,"s3://crabby-images/9d7a6/9d7a69e96917e321e6924764c9d036604b8a8d65" alt=""
编译php
进入php目录
data:image/s3,"s3://crabby-images/3f812/3f81207b60c4acf51ef3215c24f225ef0dfb6027" alt=""
依赖可能会报错
需要安装
data:image/s3,"s3://crabby-images/4377e/4377e6e7a1c95e30957a6d4779d9eee1ef6e400f" alt=""
出错的时候找到出错的依赖
data:image/s3,"s3://crabby-images/ef5ee/ef5ee608362cc9f49c11ac836fc0b1f0083bda2c" alt=""
wge下载
https://mirrors.aliyun.com/rockylinux/9.4/devel/x8664/kickstart/Packages/o/oniguruma-devel-6.9.6-1.el9.5.x8664.rpm
安装ongru
dnf install oniguruma-devel-6.9.6-1.el9.5.x86_64.rpm
make && make install
data:image/s3,"s3://crabby-images/c56f1/c56f1157a3ba5b0b18bdd2da3c5a4f4728c81de7" alt=""
data:image/s3,"s3://crabby-images/e7a49/e7a49c730b009ca61e8758b7973395bef8ad603f" alt=""
data:image/s3,"s3://crabby-images/d8874/d88747f4e03853a6fe1c9ccba392eb300c51cdc9" alt=""
data:image/s3,"s3://crabby-images/9f122/9f1220e27acc2ea574bcfedd28299d45b118b95d" alt=""
data:image/s3,"s3://crabby-images/c97cc/c97cc333c1c35676f461516e71f63f1c87579c44" alt=""
data:image/s3,"s3://crabby-images/a2863/a2863f9e1a32cd828141fbafc09341ef1649cadc" alt=""
data:image/s3,"s3://crabby-images/dec7c/dec7c1be5e47338170009d9ba9056155becd459b" alt=""
修改时区
data:image/s3,"s3://crabby-images/cd611/cd611faa40eb2dc1a92f36af81191344e167be06" alt=""
cd sapi/
data:image/s3,"s3://crabby-images/ed5c4/ed5c4aa6652d55e327f3b11bc4e9c4430e82b0d9" alt=""
注释掉
data:image/s3,"s3://crabby-images/d0974/d09744fea0aaeb4524e553ef28b94584a10dd921" alt=""
data:image/s3,"s3://crabby-images/ca575/ca575a9b137eccaa6e856dc5790d602fb9077bb2" alt=""
data:image/s3,"s3://crabby-images/608f3/608f3677f762b4ab39e321c81261e306ed171fe4" alt=""
data:image/s3,"s3://crabby-images/1f0c9/1f0c9c8c9ea0c03ea0c30f4e61dddac64fe6b054" alt=""
php -m
data:image/s3,"s3://crabby-images/6877a/6877aedf3035ac0d46eccadcdec8bf51729b92f1" alt=""
data:image/s3,"s3://crabby-images/7c7ee/7c7eea3dda6811fabeb409c048f8c24c4f134edf" alt=""
data:image/s3,"s3://crabby-images/cee1b/cee1bebaeb888a3d4d3681169621582c7ea68801" alt=""
data:image/s3,"s3://crabby-images/9d28e/9d28e4df1bba0a43eba3a6189b91d1572b2b3ba2" alt=""
data:image/s3,"s3://crabby-images/72341/7234159d17dcb3c4842290bfdceefd955b342133" alt=""
vim /usr/local/nginx/conf.d/php.conf
data:image/s3,"s3://crabby-images/4d607/4d60700785ee8f47b03a9bca3575d14da17bee6a" alt=""
data:image/s3,"s3://crabby-images/c23ad/c23adea25d2e4cbf92171a35f4612931e2cc2093" alt=""
去网页访问看能否出结果
data:image/s3,"s3://crabby-images/9d4b8/9d4b8f82e87e5effb738b7470d7808d410d7b65c" alt=""
php的动态扩展模块(php的缓存模块)
把memcache放进去
data:image/s3,"s3://crabby-images/6d884/6d884c4923c5bef39690512cd4fa4f08e1e45132" alt=""
进入目录
data:image/s3,"s3://crabby-images/93987/939870edf0cd9be70c926b778058d748d8ec27e2" alt=""
data:image/s3,"s3://crabby-images/7b65f/7b65f9db90e9e26ab70e2eb8793ba78dd583c551" alt=""
make && make install
data:image/s3,"s3://crabby-images/eea41/eea415c0fc42f04dcf784d8240a02f853d095fb2" alt=""
data:image/s3,"s3://crabby-images/a3522/a3522d1b536403a502be671bec575821a8e2f12b" alt=""
data:image/s3,"s3://crabby-images/02286/02286547b28d5c1d1a59619ccf774c05a71f84ba" alt=""
data:image/s3,"s3://crabby-images/f9c20/f9c20ee8eaabf75f413898fa37b88a71485600f1" alt=""
php加载模块
vim /usr/local/php/etc/php.ini
data:image/s3,"s3://crabby-images/dd4fd/dd4fde2054c715aeeafbe3b8e4002de05cd0e0a2" alt=""
data:image/s3,"s3://crabby-images/32965/3296592fb761eb1f8c6a8eec9797d3ba48d3de10" alt=""
data:image/s3,"s3://crabby-images/db879/db879ebb5906c3e3a564b8be18d72c76d21366d3" alt=""
data:image/s3,"s3://crabby-images/2a29a/2a29aac904f7fc82007acf2e57722e8b7199969c" alt=""
data:image/s3,"s3://crabby-images/0eebd/0eebdbc10e13dcf4b6244899d97108f615f2696f" alt=""
data:image/s3,"s3://crabby-images/5f654/5f6549736a7cec4fc59195cd20d221cfdeaab459" alt=""
data:image/s3,"s3://crabby-images/08755/08755b0256dfee712da968612f9917d8bd2a3c94" alt=""
要是做完以上步骤发现没错但是就是出不来mamcahe界面请重启虚拟机然后启动nginx 和systemctl start php-fpm
测试
data:image/s3,"s3://crabby-images/8e03c/8e03c1ed89d8da5980cf747916301e96ee5270cb" alt=""
data:image/s3,"s3://crabby-images/f5d25/f5d25f266c75cc8c2529dc8111ec0be5bc976e28" alt=""
data:image/s3,"s3://crabby-images/7d6ae/7d6aec4103131e262069e03759ce09a6d35f6319" alt=""
高速缓存
data:image/s3,"s3://crabby-images/d83f9/d83f99e64c4a72f32756a3c27e91768c99753998" alt=""
重启服务
如果重启不了,出现错误是无法绑定80端口,就要把nginx所有进程杀死然后再重启服务
data:image/s3,"s3://crabby-images/df1bd/df1bd0c062daa457950d24a0fbbbc3dab3fe99c4" alt=""