• (转)IIS tomcat共用80端口解决一个IP多个域名:使用Nginx反向代理方式使两者兼容


    from :http://www.cnblogs.com/wuyou/p/3455619.html

    环境:

    windows server 2003,IIS6服务器,Tomcat7服务器

    域名有几个:

    以下是使用IIS的域名:

    http://www.formuch.com/

    http://www.formuch.cn/

    http://www.formuch.net/

    要使用Tomcat的域名:http://www.huilianvisa.com/      http://huilianvisa.com/

    问题:

    该台VPS里面已经有好几个网站了(上面已给出),但是都是用IIS挂起来的。而我们开发了一个J2EE架构的网站,使用tomcat作为服务器。大家都知道,IIS既然已经用了80端口,那我的tomcat就不能用80端口了。这样一来,我们J2EE的网站必须在域名后加上8080作为域名了(http://www.huilianvisa.com:8080/),这显然不符合要求。

    于是我从网上寻找资料,他们一部分人用的是 IIS与Tomcat的桥接器 解决问题的,但是我操作了几个小时都没有解决,于是我寻找另外一个解决方案,后来想到Nginx有一个反向代理的功能,能将请求转发到本地的另外一些服务器。于是问题的解决方案为:使用Nginx反向代理方式使IIS和Tomcat兼容起来。

     

    步骤:

    首先确认tomcat和IIS两个服务器没有准确无误的运行起来。

    下载Nginx,版本只要在1.1以上基本都行。

    ①修改IIS的所有网站项目的端口,修改为81(只要不是80和跟其他端口不冲突都可),因为我们的nginx服务器要占用80端口。

     

    ②设置tomcat的配置文件:server.xml,打开:

    重点在于配置红色部分:包含端口(82),监听的域名。(这里我已经把注释全去掉了,省事,这是整个server.xml文件)

    <?xml version='1.0' encoding='utf-8'?>

     

    <Server port="8005" shutdown="SHUTDOWN">

     

      <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />

      <Listener className="org.apache.catalina.core.JasperListener" />

      <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />

      <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />

      <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />

     

      <GlobalNamingResources>

     

        <Resource name="UserDatabase" auth="Container"

                  type="org.apache.catalina.UserDatabase"

                  description="User database that can be updated and saved"

                  factory="org.apache.catalina.users.MemoryUserDatabaseFactory"

                  pathname="conf/tomcat-users.xml" />

      </GlobalNamingResources>

     

      <Service name="Catalina">

     

        <Connector port="82" protocol="HTTP/1.1"

                   connectionTimeout="20000"

                   redirectPort="8443" URIEncoding="UTF-8" />

     

     

        <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

     

     

        <Engine name="Catalina" defaultHost="www.huilianvisa.com">

     

          <Realm className="org.apache.catalina.realm.LockOutRealm">

     

            <Realm className="org.apache.catalina.realm.UserDatabaseRealm"

                   resourceName="UserDatabase"/>

          </Realm>

     

          <Host name="www.huilianvisa.com"  appBase="webapps"

                unpackWARs="true" autoDeploy="true">

     

            <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"

                   prefix="localhost_access_log." suffix=".txt"

                   pattern="%h %l %u %t "%r" %s %b" />

     

    <Context path = "" docBase = "d:/website/hlcg_war_exploded"  />

     

          </Host>

        </Engine>

      </Service>

    </Server>

     

     

    ③来到nginx的conf目录,打开nginx.conf,对里面修改如下:

    (这里主要是添加转发的域名,对于IIS我们全转发到对应域名加上81端口,对于tomcat的我们全加上82端口,其中Nginx监听80端口)

     

    #user  nobody;

    worker_processes  1;

     

    #error_log  logs/error.log;

    #error_log  logs/error.log  notice;

    #error_log  logs/error.log  info;

     

    #pid        logs/nginx.pid;

     

     

    events {

        worker_connections  1024;

    }

     

     

    http {

        include       mime.types;

        default_type  application/octet-stream;

     

        #access_log  logs/access.log  main;

     

        sendfile        on;

        #tcp_nopush     on;

     

        keepalive_timeout  65;

     

        #gzip  on;

     

    #这里是影院网站

     

        server {

            listen       80;

            server_name  www.formuch.com;

     

            location / {

           proxy_pass   http://www.formuch.com:81;

            }

     

        }

     

        server {

            listen       80;

            server_name  www.formuch.net;

     

            location / {

           proxy_pass   http://www.formuch.net:81;

            }

        }

     

        server {

            listen       80;

            server_name  www.formuch.cn;

     

            location / {

           proxy_pass   http://www.huilianvisa.com:81;

            }

        }

     

        server {

            listen       80;

            server_name  www.huilianvisa.com;

     

            location / {

           proxy_pass   http://www.huilianvisa.com:82;

            }

        }

     

        server {

            listen       80;

            server_name  huilianvisa.com;

     

            location / {

           proxy_pass   http://www.huilianvisa.com:82;

            }

        }

    }

     

    Listen:Nginx监听的端口(80),这里不要改

    server_name:Nginx监听的域名。

    proxy_pass:要转发到的地址。

    ④打开IIS服务器,再打开Tomcat服务器,再打开Nginx服务器,访问对应的域名,即Nginx配置中的server_name,记得不需要加端口!因为Nginx会帮你访问这些网站。

    整个配置就完成了。

  • 相关阅读:
    Java内存模型(JMM)
    线程安全问题的本质详解: 原子性、有序性、可见性
    Quartz实现分布式可动态配置的定时任务
    Java引用详解-StrongReference SoftReference WeakReference PhantomReference
    流行的报表生成工具-JXLS
    Java线程监控及中断
    IntelliJ IDEA 内存优化最佳实践
    Dapeng框架-开源高性能分布式微服务框架
    Scala实现Try with resources自动关闭IO
    Jvm启动,关闭及对应钩子
  • 原文地址:https://www.cnblogs.com/94cool/p/3927079.html
Copyright © 2020-2023  润新知