Windows安装nginx-1.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站点

时间: 2024-09-28 14:43:47

Windows安装nginx-1.10.1反向代理访问IIS网站的相关文章

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

首先去官网下载软件包,解压,路径最好不要有中文 Nginx配置的路径问题 由于在Windows下文件路径可以用"\", 也可以用"\\", 也可以用"/"作为路径做分隔符.但"\"最容易引发问题,所以要尽量避免使用. 不要添加PATH,否则会引发错误,config文件路径找不到 比如我解压在E盘 cmd命令定位到nginx.exe所在文件夹cd E:\WorkSoftWare\nginx-1.10.1 然后执行,首先保证ngi

windows安装nginx部署步骤图解(反向代理与负载均衡)_nginx

一.下载安装Nginx(本文环境为windows xp 32bit环境) 解压nginx-1.0.11.zip,进入nginx-1.0.11,在命令行中执行命令让Nginx启动.具体操作如下图: 测试是否安装成功,输入地址:http://localhost:8090 浏览器显示结果如下图: OK,Nginx部署成功了. 二.关于Nginx的反向代理配置. 反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器

如何在 FreeBSD 10.2 上安装 Nginx 作为 Apache 的反向代理

如何在 FreeBSD 10.2 上安装 Nginx 作为 Apache 的反向代理 Nginx 是一款自由开源的 HTTP 和反向代理服务器,也可以用作 POP3/IMAP 的邮件代理服务器.Nginx 是一款高性能的 web 服务器,其特点是功能丰富,结构简单以及内存占用低. 第一个版本由 Igor Sysoev 发布于2002年,到现在有很多大型科技公司在使用,包括 Netflix. Github. Cloudflare. WordPress.com 等等. 在这篇教程里我们会"在 fre

如何阻止网站被恶意反向代理访问(防网站镜像)_php技巧

什么是反向代理? 先说说正向代理的概念: 正向代理,也就是传说中的代理,他的工作原理就像一个跳板.简单的说,我是一个用户,我访问不了某网站,但是我能访问一个代理服务器.这个代理服务器呢,他能访问那个我不能访问的网站,于是我先连上代理服务器,告诉他我需要那个无法访问网站的内容,代理服务器去取回来,然后返回给我.从网站的角度,只在代理服务器来取内容的时候有一次记录,有时候并不知道是用户的请求,也隐藏了用户的资料,这取决于代理告不告诉网站. 结论就是,正向代理是一个位于客户端和原始服务器(origin

Ubuntu14编译安装Nginx同时配置Google反向代理 + SSL 证书

在看这篇文章之前,首先你得准备一台墙外的服务器或 VPS,本文默认用 root 用户,并操作在系统的 /root 目录下,为了安全考虑,请自行更换目录. 一.编译安装 Nginx 1.首先更新下系统 sudo apt-get update && sudo apt-get upgrade 2.安装的 Nginx 需要的包以及 Git sudo apt-get install libpcre3 libpcre3-dev zlib1g-dev libssl-dev build-essential

debian+nginx+php环境实现反向代理和负载均衡教程

配置nginx的PHP环境 安装nginx     sudo apt-get install nginx 安装nginx就可以通过下面地址来访问了:http://localhost/ 安装php     sudo apt-get install php5-cli php5-cgi php5-fpm php5-mcrypt php5-fpm:与nginx配合方式之一,另外个是:spawn-fcgi. 配置nginx的虚拟主机 在/etc/nginx/sites-available/default中

CentOS 7.2安装Nginx 1.10.2的详细教程_Linux

一.使用Yum安装(推荐) 使用Yum安装是推荐的方式,整体的流程非常的简单,也不容易出错,如果不需要什么特殊配置,建议使用Yum尽进行安装. 1.安装epel-release源并进行安装 yum install epel-release yum update yum install nginx 2.执行相关的应用操作 systemctl start nginx #启动 systemctl stop nginx #停止 systemctl restart nginx #重启 systemctl

如何阻止网站被恶意反向代理访问

 最近有人用小站数据,利用反向代理技术,做了个小偷站.用户访问的是他的网址,但实质上内容数据确是我的,这是一起恶意反向代理事件 什么是反向代理?    先说说正向代理的概念:    正向代理,也就是传说中的代理,他的工作原理就像一个跳板.简单的说,我是一个用户,我访问不了某网站,但是我能访问一个代理服务器.这个代理服务器呢,他能访问那个我不能访问的网站,于是我先连上代理服务器,告诉他我需要那个无法访问网站的内容,代理服务器去取回来,然后返回给我.从网站的角度,只在代理服务器来取内容的时候有一次记

CentOS中nginx负载均衡和反向代理的搭建

1: 修改centos命令行启动(减少内存占用): vim /etc/inittab     id:5:initdefault:  --> 修改5为3  若要界面启动使用 startx 2:安装jdk 1)解压:jdk-7u55-linux-i586.tar.gz        [root@localhost jdk]# tar -zxvf jdk-7u55-linux-i586.tar.gz 2)复制:[root@localhost jdk]# cp -rf jdk1.7.0_55/ /usr