转载:Nginx简介

一、前言

  为毛要用nginx服务器代理,不直接用tomcat 7.0,还做多了一次接请求?

  这个是我想问的,公司的新项目是要用Nginx+tomcat7+jdk开发的,用户命名可以直接访问tomcat,为啥还要用Nginx?这货是个啥玩意?

二、为什么使用Nginx?

  在传统的Web项目中,并发量小,用户使用的少。所以在低并发的情况下,用户可以直接访问tomcat服务器,然后tomcat服务器返回消息给用户。比如,我们上传图片:

这里写图片描述
当然我们知道,为了解决并发,可以使用负载均衡:也就是我们多增加几个tomcat服务器。当用户访问的时候,请求可以提交到空闲的tomcat服务器上。

这里写图片描述
但是这种情况下可能会有一种这样的问题:上传图片操作。我们把图片上传到了tomcat1上了,当我们要访问这个图片的时候,tomcat1正好在工作,所以访问的请求就交给其他的tomcat操作,而tomcat之间的数据没有进行同步,所以就发生了我们要请求的图片找不到。

  为了解决这种情况,我们就想出了分布式。我们专门建立一个图片服务器,用来存储图片。这样当我们都把图片上传的时候,不管是哪个服务器接收到图片,都把图片上传到图片服务器。

  图片服务器上需要安装一个http服务器,可以使用tomcat、apache、nginx。

这里写图片描述
看到这里大家可能会问,既然我们要选择的是http服务器,为什么不继续使用tomcat,而要使用Nginx?

  原因如下:nginx常用做静态内容服务和代理服务器(不是你FQ那个代理),直面外来请求转发给后面的应用服务(tomcat,django什么的),tomcat更多用来做做一个应用容器,让java web app跑在里面的东西,对应同级别的有jboss,jetty等东西。

  借鉴博客:nginx和tomcat的区别

三、什么是Nginx?

  根据前面的对比,我们可以了解到Nginx是一个http服务器。是一个使用c语言开发的高性能的http服务器及反向代理服务器。Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗斯的程序设计师Igor Sysoev所开发,官方测试nginx能够支支撑5万并发链接,并且cpu、内存等资源消耗却非常低,运行非常稳定。

3.1 Nginx的应用场景

  1、 http服务器。Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器。

  2、 虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。

基于端口的,不同的端口
基于域名的,不同域名
3、 反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用nginx做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。

### 子域名代理转发的 Nginx 配置 为了实现子域名的代理转发,可以通过配置 Nginx 来完成这一需求。以下是详细的配置过程以及注意事项。 #### 1. 下载并安装 Nginx 首先需要确保已经成功下载并安装了 Nginx 软件包。可以从官方网站获取最新版本的安装包,并按照操作系统的具体要求进行安装[^1]。 ```bash wget https://nginx.org/download/nginx-<version>.tar.gz tar -zxvf nginx-<version>.tar.gz cd nginx-<version> ./configure make && make install ``` #### 2. 修改 Nginx 配置文件 Nginx 的核心功能之一就是通过其灵活的配置文件来定义服务行为。对于子域名代理转发的需求,可以在 `server` 块中指定对应的子域名及其目标地址[^2]。 以下是一个典型的 Nginx 配置示例: ```nginx server { listen 80; server_name app1.example.com; location / { proxy_pass http://localhost:5000; # 将请求转发至本地运行的 Flask 应用 proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } ``` 上述配置实现了将来自 `app1.example.com` 的 HTTP 请求转发到本机上监听于 5000 端口的服务。如果该服务是由 Flask 提供,则此设置能够正常工作。 #### 3. 使用 SSL 加密连接 (可选) 如果希望启用 HTTPS 协议以提高安全性,还需要额外配置证书和私钥位置[^4]。例如: ```nginx server { listen 443 ssl; server_name app1.example.com; ssl_certificate /path/to/fullchain.pem; ssl_certificate_key /path/to/private.key; location / { proxy_pass http://localhost:5000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } ``` 在此基础上还可以进一步优化性能参数,比如调整超时时间或缓存策略等。 #### 4. 测试与重启服务 修改完成后应先验证配置文件是否有误,再重新加载 Nginx 进程使更改生效。 ```bash nginx -t # 检查语法错误 systemctl reload nginx # 或者 service nginx reload 如果未使用 systemd ``` 以上步骤即完成了基于 Nginx 的子域名代理转发配置[^3]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值