网站首页 > 技术教程 正文
安全服务器是只允许所需数量的服务器。理想情况下,我们将通过单独启用其他功能来基于最小系统构建服务器。进行最少的配置也有助于调试。如果该错误在最小系统中不可用,则分别添加功能,然后继续搜索错误。
这是运行nginx所需的最低配置:
# /etc/nginx/nginx.confevents {}
# event context have to be defined to consider config valid
http {}
server {
listen 80;
server_name javatpoint.co www.javatpoint.co *.javatpoint.co;
return 200 "Hello";
}
Root,Location和try_files指令
Root 指令
root指令用于设置请求的根目录,从而允许nginx将传入的请求映射到文件系统上。
server {
listen 80;
server_name javatpoint.co;
root /var/www/javatpoint.co;
}
它允许nginx根据请求返回服务器内容:
javatpoint.co:80/index.html # returns /var/www/learnfk.com/index.html
javatpoint.co:80/foo/index.html # returns /var/www/learnfk.com/foo/index.html
Location指令
location指令用于根据请求的URI(统一资源标识符)来设置配置。
语法为:
location [modifier] path
示例:
location /foo { # ...}
如果未指定修饰符,则将路径视为前缀,之后可以跟随任何内容。上面的示例将匹配:
/foo
/fooo
/foo123
/foo/bar/index.html...
我们还可以在给定的上下文中使用多个location指令:
server {
listen 80;
server_name javatpoint.co;
root /var/www/javatpoint.co;
location/{
return 200 "root";
}
location /foo {
return 200 "foo";
}
}
javatpoint.co:80 / # => "root"
javatpoint.co:80 /foo # => "foo"
javatpoint.co:80 /foo123 # => "foo"
javatpoint.co:80 /bar # => "root"
Nginx还提供了一些可以与 location 指令结合使用的修饰符。
修饰符已分配优先级:
= - Exact match
^~ - Preferential match
~ && ~* - Regex match
no modifier - Prefix match
首先,nginx将检查所有精确匹配项。如果不存在,它将寻找优先选项。如果此匹配也失败,则将按其出现顺序测试正则表达式匹配。如果其他所有操作均失败,则将使用最后一个前缀匹配。
location /match {
return 200 'Prefix match: will match everything that starting with /match';
}
location ~* /match[0-9] {
return 200 'Case insensitive regex match';
}
location ~ /MATCH[0-9] {
return 200 'Case sensitive regex match';
}
location ^~ /match0 {
return 200 'Preferential match';
}
location = /match {
return 200 'Exact match';
}
/match # => 'Exact match'
/match0 # => 'Preferential match'
/match1 # => 'Case insensitive regex match'
/MATCH1 # => 'Case sensitive regex match'
/match-abc # => 'Prefix match: matches everything that starting with /match'
try\_files指令
该指令尝试不同的路径,并返回找到的任何路径。
try_files $uri index.html =404;
因此,/foo.html将尝试按以下顺序返回文件:
$uri(/foo.html);
index.html
如果未找到:404
如果我们在服务器上下文中定义try\_files,然后定义查找所有请求的位置,则不会执行try\_files。发生这种情况是因为服务器上下文中的try\_files定义了其伪位置,该伪位置是可能的最低特定位置。因此,定义location/ 会比我们的伪位置更具体。
server {
try_files $uri /index.html =404;
location/{
}
}
因此,我们应该避免在服务器上下文中使用try_files:
server {
location/{
try_files $uri /index.html =404;
}
}
如里需要学习更多关于nginx的知识体系,也可以关注小编,持续更新。
基础的服务安装、配置文件介绍、虚拟主机配置实践、Nginx优化配置详解、LNMP架构Nginx反向代理负载均衡配置、Nginx+Tomcat多实例及负载均衡配置、高可用、Nginx 版本的平滑升级与回滚、Nginx限流配置、Nginx日志生产实战、Nginx配置文件在线生成工具介绍等。
猜你喜欢
- 2024-10-12 优化体系--tomcat参数优化(内存、线程、压缩、集群、ARP)
- 2024-10-12 Linux-tomcat部署,注意几点安全配置
- 2024-10-12 很全的Tomcat实战-调优方案,提升性能必备
- 2024-10-12 Tomcat配置与优化--架构师必修课(tomcat7优化配置)
- 2024-10-12 详解tomcat7优化配置参数(tomcat性能优化方法)
- 2024-10-12 tomcat,nginx,mysql性能调优与配置
- 2024-10-12 Tomcat服务器配置详解(tomcat服务器的配置)
- 2024-09-25 小计Tomcat的调优思路(tomcat8调优)
- 2024-09-25 Nginx系列篇三:linux中Nginx+keepalived做一个高可用的主从配置
- 2024-09-25 企业十大应用-Tomcat-配置详解(tomcat企业版要收费吗)
你 发表评论:
欢迎- 最近发表
-
- Win10 TH2正式版官方ESD映像转换ISO镜像方法详解
- 使用iso镜像升级到Windows 10的步骤
- macOS Ventura 13.2 (22D49) Boot ISO 原版可引导镜像
- 安利一个用ISO镜像文件制作引导U盘的的小工具RUFUS
- CentOS 7使用ISO镜像配置本地yum源
- 用于x86平台的安卓9.0 ISO镜像发布下载:通吃I/A/N、完全免费
- AlmaLinux 9.6发布:升级工具、初步支持IBM Power虚拟化技术
- Rufus写入工具简洁介绍与教程(写入模式)
- 新硬件也能安装使用了,Edge版Linux Mint 21.3镜像发布
- 开源工程师:Ubuntu应该抛弃32位ISO镜像
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)