本篇文章為大家展示了squid的日志rotate問題怎么解決,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
創(chuàng)新互聯(lián)建站是一家集網(wǎng)站建設(shè),易門企業(yè)網(wǎng)站建設(shè),易門品牌網(wǎng)站建設(shè),網(wǎng)站定制,易門網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,易門網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
Squid不斷的寫日志,假如cache非常忙,那么在一段時間后,這些日志文件可能變得很大。某些操作系統(tǒng)甚至限制了文件的最大size(例如2G),假如寫文件超過了這個size就會報錯。為了保持日志文件容易管理,以及讓Squid正常工作,必須定期輪轉(zhuǎn)日志。
Squid有內(nèi)建的功能用于輪轉(zhuǎn)日志??赏ㄟ^squid -k rotate命令來調(diào)用它,然后告訴Squid對每個日志文件保持多少份舊拷貝。例如,假如設(shè)置它為7,對每個日志文件會有8個版本:1個當(dāng)前的,和7個舊的。
舊日志文件以數(shù)字?jǐn)U展來重命名。例如,當(dāng)執(zhí)行一次輪轉(zhuǎn)時,Squid重命名log.6到log.7,然后是log.5到log.6,依此類推。當(dāng)前l(fā)og變成log.0,并且Squid創(chuàng)建一個新的空文件,命名為log。
啟動squid后,每次執(zhí)行squid -k rotate時,Squid輪轉(zhuǎn)下述文件:cache.log, access.log, store.log, useragent.log (假如激活), 以及referer.log (假如激活)。Squid也會創(chuàng)建最新版本的swap.state文件。然而請注意,swap.state不會以數(shù)字?jǐn)U展形式來輪轉(zhuǎn)。
Squid不會自己輪轉(zhuǎn)日志,最好的辦法是在crontab里自動執(zhí)行。例如:
0 0 * * * /usr/local/squid/sbin/squid -k rotate
補: 0 0 * * 1 /usr/local/squid/sbin/squid -f /usr/local/squid/etc/squid.conf.external -k rotate > /dev/null 2>&1 0 0 * * 1 /usr/local/squid/sbin/squid -f /usr/local/squid/etc/squid.conf.internal -k rotate > /dev/null 2>&1 0 0 * * 1 /usr/local/squid/sbin/squid -f /usr/local/squid/etc/squid.conf.reverse -k rotate > /dev/null 2>&1
假如你想編寫自己的腳本來管理日志文件,Squid提供了一個有用的模式,簡單的設(shè)置logfile_rotate指令為0。這樣,當(dāng)你運行squid -k rotate命令時,Squid簡單的關(guān)閉當(dāng)前日志文件,并且打開新的。如果操作系統(tǒng)允許重命名被其他進程打開的文件,則這點非常有用。下述shell腳本描述了一個思路:
#!/bin/sh set -e yesterday_secs=`perl -e 'print time -43200'` yesterday_date=`date -r $yesterday_secs +%Y%m%d` cd /usr/local/squid/var/logs # rename the current log file without interrupting the logging process mv access.log access.log.$yesterday_date # tell Squid to close the current logs and open new ones /usr/local/squid/sbin/squid -k rotate # give Squid some time to finish writing swap.state files sleep 60 mv access.log.$yesterday_date /archive/location/ gzip -9 /archive/location/access.log.$yesterday_date
上述內(nèi)容就是squid的日志rotate問題怎么解決,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
本文題目:squid的日志rotate問題怎么解決
當(dāng)前地址:http://www.rwnh.cn/article6/igehog.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、App開發(fā)、做網(wǎng)站、網(wǎng)站收錄、自適應(yīng)網(wǎng)站、標(biāo)簽優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)