Windows安装nginx1.10.1反向代理访问IIS网站

首先去官网下载软件包,解压,路径最好不要有中文

Nginx配置的路径问题

由于在Windows下文件路径可以用”\”, 也可以用”\\”, 也可以用”/”作为路径做分隔符。但”\”最容易引发问题,所以要尽量避免使用。

不要添加PATH,否则会引发错误,config文件路径找不到

比如我解压在E盘

cmd命令定位到nginx.exe所在文件夹cd E:\WorkSoftWare\nginx-1.10.1
然后执行,首先保证nginx.conf文件配置没问题

其实nginx最重要的和最主要的工作就是配置文件,其他没什么需要我们应用开发人员关注的,除非想修改底层源码.
nginx.conf配置如下:

#user nobody;
worker_processes 1;
#工作进程的个数,可以配置多个 

#全局错误日志及PID文件
error_log /WorkSoftWare/nginx-1.10.1/logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info; 

pid  /WorkSoftWare/nginx-1.10.1/logs/nginx.pid; 

events {
 worker_connections 1024; #单个进程最大连接数(最大连接数=连接数*进程数)
} 

#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
 include  mime.types; #设定配置文件位置,这里的conf是指nginx.conf所在的目录,也可以用绝对路径指定其他地方的配置文件
 default_type application/octet-stream; #默认类型-8进制文件流 

 #设定日志格式
 #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 /WorkSoftWare/nginx-1.10.1/logs/access.log main; 

 sendfile  on; #是否激活sendfile()函数,比默认模式更有效率
 #tcp_nopush  on; #将HTTP响应头压缩到一个包中发送,仅在sendfile开启时才能配合使用 

 #连接超时时间
 #keepalive_timeout 0;
 keepalive_timeout 65; 

 gzip on; #启用Gzip压缩 

 #服务器的集群
 #设定负载均衡的服务器列表 支持多组的负载均衡,可以配置多个upstream 来服务于不同的Server.
 #nginx 的 upstream 支持 几 种方式的分配
 #1)、轮询(默认) 每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
 #2)、weight 指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。 跟上面样,指定了权重。
 #3)、ip_hash 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
 #4)、fair
 #5)、url_hash #Urlhash 

 #upstream imicrosoft.net
 #{
  #服务器集群名字
  #服务器配置 weight是权重的意思,权重越大,分配的概率越大。
  #server 192.98.12.60:1985 weight=3 max_fails=2 fail_timeout=30s;
  #server 192.98.12.42:8086 weight=3 max_fails=2 fail_timeout=30s; 

  #weigth参数表示权值,权值越高被分配到的几率越大
  #1.down 表示单前的server暂时不参与负载
  #2.weight 默认为1.weight越大,负载的权重就越大。
  #3.backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。
  #本例是指在同一台服务器,多台服务器改变ip即可
 # server 127.0.0.1:8055 weight=4 down;
 # server 127.0.0.1:8010 weight=5 backup;
 #} 

 upstream localhost
 {
  server 127.0.0.1:9000 weight=3 max_fails=2 fail_timeout=200s;
  server 127.0.0.1:8086 weight=5 max_fails=2 fail_timeout=200s;
 } 

 #当前的Nginx的配置,代理服务器的地址,即Nginx安装的服务器地址、监听端口、默认地址,
 #设定虚拟主机,默认为监听80端口
 server
 {
  listen  9090; #侦听9090端口
  #对于server_name,如果需要将多个域名的请求进行反向代理,可以配置多个server_name来满足要求
  server_name localhost; #当前服务的域名 

  charset utf8;
  #charset koi8-r; 

  #设定本虚拟主机的访问日志
  #access_log logs/host.access.log main; 

  #如果访问 /images/*, /js/*, /css/* 资源,则直接取本地文件,不用转发。
  #但如果文件较多效果不是太好。
  #location ~ .*\.(jpg|jpeg|gif|css|png|ico|html)$
  #{
  # expires 30d;
  # root /nginx-1.10.1;#root:
  # break;
  #} 

  #对 "/" 启用负载均衡
  location / { 

   root html;  #默认主页目录在nginx安装目录的html子目录 

   index index.html index.htm index.aspx; #没有索引页时,罗列文件和子目录
   #proxy_pass http://www.imicrosoft.net; #跟载均衡服务器的upstream对应
   autoindex on; #没有索引页时,罗列文件和子目录 

   #保留用户真实信息
   proxy_redirect off; #url不跳转
   proxy_set_header Host $host;
   proxy_set_header X-Real-IP $remote_addr;
   proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
   #缓冲区代理缓冲用户端请求的最大字节数,可以理解为先保存到本地再传给用户
   # client_body_buffer_size 128k;
   # #跟后端服务器连接超时时间 发起握手等候响应超时时间
   # proxy_connect_timeout 12;
   # #连接成功后 等待后端服务器响应时间 其实已进入后端的排队之中等候处理
   # proxy_read_timeout 90;
   # #代理请求缓存区 这个缓存区间会保存用户的头信息一共Nginx进行规则处理 一般只要能保存下头信息即可
   # proxy_send_timeout 90;
   # #同上 告诉Nginx保存单个用的几个Buffer最大用多大空间
   # proxy_buffer_size 4k;
   # proxy_buffers 4 32k;
   # #如果系统很忙的时候可以申请国内各大的proxy_buffers 官方推荐 *2
   # proxy_busy_buffers_size 64k;
   # #proxy 缓存临时文件的大小
   proxy_temp_file_write_size 64k;
   # proxy_next_upstream error timeout invalid_header http_500 http_503 http_404;
   proxy_max_temp_file_size 128m;
   #启动代理
   proxy_pass http://localhost;
   client_max_body_size 10m; #允许客户端请求的最大单个文件字节数
  } 

  #示例一
  #location / {
  #  proxy_pass http://imicrosoft.net;
  #
  #  proxy_redirect default;
  #
  #  proxy_set_header Host $host;
  #  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  #} 

  #示例二
  #location /tileservice {
  #  proxy_pass http://cluster/MongoTileService/tileService;
  #  proxy_set_header Host $host;
  #  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  #} 

  #error_page 404    /404.html; 

  # redirect server error pages to the static page /50x.html
  #
  error_page 500 502 503 504 /50x.html;
  location = /50x.html {
   root html;
  } 

  # proxy the PHP scripts to Apache listening on 127.0.0.1:80
  #对 "/XXXXX.PHP" 启用负载均衡
  #location ~ \.php$ {
  # proxy_pass http://127.0.0.1;
  #} 

  #location /baidu
  #{
  #proxy_pass http://www.google.com;
  #proxy_set_header Host $host;
  #proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  #} 

  # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
  #
  #location ~ \.php$ {
  # root   html;
  # fastcgi_pass 127.0.0.1:9000;
  # fastcgi_index index.php;
  # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
  # include  fastcgi_params;
  #} 

  # deny access to .htaccess files, if Apache's document root
  # concurs with nginx's one
  #
  #location ~ /\.ht {
  # deny all;
  #}
 } 

 # another virtual host using mix of IP-, name-, and port-based configuration
 #
 #server {
 # listen  8000;
 # listen  somename:8080;
 # server_name somename alias another.alias; 

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

 # HTTPS server
 #
 #server {
 # listen  443 ssl;
 # server_name localhost; 

 # ssl_certificate  cert.pem;
 # ssl_certificate_key cert.key; 

 # ssl_session_cache shared:SSL:1m;
 # ssl_session_timeout 5m; 

 # ssl_ciphers HIGH:!aNULL:!MD5;
 # ssl_prefer_server_ciphers on; 

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

}

结果如图:

IIS站点

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Nginx+IIS简单的部署教程

    随着互联网项目用户访问量不断上升,单点web服务器是无法满足大型高并发高负载的业务处理的,为了给web服务器做负载均衡方案,打算采用Nginx搭建负载均衡服务器,把用户请求分配到N个服务器来缓解服务器压力. Nginx简介: Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器 . Nginx 是由 Igor Sysoev 为俄罗斯访问量第二的Rambler.ru 站点开发的,它已经在该站点运行超过四年

  • 采用软件负载均衡器实现web服务器集群(iis+nginx)

    我用nginx实现网站负载均衡测试的例子,windows下IIS做负载实测. 如果你的网站访问量(pv)越来越高,一台服务器已经没有办法承受流量压力,那就增多几台WEB服务器来做负载吧. 做网站负载可以买硬件设备来实现,我们公司用的是F5,不过价格就几十万到上百万,太贵了, 目前好多门户网站与大访问量的网站都在使用nginx做为HTTP服务器,所以nginx是非常优秀的,下面我亲手做这个负载测试吧. 软/硬件环境: (2台服务器) 第一台:  CPU:Inter(R) 酷睿 i5 CPU 2.2

  • nginx+iis实现简单的负载均衡

    最近在研究分布式系统架构方面的知识,包括负载均衡,数据库读写分离,分布式缓存redis等.本篇先从负载均衡服务架构入手,关于负载均衡百度百科的定义如下:负载均衡,英文名称为Load Balance,其意思就是分摊到多个操作单元上进行执行,例如Web服务器.FTP服务器.企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务. 我的解释:一项任务交由一个开发人员处理总会有上限处理能力,这时可以考虑增加开发人员来共同处理这项任务,多人处理同一项任务时就会涉及到调度问题,即任务分配,这和多线程

  • Nginx反向代理+DNS轮询+IIS7.5 千万PV 百万IP 双线 网站架构案例

    Nginx  ("engine x") 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器. Nginx 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,它已经在该站点运行超过两年半了.Igor 将源代码以类BSD许可证的形式发布. Nginx 的中文维基:http://wiki.codemongers.com/NginxChs 在高并发连接的情况下,Nginx是Apache服务器不错的替代品.Nginx

  • iis、apache、nginx使用X-Frame-Options防止网页被Frame的解决方法

    当然也是因为被360检测到了示"X-Frame-Options头未设置",根据360的提示与百度了一些网上的一些资料整理了下,完美解决问题. 首先看下360给出的方案,但么有针对服务器的具体设置,不是每个人对服务器都很懂啊. 描述: 目标服务器没有返回一个X-Frame-Options头. X-Frame-Options HTTP响应头是用来确认是否浏览器可以在frame或iframe标签中渲染一个页面,网站可以用这个头来保证他们的内容不会被嵌入到其它网站中,以来避免点击劫持. 危害: 攻击者可

  • iis+nginx实现负载均衡的详细步骤

    简要说明:nginx的简介自行百度. 目的:把用户的请求分到各个服务器减轻压力.nginx把监听的端口的请求平均转到布署了网站的服务器. 一.windows上安装nginx 1.官网下载windows版的nginx http://nginx.org/en/docs/windows.html 目前最新版本为1.13.2 2.下载解压后 3.因为我电脑80端口已经被使用,所以修改配置文件改为监听8080端口 4.双击主程序运行,可以看到nginx已经在进程里面运行了. 5.尝试打开 http://l

  • 让iis记录nginx反向代理的真实ip

    一.设置X-Forwarded-For段 nginx配置示例: 复制代码 代码如下: server{   location   {      ...     proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;     ...   }} 二.在iis站点上安装isapi filter 在f5的开发论坛上找到的,按开发者的话说,是为了解决iis放在f5后记录不到用户ip的问题,管他前端是f5还是nginx还是squid还是h

  • nginx、Apache、IIS服务器解决 413 Request Entity Too Large问题方法汇总

    一.nginx服务器 nginx出现这个问题的原因是请求实体太长了.一般出现种情况是Post请求时Body内容Post的数据太大了,如上传大文件过大.POST数据比较多. 处理方法 在nginx.conf增加 client_max_body_size的相关设置, 这个值默认是1m,可以增加到8m以增加提高文件大小限制:当然可以设置的更大点. 复制代码 代码如下: # 在http,server或者location段修改下面的配置:# set client body size to 8M #clie

  • IIS、Apache、Nginx下用IE下载apk文件变成zip的解决办法

    下面我们来说下具体的解决方法 一.IIS的解决方案 我们只需要将服务器中的 MIME类型改为:  application/vnd.android.package-archive 就可以了 二.APACHE的解决方案 在Apache安装目录下的conf/mime.types文件的对应位置,加上以下一行语句,指定APK文件的MIME类型为 application/vnd.android.package-archive 即可: 复制代码 代码如下: application/vnd.android.pa

  • iis、apache与nginx禁止目录执行asp、php脚本的实现方法

    一般iis中比较简单,iis6如下图所示即可: 很多购买虚拟主机空间的用户,如果空间商提供了在线管理程序,也可以实现.具体的看下帮助即可. 需要知道目录名称,设置即可. iis7+禁止执行php等 IIS7也类似于IIS6.0,选择站点对应的目录,data.uploads及静态html文件目录,双击功能试图面板中的"处理程序映射"(如图2) 在"编辑功能权限--"中,我们直接去除脚本的执行权限即可.(如图3) apache中一般是通过.htaccess文件来限制 A

随机推荐