<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
有用Tomcat的,絕對都會遇到這樣一個問題:catalina.out檔案過大。
它是Tomcat預設生成的紀錄檔檔案,會隨著時間的推移,逐漸增大,不斷的增長,甚至達到幾G,幾十G的大小。由於檔案過大,不僅佔系統的儲存,我們還將無法使用過常規的編輯工具進行檢視,嚴重影響系統的維護工作。
對此,出現了以下幾種解決catalina.out檔案過大的方案。
除非不需要紀錄檔,否則不建議使用
1.手動版
每次監控到tomcat的硬碟空間變小達到閾值,手動登陸伺服器,切換到tomcat的logs下,手動清空
echo " " > catalina.out
2.指令碼版
編寫指令碼,放入計劃任務中,定時清空
crontab -e 0 24 * * * sh /root/qin_catalina.out.sh vim qin_catalina.out.sh #!/usr/bin/bash echo " " > catalina.out
1.紀錄檔切割工具版0.1
使用cronolog紀錄檔切分工具切分Tomcat的catalina.out紀錄檔檔案
<1>下載cronolog,並進行安裝
wget http://cronolog.org/download/cronolog-1.6.2.tar.gz (中國伺服器可能無法下載或下載緩慢,可先下載到境外伺服器上) tar zxvf cronolog-1.6.2.tar.gz ./cronolog-1.6.2/configure make make install (預設安裝在/usr/local/sbin下)
<2>.設定
在tomcat/bin/catalian.sh中
org.apache.catalina.startup.Bootstrap "$@" start >> "$CATALINA_BASE"/logs/catalina.out 2&1 & 改成: org.apache.catalina.startup.Bootstrap"$@" start |/usr/local/sbin/cronolog "$CATALINA_BASE"/logs/catalina.%Y-%m-%d.out >> /dev/null 2>&1 & 或 org.apache.catalina.startup.Bootstrap "$@" start 2>&1 | /usr/local/sbin/cronolog "$CATALINA_BASE"/logs/catalina.%Y-%m-%d.out >> /dev/null & 並註釋 touch "$CATALINA_OUT"
<3>重啟Tomcat
Tomcat輸出紀錄檔檔案分割成功,輸出log檔案格式變為:catalina.2017-05-15.out
1.紀錄檔切割工具版0.2
CentOS6.5後自帶logrotate程式,可以解決catalina.out的紀錄檔輪轉問題
<1>在/etc/logrotate.d/目錄下新建一個tomcat的檔案
cat >/etc/logrotate.d/tomcat /usr/local/tomcat/logs/catalina.out{ 要輪轉的檔案 copytruncate 建立新的catalina.out副本,截斷源catalina.out檔案 daily 每天進行catalina.out檔案的輪轉 rotate 7 至多保留7個副本 missingok 檔案丟失了,輪轉不報錯 compress 使用壓縮 size 500M 當catalina.out檔案大於16MB,就輪轉 }
其他引數:
compress 通過gzip 壓縮轉儲以後的紀錄檔
nocompress 不做gzip壓縮處理
copytruncate 用於還在開啟中的紀錄檔檔案,把當前紀錄檔備份並截斷;是先拷貝再清空的方式,拷貝和清空之間有一個時間差,可能會丟失部分紀錄檔資料。
nocopytruncate 備份紀錄檔檔案不過不截斷
create mode owner group 輪轉時指定建立新檔案的屬性,如create 0777 nobody nobody
nocreate 不建立新的紀錄檔檔案
delaycompress 和compress 一起使用時,轉儲的紀錄檔檔案到下一次轉儲時才壓縮
nodelaycompress 覆蓋 delaycompress 選項,轉儲同時壓縮。
missingok 如果紀錄檔丟失,不報錯繼續捲動下一個紀錄檔
errors address 專儲時的錯誤資訊傳送到指定的Email 地址
ifempty 即使紀錄檔檔案為空檔案也做輪轉,這個是logrotate的預設選項。
notifempty 當紀錄檔檔案為空時,不進行輪轉
mail address 把轉儲的紀錄檔檔案傳送到指定的E-mail 地址
nomail 轉儲時不傳送紀錄檔檔案
olddir directory 轉儲後的紀錄檔檔案放入指定的目錄,必須和當前紀錄檔檔案在同一個檔案系統
noolddir 轉儲後的紀錄檔檔案和當前紀錄檔檔案放在同一個目錄下
sharedscripts 執行postrotate指令碼,作用是在所有紀錄檔都輪轉後統一執行一次指令碼。如果沒有設定這個,那麼每個紀錄檔輪轉後都會執行一次指令碼
prerotate 在logrotate轉儲之前需要執行的指令,例如修改檔案的屬性等動作;必須獨立成行
postrotate 在logrotate轉儲之後需要執行的指令,例如重新啟動 (kill -HUP) 某個服務!必須獨立成
daily 指定轉儲週期為每天
weekly 指定轉儲週期為每週
monthly 指定轉儲週期為每月
rotate count 指定紀錄檔檔案刪除之前轉儲的次數,0 指沒有備份,5 指保留5 個備份
dateext 使用當期日期作為命名格式
dateformat .%s 配合dateext使用,緊跟在下一行出現,定義檔案切割後的檔名,必須配合dateext使用,只支援 %Y %m %d %s 這四個引數
size(或minsize) log-size 當紀錄檔檔案到達指定的大小時才轉儲,log-size能指定bytes(預設)及KB (sizek)或
<2>當執行以上操作時是自動執行的,也可手動切割
logrotate /etc/logrotate.conf
如果只輪轉tomcat組態檔,要指定檔案
logrotate --force /etc/logrotate.d/tomcat
<3>刪除要清理的紀錄檔
手工查詢需要清理的紀錄檔檔案
cd /usr/local/tomcat/logs rm -rf catalina.out.4.gz
2.紀錄檔切割指令碼版
使用cron每天來定時備份當前的catalina.out,然後清空他的內容;
<1>crontab -e
01 0 * * * sh /root/qie_catalina.out.sh
<2>cat qie_catalina.out.sh 參考指令碼
#!/bin/bash DATE=`date "+%Y-%m-%d"` cp /etc/tomcat/logs/catalina.out /etc/tomcat/logs/`catalina.out.$DATE` wait echo " " > catalina.out
3.修改紀錄檔級別版
紀錄檔級別:
SEVERE (highest value) > WARNING > INFO > CONFIG > FINE > FINER > FINEST (lowest value)
<1>修改conf/logging.properties紀錄檔組態檔,將level級別設定成WARNING減少紀錄檔的輸出。也可以設定成OFF,直接禁用。
catalina.org.apache.juli.FileHandler.level = WARNING catalina.org.apache.juli.FileHandler.directory = ${catalina.base}/logs catalina.org.apache.juli.FileHandler.prefix = catalina.
到此這篇關於Tomcat解決catalina.out檔案過大的問題的文章就介紹到這了,更多相關Tomcat catalina.out檔案過大內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45