16.4 配置Tomcat監聽80端口
首先確定80端口沒有被別的服務給佔用:如nginx、apache,如果被佔用了,需要想辦法把80端口給留出來
tomcat默認監聽的是8080端口
tomcat是支持自定義端口的,比如把8080改爲80端口
編輯配置文件vim /usr/local/tomcat/conf/server.xml, 搜索8080
[root@aiker src]# vim /usr/local/tomcat/conf/server.xml
<!--The connectors can use a shared executor, you can define one or more named thread pools-->
<!--
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
maxThreads="150" minSpareThreads="4"/>
-->
<!-- A "Connector" represents an endpoint by which requests are received
and responses are returned. Documentation at :
Java HTTP Connector: /docs/config/http.html
Java AJP Connector: /docs/config/ajp.html
APR (HTTP/AJP) Connector: /docs/apr.html
Define a non-SSL/TLS HTTP/1.1 Connector on port 8080
-->
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
<!-- A "Connector" using the shared thread pool-->
<!--
<Connector executor="tomcatThreadPool"
port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
-->
<!-- Define a SSL/TLS HTTP/1.1 Connector on port 8443
This connector uses the NIO implementation with the JSSE engine. When
67,58 39%
Connector port="8080" protocol="HTTP/1.1"修改爲Connector port="80" protocol="HTTP/1.1"
<Connector port="80" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
改完之後重啓服務,先shutdown 再startup
[root@aiker src]# /usr/local/tomcat/bin/shutdown.sh && /usr/local/tomcat/bin/startup.sh
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr/local/jdk1.8
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr/local/jdk1.8
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.
查看監聽端口:
[root@aiker src]# netstat -antp | grep java
tcp6 0 0 :::80 :::* LISTEN 5170/java
tcp6 0 0 127.0.0.1:8005 :::* LISTEN 5170/java
tcp6 0 0 :::8009 :::* LISTEN 5170/java
16.5/16.6/16.7 配置Tomcat虛擬主機
Apache和nginx都支持虛擬主機配置文件,虛擬主機配置文件一臺服務器上或者一個webserver上,支持一個IP下可以訪問多個域名,一個域名就代表一個網站,通過配置虛擬主機可以配置多個網站,每個網站都稱之爲一個虛擬主機,tomcat同樣也支持這個概念
開啓虛擬機
編輯配置文件
vim /usr/local/tomcat/conf/server.xml
搜索 Host
tomcat的配置文件格式爲 xml,語法是“<>開頭,</>結尾” 虛擬主機配置文件內容 其中<Host>和</Host>之間的配置爲虛擬主機配置部分,name定義域名, appBase定義應用的目錄,Java的應用通常是一個jar的壓縮包,你只需要將jar的壓縮包放到appBase目錄下面即可。剛剛阿銘訪問的Tomcat默認頁其實就是在appBase目錄下面,不過是在它子目錄ROOT裏。
下面進入這個配置文件server.xml,搜索host
<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">
<!-- SingleSignOn valve, share authentication between web applications
Documentation at: /docs/config/valve.html -->
<!--
<Valve className="org.apache.catalina.authenticator.SingleSignOn" />
-->
<!-- Access log processes all example.
Documentation at: /docs/config/valve.html Note: The pattern used is equivalent to using pattern="common" -->
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log" suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
</Host>
</Engine>
</Service></Server>
添加如下內容
<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">
<!-- SingleSignOn valve, share authentication between web applications
Documentation at: /docs/config/valve.html -->
<!--
<Valve className="org.apache.catalina.authenticator.SingleSignOn" />
-->
<!-- Access log processes all example.
Documentation at: /docs/config/valve.html Note: The pattern used is equivalent to using pattern="common" -->
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log" suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
</Host>
<Host name="www.123.cn" appBase=""
unpackWARs= "true" autoDeploy="true"
xmlValidation="false" xmlNamespaceAware="false">
<Context path="" docBase="/data/wwwroot/123.cn/" debug="0" reloadable="true" crossContext="true"/></Host>
</Engine>
[root@aiker ~]# vim /usr/local/tomcat/conf/server.xml
[root@aiker ~]#
docBase,這個參數用來定義網站的文件存放路徑,如果不定義,默認是在appBase/ROOT下面,定義了docBase就以該目錄爲主了,其中appBase和docBase可以一樣。在這一步操作過程中很多遇到過訪問404的問題,其實就是docBase沒有定義對。
appBase爲應用存放目錄,通常是需要把war包直接放到該目錄下面,它會自動解壓成一個程序目錄
下面我們通過部署一個java的應用來體會appBase和docBase目錄的作用
下載zrlog
wget http://dl.zrlog.com/release/zrlog-1.7.1-baaecb9-release.war
[root@aiker src]# wget
--2018-02-11 21:21:07--
正在解析主機 dl.zrlog.com (dl.zrlog.com)... 183.158.35.59
正在連接 dl.zrlog.com (dl.zrlog.com)|183.158.35.59|:80... 已連接。
已發出 HTTP 請求,正在等待迴應... 200 OK長度:7122027 (6.8M) [application/zip]
正在保存至: “zrlog-1.7.1-baaecb9-release.war”100%[===================================================>] 7,122,027
2.21MB/s 用時 3.1s 2018-02-11 21:21:11 (2.21 MB/s) -
已保存 “zrlog-1.7.1-baaecb9-release.war” [7122027/7122027])
[root@aiker ~]# du -sh zrlog-1.7.1-baaecb9-release.war
6.8M zrlog-1.7.1-baaecb9-release.war
appBase爲應用存放目錄(實際上是一個相對路徑,相對於 /usr/local/tomcat/ 路徑),通常是需要把war包直接放到該目錄下面,它會自動解壓成一個程序目錄 爲了方便測試,下載一個zrlog(java寫的blog站點應用,輕量),進行測試
appbase自動解壓war包
[root@aiker ~]# ls /usr/local/tomcat/webapps/
docs examples host-manager manager ROOT
[root@aiker ~]#
root@aiker ~]#
[root@aiker ~]#
[root@aiker ~]#
[root@aiker ~]# cp zrlog-1.7.1-baaecb9-release.war /usr/local/tomcat/webapps/
[root@aiker ~]# !lsls /usr/local/tomcat/webapps/
docs host-manager ROOT zrlog-1.7.1-baaecb9-release.war
examples manager zrlog-1.7.1-baaecb9-release
[root@aiker ~]#
把root下的 zrlog文件移到src目錄下
[root@aiker ~]# ls
1.txt anaconda-ks.cfg zrlog-1.7.1-baaecb9-release.war
[root@aiker ~]# mv zrlog-1.7.1-baaecb9-release.war /usr/local/src
[root@aiker ~]# ls
1.txt anaconda-ks.cfg
[root@aiker ~]# cd /usr/local/src
[root@aiker src]# rm -f /usr/local/tomcat/webapps/zrlog-1.7.1-baaecb9-release.war
[root@aiker src]# ls
apache-tomcat-8.5.8.tar.gz nginx-1.12.1apr-1.6.2 nginx-1.12.1.tar.gz
apr-1.6.2.tar.gz php-5.6.30apr-util-1.6.0 php-5.6.30.tar.gz
apr-util-1.6.0.tar.gz php-7.1.6httpd-2.4.27 php-7.1.6.tar.bz2
httpd-2.4.27.tar.gz phpredis-develop
jdk-8u101-linux-x64.tar.gz phpredis-develop.zip
logs zrlog-1.7.1-baaecb9-release.war
mysql-5.6.36-linux-glibc2.5-x86_64.tar.gz
[root@aiker src]#
剛剛把webapps目錄下的 zrlog 刪掉了,解壓的目錄頁跟着沒了,其實我們只是想刪包,留着目錄
[root@aiker src]# cd /usr/local/tomcat/webapps/
[root@aiker webapps]# lsdocs examples host-manager manager ROOT
[root@aiker webapps]#
再把它拷貝回來,再改下名字
[root@aiker webapps]# cp /usr/local/src/zrlog-1.7.1-baaecb9-release.war .
[root@aiker webapps]# ls
docs host-manager ROOT zrlog-1.7.1-baaecb9-release.war
examples manager zrlog-1.7.1-baaecb9-release
[root@aiker webapps]#
[root@aiker webapps]# mv zrlog-1.7.1-baaecb9-release zrlog
[root@aiker webapps]# ls
docs host-manager ROOT zrlog-1.7.1-baaecb9-release
examples manager zrlog zrlog-1.7.1-baaecb9-release.war
[root@aiker webapps]#
發現改完名字了,又自動生成一個 解壓文件了,只要war包存在,過會兒 又會自動生成一個解壓的文件
現在要訪問這個zrlog ,怎麼訪問呢,現在 就可以登錄站點,嘗試訪問了
會出來一個安裝嚮導,實際上就是讓我們去配置數據庫
之前也講過怎麼去創建一個用戶,創建一個庫
先來檢查下mysql服務有沒有啓動
[root@aiker webapps]# ps aux |grep mysql
root 2126 0.0 0.1 115392 1616 ? S 16:30 0:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/data/mysql --pid-file=/data/mysql/aiker.pid
mysql 2294 0.0 45.5 1300800 455660 ? Sl 16:30 0:10 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysql --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/data/mysql/aiker.err --pid-file=/data/mysql/aiker.pid --socket=/tmp/mysql.sock
root 4140 0.0 0.0 112684 980 pts/1 R+ 22:03 0:00 grep --color=auto mysql
[root@aiker webapps]#
有啓動的話就進mysql
[root@aiker webapps]# mysql -uroot -paiker123456
Warning: Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1Server version: 5.6.36 MySQL Community Server (GPL)
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trade of Oracle Corporation and/or its
affiliates. Other names may be trades of their respective
owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
創建數據庫
mysql> create database zrlog;Query OK, 1 row affected (0.00 sec)mysql>
再創建一個用戶
mysql> grant all on zrlog.* to 'zrlog'@127.0.0.1 identified by 'aiker123456';
Query OK, 0 rows affected (0.05 sec)mysql> mysql> mysql> quitBye
使用這個新創建的用戶登錄mysql,查看數據庫,只要有zrlog就ok
[root@aiker webapps]# mysql -uzrlog -h127.0.0.1 -paiker123456
Warning: Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2Server version: 5.6.36 MySQL Community Server (GPL)
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trade of Oracle Corporation and/or itsaffiliates. Other names may be trades of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
mysql> show databases;
+--------------------+| Database |
+--------------------+| information_schema |
| test |
| zrlog |
+--------------------+3 rows in set (0.03 sec)
mysql>
瀏覽器打開網址,填寫之前配置的信息
打開配置文件
[root@aiker webapps]# vim /usr/local/tomcat/conf/server.xml
<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">
<!-- SingleSignOn valve, share authentication between web applications
Documentation at: /docs/config/valve.html -->
<!--
<Valve className="org.apache.catalina.authenticator.SingleSignOn" />
-->
<!-- Access log processes all example.
Documentation at: /docs/config/valve.html Note: The pattern used is equivalent to using pattern="common" -->
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log" suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
</Host>
<Host name="www.123.cn" appBase=""
unpackWARs= "true" autoDeploy="true"
xmlValidation="false" xmlNamespaceAware="false">
<Context path="" docBase="/data/wwwroot/123.cn/" debug="0" reloadable="true" crossContext="true"/></Host>
</Engine>
測試用docBase指定路徑,訪問是否生效,前面做了新增虛擬機配置,自然就需要生成對應的目錄
mkdir /data/wwwroot/123.cn/
將之前的zrlog的文件移動到當前目錄下
[root@aiker webapps]# vim /usr/local/tomcat/conf/server.xml
[root@aiker webapps]# mkdir /data/wwwroot/123.cn
[root@aiker webapps]# mv /usr/local/tomcat/webapps/zrlog/admin/ error/ include/ META-INF/
assets/ favicon.ico install/ WEB-INF/
[root@aiker webapps]# mv /usr/local/tomcat/webapps/zrlog/* /data/wwwroot/123.cn/
[root@aiker webapps]#
[root@aiker webapps]#
[root@aiker webapps]#
用windows測試下
重啓服務,之前修改了配置文件,新增了虛擬主機,但並沒有重啓,所以沒有及時生效
[root@aiker webapps]# /usr/local/tomcat/bin/shutdown.sh
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr/local/jdk1.8
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
[root@aiker webapps]# /usr/local/tomcat/bin/startup.sh
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr/local/jdk1.8Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.
[root@aiker webapps]#
[root@aiker webapps]# netstat -lntp |grep 80
tcp6 0 0 :::80 :::* LISTEN 4322/java
tcp6 0 0 127.0.0.1:8005 :::* LISTEN 4322/java
tcp6 0 0 :::8009 :::* LISTEN 4322/java
[root@aiker webapps]#
[root@aiker webapps]# pwd/usr/local/tomcat/webapps
[root@aiker webapps]#
把www.123.cn 綁定windows hosts
再去瀏覽器訪問www.123.cn
16.8 Tomcat日誌
ls /usr/local/tomcat/logs
[root@aiker webapps]# ls /usr/local/tomcat/logs/
catalina.2018-02-11.log host-manager.2018-02-11.log localhost_access_log.2018-02-11.txt
catalina.out manager.2018-02-11.log
其中catalina開頭的日誌爲Tomcat的綜合日誌,它記錄Tomcat服務相關信息,也會記錄錯誤日誌。
其中catalina.2018-xx-xx.log和catalina.out內容相同,前者會每天生成一個新的日誌。
host-manager和manager爲管理相關的日誌,其中host-manager爲虛擬主機的管理日誌。
localhost和localhost_access爲虛擬主機相關日誌,其中帶access字樣的日誌爲訪問日誌,不帶access,字樣的爲默認虛擬主機的錯誤日誌。
訪問日誌默認不會生成,需要在server.xml中配置一下。
具體方法是在對應虛擬主機的<Host></Host>裏面加入下面的配置(假如域名爲www.123.cn):
</Host>
<Host name="www.123.cn" appBase=""
unpackWARs= "true" autoDeploy="true"
xmlValidation="false" xmlNamespaceAware="false">
<Context path="" docBase="/data/wwwroot/123.cn/" debug="0" reloadable="true" crossContext="true"/>
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="www.123.cn_access_log" suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
prefix定義訪問日誌的前綴,suffix定義日誌的後綴,pattern定義日誌格式。新增加的虛擬主機默認並不會生成類似默認虛擬主機的那個localhost.日期.log日誌,錯誤日誌會統一記錄到catalina.out中。關於Tomcat日誌,你最需要關注catalina.out,當出現問題時,我們應該第一想到去查看它。
[root@aiker webapps]# less /usr/local/tomcat/logs/www.123.cn_access_log.2018-03-17.txt
172.16.58.8 - - [11/Feb/2018:20:34:51 +0800] "GET /post/first HTTP/1.1" 200 12668
172.16.58.8 - - [11/Feb/2018:20:34:51 +0800] "GET /assets/css/video-js.css HTTP/1.1" 304 -
172.16.58.8 - - [11/Feb/2018:20:34:51 +0800] "GET /include/templates/default/css/style.css HTTP/1.1" 304 -
172.16.58.8 - - [11/Feb/2018:20:34:51 +0800] "GET /include/templates/default/css/editormd.css HTTP/1.1" 304 -
172.16.58.8 - - [11/Feb/2018:20:34:51 +0800] "GET /include/templates/default/js/lib/jquery-1.10.2.min.js HTTP/1.1" 304 -
172.16.58.8 - - [11/Feb/2018:20:34:51 +0800] "GET /include/templates/default/js/lib/modernizr.min.js HTTP/1.1" 304 -
擴展
邱李的tomcat文檔
https://www.linuser.com/forum.php?mod=forumdisplay&fid=37
JAR、WAR包區別
Jar、war、EAR、在文件結構上,三者並沒有什麼不同,它們都採用zip或jar檔案文件壓縮格式。但是它們的使用目的有所區別:
Jar文件(擴展名爲. Jar,Java Application Archive)包含Java類的普通庫、資源(resources)、輔助文件(auxiliary files)等
War文件(擴展名爲.War,Web Application Archive)包含全部Web應用程序。在這種情形下,一個Web應用程序被定義爲單獨的一組文件、類和資源,用戶可以對jar文件進行封裝,並把它作爲小型服務程序(servlet)來訪問。
Ear文件(擴展名爲.Ear,Enterprise Application Archive)包含全部企業應用程序。在這種情形下,一個企業應用程序被定義爲多個jar文件、資源、類和Web應用程序的集合。
每一種文件(.jar, .war, .ear)只能由應用服務器(application servers)、小型服務程序容器(servlet containers)、EJB容器(EJB containers)等進行處理。
EAR文件包括整個項目,內含多個ejb module(jar文件)和web module(war文件)
EAR文件的生成可以使用winrar zip壓縮方式或者jar命令。
步驟:
先打包成war和jar,並寫好application.xml,放到META-INF目錄下,然後 jar cf your_application.ear your_war.war your_jar.jar META-INF/application.xml, 打包,我這假設都在當前目錄下 可以用 jar xf your_application.ear解壓
application.xml中描述你的ear中包括的war和jar (上篇文章已經提到)
jboss中 的application.xml例子
<span style="font-size:18px;"><span style="font-size:18px;"><?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE application PUBLIC
"-//Sun Microsystems, Inc.//DTD J2EE Application 1.3//EN"
"http://java.sun.com/dtd/application_1_3.dtd">
<application>
<display-name>lishehetestear</display-name>
<module>
<java>lishehe_api-0.0.1-SNAPSHOT.jar</java>
</module>
<module>
<java>lishehe_core-0.0.1-SNAPSHOT.jar</java>
</module>
<module>
<web>
<web-uri>lishehe_war-0.0.1-SNAPSHOT.war</web-uri>
<context-root>/lishehe_war</context-root>
</web>
</module>
</application></span></span>
WAR的使用:
如果想生成war文件:可以使用如下命令:jar -cvf web1.war *
如果想查看web1.war中都有哪些文件,可以使用命令:jar -tf web1.war
如果想直接解壓web1.war文件,可以使用命令:jar -xvf web1.war
另外,也可使用winrar軟件選擇zip壓縮方式,並將壓縮文件後綴名改爲war即可壓縮生成war文件;同樣使用winrar軟件可以強行打開war文件,或者強行解壓war文件
使用jar命令與winrar軟件的區別在於前者在壓縮文件的同時會生成MetaINF文件夾,內包含MANIFEST.MF文件。
總結:
何時使用war或者jar文件:當你的項目在沒有完全竣工的時候,不適合使用war文件,因爲你的類會由於調試之類的經常改,這樣來回刪除、創建war文件很不爽,最好是你的項目已經完成了,不改了,那麼就打個war包吧,這個時候一個war文件就相當於一個web應用程序鳥;而jar文件就是把類和一些相關的資源封裝到一個包中,便於程序中引用。
tomcat常見配置彙總
http://blog.sina.com.cn/s/blog_4ab26bdd0100gwpk.html
啓動內存參數的配置tomcat/bin/catalina.bat
如果是linux 就是 catalina.sh
在rem 的後面增加如下參數
set JAVA_OPTS= -Xms256m -Xmx256m -XX:MaxPermSize=64m
2 修改Tomcat的JDK目錄
打開tomcat/bin/catalina.bat
在最後一個rem後面增加
set JAVA_HOME=C:\Program Files\Java\jdk1.6.0
3 增加虛擬目錄
/tomcat/conf/server.xml
第一行是以前默認存在的,第二行是新增的
<Context path="" docBase="ROOT" debug="0" reloadable="true"></Context>
<Context path="/jsp/a" reloadable="true" docBase="E:\workplace\www.java2000.net\WebContent" />
4 GET方式URL亂碼問題解決
打開 tomcat/conf/server.xml
查找下面這部分,在最後增加一段代碼就可以了。
<Connector port="80" maxHttpHeaderSize="8192"
.................
URIEncoding="UTF-8" useBodyEncodingForURI="true"
...............
/>
其中的UTF-8 請根據你的需要自己修改,比如GBK
5 虛擬主機配置文件
tomcat/conf/server.xml
<!-- 默認的主機 -->
<Host name="localhost" appBase="webapps"
unpackWARs="true"
xmlValidation="false" xmlNamespaceAware="false">
<Context path="" docBase="ROOT" debug="0" reloadable="true"></Context>
...
</host>