Nginx

Nginx概述
Nginx是一个高性能的HTTP和反向代理服务器,特点是占有内存少,并发性能强。Nginx专为性能优化而开发,性能是最重要的考量,能承受高负载的考验。
Nginx支持热部署,它的启动非常容易,并且几乎可以做到7*24小时不间断运行,即使几个月也不需要重新启动。它还可以在不间断服务的情况下,对软件版本进行升级。

Nginx特点
1,反向代理
正向代理:
Nginx不仅可以做反向代理,实现负载均衡,还可以做正向代理进行上网等功能。
正向代理:如果把局域网外的Internet想象成一个巨大的资源库,则局域网中的客户端要访问Internet,则需要通过代理服务器来访问,这种代理服务就称为正向代理。
反向代理:
反向代理,客户端对代理是无感知的,因为客户端不需要任何配置就可以访问,我们只需要将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,再返回给客户端。此时,反向代理服务器和目标服务器对外就说一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP地址。
2,负载均衡
客户端发送多个请求到服务器,服务器处理请求,有一些可能要与数据库进行交互,服务器处理完毕之后,再将结果返回给客户端。
这种架构模式对于早期的系统相对单一,并发请求相对较少的情况下是比较合适的,成本也低。但是,随着信息量的增加,访问量和数据量飞速增长,这种架构会造成客户端的请求日益缓慢。
这时候就提出了负载均衡的概念。单个服务器解决不了,我们就增加服务器的数量,然后将请求分发到各个服务器上,将原先请求集中到单个服务器上的情况改为将请求分发到多个服务器上,将负载分发到不同的服务器,也就是我们常说的负载均衡。
3,动静分离
为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速度,降低原来单个服务器的压力。

Nginx配置文件
Nginx的配置文件nginx.conf位置在/usr/local/openresty/nginx/conf目录下

组成部分:
1,全局块
从配置文件开始到events块之间的内存,主要会设置一些影响Nginx服务器整体运行的配置指令
如:worker_processes 1; worker_processes的值越大,可以支持的并发处理数量也就越多
2,events块
events块涉及的指令主要影响Nginx服务器与用户的网络连接
比如worker_connections 1024; 支持的最大连接数
3,http块
Nginx 服务器配置中最频繁的部分
http块也可以包括http全局块,server块
Nginx安装
1,选择使用yum安装方式,yum默认会安装openresty源的最新版本

sudo yum install -y yum-utils
//添加openresty yum源
sudo yum-config-manager --add-repo https://openresty.org/package/centos/openresty.repo
//安装openresty
sudo yum install -y openresty

2,yum方式安装后,安装目录在/usr/local/openresty同时可执行二进制文件为/usr/bin/openresty(它只是一个软链接)。如果你的/usr/bin目录不在系统PATH中,是无法直接执行openresty命令。你需要将/usr/bin添加到到系统环境变量PATH中。

3,为我们的采集项目创建一个OpenResty应用,其实就是创建一个目录,应用相关配置文件都放在这个目录中,方便管理。

mkdir -p /opt/app/collect-app/
mkdir -p /opt/app/collect-app/conf/
mkdir -p /opt/app/collect-app/logs/
mkdir -p /opt/app/collect-app/conf/vhost/
cp /usr/local/openresty/nginx/conf/mime.types /opt/app/collect-app/conf/

4,编写nginx配置文件,命名为nginx.conf,放到/opt/app/collect-app/conf目录下

#nginx.conf
#nginx 用户和组
user root root;
#work进程数
worker_processes 4;
#错误日志路径和日志级别
error_log logs/nginx_error.log error;
#nginx pid 文件
pid logs/nginx.pid;
#单个worker最大打开的文件描述符个数
worker_rlimit_nofile 65535;
events
{
}
http
{
....
#定义数据采集的ACCESS日志格式
include /opt/app/collect-app/conf/vhost/*.conf
}

企业工程中,我们一般会把多个应用配置和nginx主配置文件分开,然后在主配置文件中通过include命令包含我们的应用配置。

server
{
listen 8802 default_server;
}

5,编写APP的nginx配置,命名为collect-app.conf,放到/opt/app/collect-app/conf/vhost/下。企业中,我们会把多个应用配置和nginx主配置文件分开,然后在主配置文件中通过include命名包含我们的应用配置。

6,测试配置文件是否正确,并启动服务。

7,Nginx启动之后,根据我们的配置已经在8802端口监听请求。我们数据服务配置的路径是/data/v1,同时我们会解析请求中url的参数project的参数值。
测试接口能否正常接收数据?认识我们的接口,我们的服务监听8802端口,请求路径是/data/v1,如果客户端有数据请求过来,我们解析HTTP请求,request_body中的数据,解析后的数据和我们自己定义的数据做一个拼接,日志写入到collect-app.access.log文件中,返回给客户端{“code”:200,“msg”:“ok”}。如果一个客户请求的request_body为空,我们将在日志中记录空行,返回给客户端{“code”:500,“msg”:“req body nil”}

8,将接口配置到管理中心,就可以接收到客户端上报的数据。

Nginx常用的命令

openresty -h
nginx version: openresty/1.17.8.2
Usage: nginx [-?hvVtTq]	[-s signal] [-c filename] [-p prefix] [-g directives]
Options:
-?, -h	:	this help
-v		:	show version and exit
-V		:	show version and configure options then exit
-t		:	test configuration and exit
-T		:	test configuration, dump it and exit
-q		:	suppress non-error messages during configuration testing
-s signal :	send signal to a master process: stop, quit, reopen, reload
-p prefix : set prefix path (default : /usr/loca;/openresty/nginx)
-c filename : set configuration file (default : conf/nginx.conf)
-g directives : set global directives out of configuration file
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值