我是靠谱客的博主 小巧烧鹅,最近开发中收集的这篇文章主要介绍(转)IIS tomcat共用80端口解决一个IP多个域名:使用Nginx反向代理方式使两者兼容...,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

环境:

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会帮你访问这些网站。

整个配置就完成了。




本文转自94cool博客园博客,原文链接:http://www.cnblogs.com/94cool/p/3927079.html,如需转载请自行联系原作者

最后

以上就是小巧烧鹅为你收集整理的(转)IIS tomcat共用80端口解决一个IP多个域名:使用Nginx反向代理方式使两者兼容...的全部内容,希望文章能够帮你解决(转)IIS tomcat共用80端口解决一个IP多个域名:使用Nginx反向代理方式使两者兼容...所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(46)

评论列表共有 0 条评论

立即
投稿
返回
顶部