Nginx技术进阶详讲

Nginx技术进阶详讲

作者 : Stanley 罗昊

转载请注明出处和署名,谢谢!

并发数问题

讲到并发数这个概念,想必各位应该都知道是什么意思,就是同时访问一个项目,就比我们现在做的一些项目完工以后要放到公网环境下的时候,所有人都能用,比如,你上百度,同时别人也在上,所以有多少人同时在,又同时去处理,这就是所谓的并发数;

tomcat的并发数大概在300左右,如果再多的话,它的访问速度就会变的很慢,这里值得提一下,虽然只有300,但是并发数还是比较多的,什么概念呢?就死在一秒之内,甚至不到一秒,同时访问这个系统的并发量300左右,当然它也受限于网络带宽的问题;

带宽越大,我在你这个网页上下载的速度也就越快,如果我的带宽只有一兆的话,那么我的下载速度也就几十KB,所以这些并发数,还受限于这写影响;

Nginx解决并发数问题

刚才我也说了,Tomcat的并发量大概也就300,同时连进来的人数若要超过这300,那么速度就会变得非常慢,会出现丢包的情况,至于什么是丢包我在这里就不详说了,各位可以自行百度;

怎么解决这个问题呢?

那么就用Nginx(静态资源服务武器)来解决这个问题;

nginx是一个很强大的高性能的wbe和反向代理服务器,它狙狗非常优越的特性:

在连接高并发的情况下,Nginx是Apache服务器不错的替代品,而它的并发量在50000左右,简直无法跟tomcat相比,就不是一个数量级的;

但是有一个疑问就是,那直接学或直接用Nginx不就完了吗,干嘛还要学Tomcat、JBOSS....

Nginx是一个HTTP和反向代理服务器,Tomcat是应用服务器,能够运行java程序、执行jsp、serviet;

Nginx不行,它是来处理静态资源的,你往上面放一个静态的图片、视频、音频以及一个HTML,它能帮你处理,你往上面放一个java源代码,它就不能帮你处理了;

所以,Nginx跟Tomcat这些应用服务器没有任何冲突,Nginx的应用面,跟Tomcat简直就是两个应用面,他们之间没有任何冲突;

使用Nginx访问静态资源

Ngxin下载网盘地址【windows】(腾讯微云):

链接:https://share.weiyun.com/5VfMTOP 密码:mf39a6

下载安装好后打开,我们需要配置一些属性来做负载均衡👇

1.启动Nginx

解压到指定文件夹后,我们双击Nginx:

进去之后双击nginx.exe,运行即可【可以在系统资源管理器】中查看Nginx运行状态;

2.配置Nginx

在conf文件中,双击nginx.conf使用记事本或者其他文本工具打开:

接下来我们开始对它的配置文件进行一系列的解读;

3.Nginx.conf配置文件解读

点进去后,首先我声明一点,我不是做运维的,我是干开发的,所以我只会说一些对于我们开发而言比较重要的一些配置;

第一部分:👇

http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       8888;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
        }

首先,http是处理http协议的,setver算是一个节点,这代表其中一个服务,服务监听端口是8888端口,当你执行8888端口的时候,他就会自动帮你映射到你Nginx所在的根目录;

这个根目录是在咱们的电脑上的Nginx安装目录:

在配置文件中可以清晰的看到,它映射到这个nginx根目录中的html文件夹:

而这里面的资源,你都可以通过8888来访问了;

 比如我现在想访问我这里的一张图片,很简单,打开浏览器,直接输入端口8888,加上你的文件地址全目录即可【前提是你先启动Nginx】👇

地址栏输入👇:

这样就完成了静态资源的访问;

 反向代理(动静分离)

反向代理(Reverse Proxy)实际运行方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器。

通俗点理解就是,当你访问一个页面,那个页面上肯定有一些什么图片啊音频视频,当我们访问这个网页的时候,相当于你发了两次请求,比如百度,你访问百度一次,又向它的内外服务器发了一次请求,而它的内网服务器就是nginx,它从内网服务器拿出你访问的一些图片,音频,从而可以看出,静态资源与动态资源是放在一个不同的服务器上;

我访问百度,百度一看我要访问的是图片就是一些静态资源,那么,它就是把你的这次请求转发给静态资源服务器,获取图片后,响应给你;

所以,作为用户,你不知道你到底访问的是哪一台服务器;

通过反向代理机制可以做负载均衡;

负载均衡

先通过一张图大概了解一下:

我们需要在配置文件中配置一下,首先,还是在刚刚我在上面写的那个文件,用记事本打开,接下来,我将介绍第二个比较重要的配置👇:

#配置应用服务器的ip端口
http {
upstream myproject {
 server 127.0.0.1:8081;
 server 127.0.0.1:8082;
 }

 server {
 listen 6565;
 server_name www.domain.com;
 location / {
 proxy_pass http://myproject;
 }
 }
}

首先,这段代码在配置文件中不内置,需要自己手动添加进去,我大概介绍一下;

upstream是关键字来标识自己是一个配置反向代理的字段,不可以更改,后面的myspringboot可以随便更改;

后面的就是配置你的应用服务器集群,用来帮你代理的;

配置完成后重启才能生效;

直接在任务管理器结束Nginx进程,再开即可~

而下面的server就代表,通过6565来访问以上两个应用服务器季集群,从而达到,负载均衡;

今日感悟:

人的一切痛苦,本质上都是对自己无能的愤怒;

 

posted @ 2019-03-17 10:48  StanleyBlogs  阅读(930)  评论(0编辑  收藏  举报