Nginx 基础配置(一)|学习笔记

简介: 快速学习 Nginx 基础配置

开发者学堂课程【Nginx 企业级 Web 服务实战Nginx 基础配置】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/649/detail/10758


Nginx 基础配置(一)

内容介绍:

一、try_files 参数

二、长连接配置

三、作为下载服务器配置

四、作为上传服务器

五、其他配置


一、try_files 参数

基于 try_files 参数,在网站中有用户的请求,也有各种合并的资源文件如图片等等,那么这些资源文件到底在我们的服务器上是否存在,或者有些用户访问错误,或者有些内容写错,这些都使用 try_files 实现。

try_files 会按顺序检查文件是否存在,返回第一个找到的文件或文件夹(结尾加斜线表示为文件夹),如果所有文件或文件夹都找不到,会进行一个内部重定向到最后一个参数。

只有最后一个参数可以引起一个内部重定向,之前的参数只设置内部 URI 的指向。最后一个参数是回退 URI 且必须存在,否则会出现内部500错误。

try_files file ...uri;

try_files file ...=code

try_files 后面可以做一些配置,假如文件不存在的话,给用户返回一个新的 uri,或者返回一个指定的 code 状态码。

例如

#try_files  $uri  /about/default.html  会返回一个新的uri:/about/default.html

#try_files $uri $uri/index.html $uri.html /about/default.html;  先判断有没有$uri下的index.html,或者.html,都没有再判断about下有没有default.html

try_files $uri $uri/index.html $uri.html =489;

都能匹配上然后返回一个指定的 code 状态码

演示:

注释掉最后的

auth basic_user_file  /apps/nginx/conf/.htpasswd;

然后输入 try_files $uri

访问网址 magedu.net/login/index.html,如图 uri 即为 /login/index.html

image.png

要是请求不存在,例如为 index1.html

image.png

对于这种请求不存在,找是否有 $uri /index.html,用户访问的是否是个目录呢,找目录下的 $ur i的文件 index.html 或者 $uri.html

可以像模糊匹配一样补全,在代码中继续输入 $uri/index.html  $uri.html

然后保存之后 reload 一下

之后访问网址 www.magedu.net/login/index1 时,页面报错,因为用户只输入index1,有可能是一个目录,也有可能是文件

找不到还有可能是以另一种方式存在服务器上

现在创建一个 index1的目录,在另一个端口上输入 cd /data/nginx/html

ll

mkdir index1

vim index1/index.html

创建之后 index1就会以目录的形式访问

继续刷新浏览器发现还是报错,尝试将

try_files $uri $uri/index.html  $uri.html 放在根下 location / {

root  /data/nginx/html/pc;

index index.html index.htm;

}

现在将 index1移到目录 /data/nginx/html/pc 下,在另个端口输入 ll /apps/nginx/conf/nginx.conf^C

cd /data/nginx/html/pc

mv /data/nginx/html/index1

ll

/apps/nginx/sbin/nginx -s reload

这时再来访问网址 magedu.net/index1/

页面显示 index1

找到这是因为在访问根时,输入了一个不存在的 uri,该 uri 为 index1,但是在资源目录里没有 index1,就会接着将 $uri 当作一个目录找下面的 index.html,刚好服务器上存在,所以能找到。

如果没有写 $uri/index.html 或者没有找到就会继续找 $uri.html

例如先删掉 $uri/index.html 即 try_files $uri  $uri.html 就只会判断两个,而这两个都找不到,所以访问网址 magedu.net/index/ 时就会报错,要再来创建一个index1.html

输入vim index1.html

再写 html1

访问网址发现还是报错

来看一下日志,输入 tail -f /apps/nginx/logs/*.log

发现 error.log下有报错,index1下的.html 循环了多次

访问网址 magedu.net/index1 发现页面显示结果为 index1,访问网址时不加/,有/表示就为目录

此外如果三个都找不到 $uri $uri/index.html  $uri.html,就会有一个默认的返回页面 /about/default.html,找不到就会显示网站的首页。

比如为 /.html,此处的根相当于 location /,该/在目录 /data/nginx/html/pc 下,将 /data/nginx/html/pc 作为根,将别的目录资源返回给它,在另一个端口输入 ll

ll about/

ll about/index.html

就会将关于本公司的页面返回给用户,将 /about/index.html 放在 try_files 后,替换 /.html,此时用户访问不存在的 uri 时,就会显示首页

访问网址 magedu.net/index2,如图

image.png

显示一个默认界面

像天猫等其他网址访问不存在的会报错,例如访问

https://www.tmall.com/linux39

就会显示如图,没有跳到首页

image.png

例如京东,访问网址https://www.jd.com/linux39.html就会跳到首页

还有的是最终返回状态码,例如返回666,注释掉try_files $uri $uri/index.html  $uri.html /about/index.html

再输入try_files $uri $uri/index.html  $uri.html =666;

再访问网址 magedu.net/index2,如图显示状态码就为666

image.png

但状态码不常用


二、长连接配置

keepalive_timeout number;  #设定保持连接超时时长,0表示禁止长连接,默认为75s,通常配置在 http 字段作为站点全局配置

keepalive_requests number;  

#在一次长连接上所允许请求的资源的最大数量,默认为100次,超过100次后就会和客户端断开

在之前配置中,输入vim /apps/nginx/conf/nginx.conf

65是给真正的服务端超时时长   90是给浏览器去看的

image.png

keepalive_requests 3;

keepalive_timeout 65  65

开启长连接后,返回客户端的会话保持时间为60s,单次长连接累计请求达到指定次数请求或65秒就会被断开,后面的60为发送给客户端应答报文头部中显示的超时时间设置为60s:如不设置客户端将不显示超时时间。

句法: keepalive_requests number;

默认: keepalive_requests 100;

内容: http,server,location

设置可以通过一个保持活动连接服务的最大请求数。发出最大数量的请求后,将关闭连接。

演示:将 keepalive_requests 的值调小,调为3,在全局配置中输入

keepalive_requests 3;

保存后再 reload 后再来测试

使用命令测试:

[root@s3 apps]# telnet www .magedu . net 80

Trying 172.18.200.102...

Connected to www . magedu. net.

Escape character is ‘^]’ .

GET / HTTP/1.1

HOST: www .magedu.net

先开启多个窗口,在窗口中都输入

telnet www.magedu.net 80

GET / HTTP/1.1

HOST: www.magedu.net

回车后再反复操作输入GET / HTTP/1.1

HOST: www .magedu.net

GET / HTTP/1.1

HOST: www .magedu.net

image.png

输入三次后就会断开,显示 connection closed by foreign host

断开后就要重新建立连接

所以 keepalive_requests  后的 number 一般会调大,调成200,意味着一次长连接可以和客户端交互200个文件

相关文章
|
16天前
|
移动开发 前端开发 JavaScript
前端vue2、vue3去掉url路由“ # ”号——nginx配置(一)
前端vue2、vue3去掉url路由“ # ”号——nginx配置
49 0
|
16天前
|
JavaScript 前端开发 应用服务中间件
angular引入包、路由权限配置、打包问题与nginx配置问题(简单部署)
angular引入包、路由权限配置、打包问题与nginx配置问题(简单部署)
24 0
|
1月前
|
安全 应用服务中间件 Linux
linux nginx的配置总结
linux nginx的配置总结
19 0
|
16天前
|
前端开发 JavaScript 应用服务中间件
前端vue2、vue3去掉url路由“ # ”号——nginx配置(二)
前端vue2、vue3去掉url路由“ # ”号——nginx配置
47 0
|
1天前
|
应用服务中间件 nginx
nginx配置集群轮训策略
nginx配置集群轮训策略
9 0
|
2天前
|
安全 网络协议 应用服务中间件
一文读懂HTTPS⭐揭秘加密传输背后的原理与Nginx配置攻略
一文读懂HTTPS⭐揭秘加密传输背后的原理与Nginx配置攻略
|
9天前
|
应用服务中间件 PHP nginx
php如何实现检测nginx配置的正确性
请确保在执行此操作时,PHP有足够的权限来执行Nginx命令和访问Nginx配置文件。另外,将上述代码嵌入到您的应用程序中时,要注意安全性,以防止潜在的命令注入攻击。
50 3
|
16天前
|
安全 应用服务中间件 网络安全
linux_nginx中添加ssl配置(open ssl)
linux_nginx中添加ssl配置(open ssl)
25 1
|
16天前
|
JSON JavaScript 前端开发
vue2_vite.config.js的proxy跨域配置和nginx配置代理有啥区别?
vue2_vite.config.js的proxy跨域配置和nginx配置代理有啥区别?
32 1
|
19天前
|
安全 应用服务中间件 网络安全
SSL原理、生成SSL密钥对、Nginx配置SSL
现在,你的Nginx虚拟主机应该已经配置了SSL,可以通过HTTPS安全访问。确保在生产环境中使用有效的SSL证书来保护通信的安全性。
30 0