Tomcat部署虚拟主机

使用Tomcat部署虚拟主机

使用Tomcat部署加密虚拟主机,实现以下要求:
实现两个基于域名的虚拟主机,域名分别为:www.a.com和 www.b.com
使用www.a.com域名访问的页面根路径为/usr/local/tomcat/a/ROOT
使用www.b.com域名访问的页面根路径为/usr/local/tomcat/b/base
访问www.a.com/test时,页面自动跳转到/var/www/html目录下的页面
访问页面时支持SSL加密通讯
私钥、证书存储路径为/usr/local/tomcat/conf/cert
每个虚拟主机都拥有独立的访问日志文件
配置tomcat集群环境

方案
修改server.xml配置文件,创建两个域名的虚拟主机,修改如下两个参数块:
# cat /usr/local/tomcat/conf/server.xml
<Server>
<Service>
<Connector port=8080 />
<Connector port=8009 />
<Engine name="Catalina" defaultHost="localhost">
<Host name="www.a.com" appBase="a" unpackWARS="true" autoDeploy="true">
</Host>
<Host name="www.b.com" appBase="b" unpackWARS="true" autoDeploy="true">
</Host>
… …
----------------------------------------------------------------------------------------------------------
xml格式

<name>
name=tom
sex=man
age=23
...
</name>

<man name=tom /> #短一点的描述信息可以直接写在里面
----------------------------------------------------------------------------------------------------------
常见错误:

不要复制在<Host>里面,应该复制在上面
要有结尾</Host>
不要修改原来的<Host nam=“localhost”...>
建目录a一定要在a下面写/ROOT,而且必须是大写的/ROOT
mkdir -p /usr/local/tomcat/a/ROOT/
在里面写页面
还要重启服务,关了再开
------------------------------------------------------------------------------------------------------------
步骤一:配置服务器虚拟主机

1)修改server.xml配置文件,创建虚拟主机

# vim /usr/local/tomcat/conf/server.xml
<Host name="www.a.com" appBase="a"
unpackWARs="true" autoDeploy="true">
</Host>
<Host name="www.b.com" appBase="b"
unpackWARs="true" autoDeploy="true">
</Host>

<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">

2)创建虚拟主机对应的页面根路径
# mkdir -p /usr/local/tomcat/a/ROOT
# mkdir -p /usr/local/tomcat/b/ROOT
# echo "AAA" > /usr/local/tomcat/a/ROOT/index.html
# echo "BBB" > /usr/local/tomcat/b/ROOT/index.html

3)重启Tomcat服务器
# /usr/local/tomcat/bin/shutdown.sh
# /usr/local/tomcat/bin/startup.sh
------------------------------------------------------------------------------------
4)客户端设置host文件,并浏览测试页面进行测试(proxy充当客户端角色)
注意:ssh远程连接时使用使用-X参数才可以!!!

# vim /etc/hosts
192.168.2.100 www.a.com www.b.com

# firefox http://www.a.com:8080 #注意访问的端口为8080
# firefox http://www.b.com:8080
-----------------------------------------------------------------------------------
步骤二:修改www.b.com网站的首页目录为base

使用docBase参数可以修改默认网站首页路径。网页目录变成/usr/local/tomcat/b/base

vim /usr/local/tomcat/conf/server.xml

<Host name="www.a.com" appBase="a"
unpackWARs="true" autoDeploy="true">
</Host>
<Host name="www.b.com" appBase="b"
unpackWARs="true" autoDeploy="true">
<Context path="" docBase="base" reloadable="true"/> #添加此行,工作时若不想加,默认网页目录还是b下面的ROOT。
</Host>

<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">

# mkdir /usr/local/tomcat/b/base
# echo "base" > /usr/local/tomcat/b/base/index.html
# /usr/local/tomcat/bin/shutdown.sh
# /usr/local/tomcat/bin/startup.sh

2)测试查看页面是否正确(proxy充当客户端角色)
# firefox http://www.b.com:8080 #b的页面变了,结果为base目录下的页面内容
base
# firefox http://www.a.com:8080 #a的页面没变
AAA
--------------------------------------------------------------------------------
步骤三:跳转

1)当用户访问http://www.a.com/test打开/var/www/html目录下的页面

<Host name="www.a.com" appBase="a"
unpackWARs="true" autoDeploy="true">
<Context path="/test" docBase="/var/www/html" reloadable="true"/> #不需要做/test,因为访问/test会调转。
</Host>
<Host name="www.b.com" appBase="b"
unpackWARs="true" autoDeploy="true">
<Context path="" docBase="base" reloadable="true"/>
</Host>

<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">

# echo "Test" > /var/www/html/index.html
# /usr/local/tomcat/bin/shutdown.sh
# /usr/local/tomcat/bin/startup.sh

2)测试查看页面是否正确(proxy充当客户端角色)
# http://www.a.com:8080/test/

出现的页面如下,之前配置http时把它首页的内容改成了这个。
192.168.2.100

#返回/var/www/html/index.html的内容。
注意,访问的端口为8080
------------------------------------------------------------------------------------------
配置文件里面的基本格式:

<Server>
<Service>
<Connector port=8080 />
<Connector port=8009 />
<Engine name="Catalina" defaultHost="localhost">
<Host name="www.a.com" appBse="a" unpackWARS="true" autoDeploy="true">
</Host>
<Host name="www.b.com" appBase="b" unpackWARS="true" autoDeploy="true">
</Host>
</Service>
</Server>
----------------------------------------------------------------------------------------------
步骤四:配置Tomcat支持SSL加密网站

1)创建加密用的私钥和证书文件

一些需要理解的字母含义:
-genkeypair #生成密钥对
-alias tomcat #密钥别名
-keyalg RSA #定义密钥算法为RSA算法
-keystore #定义密钥文件存储在:/usr/local/tomcat/keystore

# keytool -genkeypair -alias tomcat -keyalg RSA -keystore /usr/local/tomcat/keystore
会出现以下页面:

输入密钥库口令: # 提示输入密码为:123456
再次输入新口令:
您的名字与姓氏是什么?
[Unknown]: tom
您的组织单位名称是什么?
[Unknown]: a
您的组织名称是什么?
[Unknown]: b
您所在的城市或区域名称是什么?
[Unknown]: shenzhen
您所在的省/市/自治区名称是什么?
[Unknown]: guangdong
该单位的双字母国家/地区代码是什么?
[Unknown]: cn
CN=tom, OU=a, O=b, L=shenzhen, ST=guangdong, C=cn是否正确?
[否]: y #只写一个字母,不要写yes,否则会让你再重做一遍这些问题。

输入 <tomcat> 的密钥口令
(如果和密钥库口令相同, 按回车):
再次输入新口令:
----------------------------------------------------------------------------------------------
2)再次修改server.xml配置文件,创建支持加密连接的Connector

# vim /usr/local/tomcat/conf/server.xml

#备注,默认这段Connector被注释掉了,打开注释,添加密钥信息即可
修改前如下:
<!-- #这是它的注释,格式如此。要去掉
<Connector port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol"
maxThreads="150" SSLEnabled="true" scheme="https" secure="true"
clientAuth="false" sslProtocol="TLS" />
-->


修改后如下:
<Connector port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol"
maxThreads="150" SSLEnabled="true" scheme="https" secure="true"
keystoreFile="/usr/local/tomcat/keystore" keystorePass="123456" #在括号内添加添加此行,位置随意,和前后有空格就行
clientAuth="false" sslProtocol="TLS" />

3)重启Tomcat服务器
# /usr/local/tomcat/bin/shutdown.sh
# /usr/local/tomcat/bin/startup.sh

4)客户端如果设置了host文件,直接浏览测试页面进行测试(proxy充当客户端角色)
[root@proxy ~]# firefox https://www.a.com:8443
[root@proxy ~]# firefox https://www.b.com:8443
[root@proxy ~]# firefox https://192.168.2.100:8443

会提示你页面不安全,只要在高级连接里添加例外就可以了。
------------------------------------------------------------------------------------------------------------
步骤五:配置Tomcat日志

排错看catalina这个日志

1)为每个虚拟主机设置不同的日志文件
# vim /usr/local/tomcat/conf/server.xml

#从默认localhost虚拟主机中把Valve这段复制过来,适当修改下即可
复制localhost的模版,然后改第二行。

<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="wwwacom" suffix=".log" #修改此行,prefix=路径。suffix="文件扩展名(文件名也可不改)
pattern="%h %l %u %t &quot;%r&quot; %s %b" />

2)重启Tomcat服务器
# /usr/local/tomcat/bin/shutdown.sh
# /usr/local/tomcat/bin/startup.sh
------------------------------------------------------------------------------
客户端(proxy)访问后,日志文件里才会有内容
# firefox http://www.a.com:8080
----------------------------------------------------------------------------
3)查看服务器日志文件
# ls /usr/local/tomcat/logs/
# cat wwwacom.2018-11-05.log

出现日志内容:
192.168.2.5 - - [05/Nov/2018:15:57:22 +0800] "GET / HTTP/1.1" 200 4
192.168.2.5 - - [05/Nov/2018:15:57:28 +0800] "GET /favicon.ico HTTP/1.1" 404 1016
#这个报错正常,是浏览器跟网站要logo,我们没有。如果不想要报错,可以把local的默认logo文件复制过来,放到对应网站下。

# cp /usr/local/tomcat/webapps/ROOT/favicon.ico /usr/local/tomcat/a/ROOT/
192.168.2.5 - - [05/Nov/2018:16:16:32 +0800] "GET /favicon.ico HTTP/1.1" 200 21630 #有了logo,就不会报错了
------------------------------------------------------------------------------------------
步骤六:扩展实验(配置Tomcat集群)(此步骤未做实验!)

1) 在192.168.4.5主机上配置Nginx调度器(具体安装步骤参考前面的章节)

[root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
http{
upstream toms {
server 192.168.2.100:8080;
server 192.168.2.200:8080;
}
server {
listen 80;
server_name localhost;
location / {
proxy_pass http://toms;
}
}
}


2) 在192.168.2.100和192.168.2.200主机上配置Tomcat调度器

以下以Web1为例:
[root@web1 ~]# yum -y install java-1.8.0-openjdk //安装JDK
[root@web1 ~]# yum -y install java-1.8.0-openjdk-headless //安装JDK
[root@web1 ~]# tar -xzf apache-tomcat-8.0.30.tar.gz
[root@web1 ~]# mv apache-tomcat-8.0.30 /usr/local/tomcat

3)启动服务
[root@web1 ~]# /usr/local/tomcat/bin/startup.sh

4) 客户端验证
为了防止有数据缓存,可以使用真实主机的google-chrome访问代理服务器,输入Ctrl+F5刷新页面。

 

转载于:https://www.cnblogs.com/summer2/p/10787970.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值