当前位置: 首页 > 编程笔记 >

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

易嘉胜
2023-03-14
本文向大家介绍Windows安装nginx1.10.1反向代理访问IIS网站,包括了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站点



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

 类似资料:
  • 我有一个RestHighLevelClient连接到一个远程elasticDB,它位于一个反向代理后面,该代理剥离了ssl。 当我打电话的时候 我得到一个握手失败的例外 正如这里和这里所描述的,我检查了日志,发现了ClientHello 服务员:你好 客户端和服务器都同意密码套件TLS_ECDHE_RSA_和_AES_128_GCM_SHA256 然后以加密和纯文本的形式跟踪请求。然后是另一个Cl

  • 为了处理微服务体系结构,它经常与反向代理(如nginx或apache httpd)一起使用,对于交叉关注点的实现,使用API网关模式。有时反向代理做API网关的工作。 看到这两种方法之间的明确区别将是很好的。使用API网关的潜在好处是调用多个微服务并聚合结果。API网关的所有其他职责都可以使用反向代理实现。例如: 身份验证(可以使用nginx LUA脚本完成); 传输安全性。它本身反向代理任务;

  • 什么是反向代理 反向代理(Reverse Proxy)方式是指用代理服务器来接受 internet 上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给 internet 上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。 举个例子,一个用户访问 http://www.example.com/readme,但是 www.example.com 上并不存在

  • 反向代理是一个 V2Ray 的附加功能,可以把服务器端的流量向客户端转发,即逆向流量转发。 反向代理功能在 V2Ray 4.0+ 可用。目前处于测试阶段,可能会有一些问题。 反向代理的大致工作原理如下: 假设在主机 A 中有一个网页服务器,这台主机没有公网 IP,无法在公网上直接访问。另有一台主机 B,它可以由公网访问。现在我们需要把 B 作为入口,把流量从 B 转发到 A。 在主机 A 中配置一

  • 本文向大家介绍Windows 2012 安装IIS和FTP的方法,包括了Windows 2012 安装IIS和FTP的方法的使用技巧和注意事项,需要的朋友参考一下  相信微软的Windows Server 2012,对部分用户而言都是崭新的面孔,而关于其在服务器上应用的专业技术文档更是少之又少。         护卫神经过整理,逐步将新技术授予广大用户,希望对大家的发展添砖加瓦……言归正传,当前使

  • 本文向大家介绍CentOS 7.2.1511 编译安装Nginx1.10.1+MySQL5.7.14+PHP7.0.11,包括了CentOS 7.2.1511 编译安装Nginx1.10.1+MySQL5.7.14+PHP7.0.11的使用技巧和注意事项,需要的朋友参考一下 准备篇 一、防火墙配置 CentOS 7.x默认使用的是firewall作为防火墙,这里改为iptables防火墙。 1、关