• 关于跨域名访问,反向代理系列话题集锦


       一:关于Nginx:

          Nginx 是什么玩意?

          Nginx是俄罗斯人编写的十分轻量级的HTTP服务器,Nginx,它的发音为“engine X”, 是一个高性能的HTTP和反向代理服务器,同时也是一个IMAP/POP3/SMTP 代理服务器.Nginx是由俄罗斯人 Igor Sysoev为俄罗斯访问量第二的 Rambler.ru站点开发的,它已经在该站点运行超过两年半了。Igor Sysoev在建立的项目时,使用基于BSD许可。

       据说他当初是F5的成员之一,英文主页:http://nginx.net

       它的影响:  

       直到2007年4月,俄罗 斯大约有20%左右的虚拟主机是由nignx服务或代理的。Google在线安全博客中统计nginx服务或代理了大约所有Internet虚拟主机的4%。而netcraft的统计显示,nginx服务的主机在过去的一年里以四倍的速度增长。短短的几年里,它的排名已跃进第9。

      它的特点:

    1、Nginx以事件驱动的方式编写,所以有非常好的性能,同时也是一个非常高效的反向代理、负载平衡。其拥有匹配 Lighttpd的性能。

    2、同时还没有Lighttpd的内存泄漏问题,而且Lighttpd的mod_proxy也有一些问题并且很久没有更新。

    3、但是Nginx并不支持cgi方式运行,原因是可以减少因此带来的一些程序上的漏洞。执行PHP程序必须使用FastCGI方式来。

    4、 nginx做为HTTP服务器,有以下几项基本特性:

       1)处理静态文件,索引文件以及自动索引;打开文件描述符缓冲.
       2)无缓存的反向代理加速,简单的负载均衡和容错.
       3)astCGI,简单的负载均衡和容错.
      4)  模块化的结构。包括gzipping, byte ranges, chunked responses,以及 SSI-filter等filter。如果由FastCGI或其它代理服务器处理单页中存在的多个SSI,则这项处理可以并行运行,而不需要相互等待。
      5) 支持SSL 和 TLSSNI.

       其他特点:

      Nginx专为性能优化而开发,性能是其最重要的考量,实现上非常注重效率 。它支持内核Poll模型,能经受高负载的考验,有报告表明能支持高达 50,000个并发连接数。

      Nginx具有很高的稳定性。其它HTTP服务器,当遇到访问的峰值,或者有人恶意发起慢速连接时,也很可能会导致服务器物理内存耗尽频繁交换,失去响应,只能重启服务器。例如当前apache一旦上到200个以上进程,web响应速度就明显非常缓慢了。而Nginx采取了分阶段资源分配技术,使得它的CPU与内存占用率非常低。nginx官方表示保持10,000个没有活动的连接,它只占2.5M内存,所以类似DOS这样的攻击对nginx来说基本上是毫无用处的。就稳定性而言,nginx比lighthttpd更胜一筹。

      Nginx支持热部署。它的启动特别容易, 并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动。你还能够在不间断服务的情况下,对软件版本进行进行升级。

      Nginx采用master-slave模型,能够充分利用SMP的优势,且能够减少工作进程在磁盘I/O的阻塞延迟。当采用select()/poll()调用时,还可以限制每个进程的连接数。

      Nginx代码质量非常高,代码很规范,手法成熟, 模块扩展也很容易。特别值得一提的是强大的Upstream与Filter链。 Upstream为诸如reverse proxy,与其他服务器通信模块的编写奠定了很好的基础。而Filter链最酷的部分就是各个filter不必等待前一个filter执行完毕。它可以把前一个filter的输出做为当前filter的输入,这有点像Unix的管线。这意味着,一个模块可以开始压缩从后端服务器发送过来的请求,且可以在模块接收完后端服务器的整个请求之前把压缩流转向客户端。

      Nginx采用了一些os提供的最新特性如对sendfile (Linux2.2+),accept-filter (FreeBSD4.1+),TCP_DEFER_ACCEPT (Linux 2.4+)的支持,从而大大提高了性能。

      当然,nginx还很年轻,多多少少存在一些问题,比如:Nginx是俄罗斯人创建,目前文档方面还不是很完善.因为文档大多是俄语,所以文档方面这也是个障碍.尽管nignx的模块比较多,但它们还不够完善。对脚本的支持力度不够。

      它的配置方法:

    配置文件

    worker_processes 1;
    events {
    worker_connections 1024;
    }
    http{
    upstream myproject {
    #这里指定多个源服务器,ip:端口,80端口(默认)
    server 192.168.43.158:80;
    server 192.168.41.167;
    }

    server {
    listen 8080;
    location / {
    proxy_pass http://myproject;
    }
    }
    }

    nginx的负载均衡有哪些功能呢?
    [list]
    [*]如果后面的服务器其中一台坏了,它能自动识别并跳转另一台服务器,等它好了之后nginx可以马上识别
    [*]服务器A和B,如果A的响应时间为3,B的响应时间为1,那么nginx会自动调整访问B的概率是A的3倍,真正做到负载均衡
    [/list]

    在这里还是想说说nginx的安装及运行
    先到http://www.nginx.net/下载最新的源码包。
    我下载到的是nginx-0.5.33.tar.gz
    解压:tar zxvf nginx-0.5.33.tar.gz
    接着:./configure
    再接着:make
    最后:make install
    好的,安装完成了。我在make的时候报了个错,说HTTP Rewrite 模块 有问题,我就./configure --without-http_rewrite_module
    然后再make,make install就可以了。
    安装好了之后新建一个配置文件,把上面的配置文件内容拷进去,当然要修改你的IP,保存为比如 load_balance.conf

    然后启动:
    /usr/local/nginx/sbin/nginx -c load_balence.conf

    如果上面的步骤走下来有问题的话,可以参考:
    nginx的中文维基
    http://wiki.codemongers.com/NginxChs
    当然也可以到官方网站
    www.nginx.net
    http://www.nginx.com/

    后话:最近本人调查发现,国内很多大网站也使用了。

    接下文:

      二、关于单点登录

    最近做了调查,针对搜狐网的,记录下,

    先看网上一哥们的

    Code

     

     我想说的,解决单点登录,方法很多,搜狐是其中一种,也比较复杂了,服务器压力也大.........

    目前遇到的系统整合,偶打算用cookie啦,跨库读数据,校验。。。。。

    个人觉得比较实用,从成本,优化,技术实现等方面考虑吧。

    (慢慢补充)

  • 相关阅读:
    缓存概念用法理解
    shiro
    Java生成验证码并进行验证(转)
    Java 8 Optional类深度解析(转)
    jdk8 stream可以与list,map等数据结构互相转换
    Java8初体验(二)Stream语法详解(转)
    Java 8 Optional 类
    cors跨域深刻理解
    httpclient连接池
    [C++] [算法] KMP算法
  • 原文地址:https://www.cnblogs.com/yhb199/p/1596745.html
Copyright © 2020-2023  润新知