国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

tomcat的安裝和自動化thread線程快照

IT那活兒 / 3438人閱讀
tomcat的安裝和自動化thread線程快照

點擊上方“IT那活兒”,關注后了解更多內容,不管IT什么活兒,干就完了?。。?/span>

某項目現場,經常出現CPU高的時候,這種情況發現了多次,通常是代碼存在一些問題,導致CPU高,經常人工去恢復,有時又未做線程快照,無法定位到具體的問題。于是想寫一個小腳本,自動去獲取,下面是本次的一點嘗試。



Tomcat的簡介


Tomcat服務器是一個免費的開放源代碼的Web 應用服務器,屬于輕量級應用服務器,在中小型系統和并發訪問用戶不是很多的場合下被普遍使用,是開發和調試JSP 程序的首選。
Xx通信企業使用較普遍的版本為Tomcat8的大版本。由于開源軟件的漏洞比較多,建議廠商在安裝Tomcat服務器時,建議安裝所需大版本最新小版本。
各個版本的Tomcat在Linux,window操作系統的安裝過程大致相似。
下面以在linux 的Tomcat8.5.72為例,詳細描述Tomcat的安裝過程。該安裝文檔適用于各個版本的Tomcat安裝。



最小化安裝要求


安裝要求:安裝tomcat遵循最小化安裝原則,安裝最小化組件,開啟最小化端口,關閉非必須服務。
  • Server(代表tomcat instance(實例),即表現出的一個jvm進程;監聽在8005端口,只接收“SHUTDOWN”。各server監聽的端口不能相同,因此,在同一物理主機啟動多個實例時,需要修改其監聽端口為不同的端口;)
  • Service(用于實現將一個或多個connector組件關聯至一個engine組件;)
  • Connector(接入前端用戶請求;)
  • Engine(Servlet實例,即servlet引擎,其內部可以有一個或多個host組件來定義站點;通常需要通過defaultHost來定義默認的虛擬主機;)
  • Host(位于engine內部用于接收請求并進行相應處理的主機或虛擬主機;)
  • Context(Context在某些意義上類似于apache中的路徑別名,一個Context定義用于標識tomcat實例中一個Web應用程序;)
  • Value(Value組件類似于過濾器,它可以工作于Engine和Host/Context之間、Host和Context之間以及Context和Web應用程序的某資源之間。一個容器可以建多個Value,而且Value定義的次序也決定了他們生效的次序。)
  • Realm(一個Realm表示一個安全上下文,它是一個授權訪問某個給定Context的用戶列表和某用戶所允許。)



JDK環境安裝



  • Tar –zxvf jdk-8u281-linux-x64.tar.gz

  • java -version

  • export JAVA_HOME=/app/jdk1.8.0_281

  • export JRE_HOME=$JAVA_HOME/jre

  • export CLASSPATH=.:$JAVA_HOME/lib:$JRE_HOME/lib

  • export PATH=$JAVA_HOME/bin:$PATH



TOMCAT環境安裝


1. Tomcat安裝及啟動
Tar –xvf *tar.gz
sh /app/tomcat/apache-tomcat-8.5.72/bin/startup.sh
2. Tomcat訪問
http://192.168.1.111:8080/



自動化線程快照


1. 實現邏輯

當主機CPU大于80%時,由于一個主機存大多個JAVA進程,按進程CPU大小,大于某個閾值時調用jstack程序生成快照,同時上傳至FTP,使用MT工具分析DUMP

2. 實現腳本

#!/bin/bash
source /etc/profile
log_file="/tmp/dump.log"
script_name="thread_dump.sh"
datee=$(date +"%Y-%m-%d-%H:%M:%S")
#######DECALRE
pro_cpu_rate=10.0
ipaddr=$(ifconfig -a|grep inet|grep -v 127.0.0.1|grep -v inet6|awk {print $2}|tr -d "addr:"|grep "^1XXXX"|head -n 1)
###########################
ps axf -o "pid %cpu command"|grep java|grep -v grep > /tmp/thread_${ipaddr}_${datee}_ddl
#################################
which  jstack
if [ $? -eq 0 ] ;then

function pro_cpu
{
ps axf -o "pid %cpu command"|grep java|grep -v grep|awk {if($2>=$pro_cpu_rate) print $1} | while read procid
do
echo $procid
done
}

function log_echo
{
typeset log_message=$1
typeset log_date=$(date +"%Y-%m-%d %H:%M:%S")
echo "[${log_date}] [${script_name}] ${log_message}" >> $log_file
}

log_echo "start jstack thread"


for i in `pro_cpu`
do
log_echo "process num $i start"
jstack $i > /tmp/thread_${ipaddr}_${datee}_$i
log_echo "process num $i end"
sleep 5
done

function file_upload
{
ftp -n <open XXXX
user XXXX
binary
lcd /tmp
cd thread_snapshot
prompt
mput thread*
close
bye
EOF
}

function file_delete
{
cd /tmp && rm -rf thread*
}

file_upload
file_delete
cat $log_file

else
echo 0
exit;
fi





本文作者:唐田壽

本文來源:IT那活兒(上海新炬王翦團隊)

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/129624.html

相關文章

  • JVM調優前戲之JDK命令行工具---jstack

    摘要:用于生成虛擬機當前時刻的線程快照。線程快照就是當前虛擬機內每一條線程正在執行的方法堆棧的集合,生成線程快照的主要目的就是定位線程出現長時間停頓的原因,如線程死鎖死循環請求外部資源導致的長時間等待等都是導致線程長時間停頓的常見原因。 在JDK的命令行中,一般開發人員最耳熟能詳的肯定就是java,javac,javap等常用命令,不過在jdk/bin下還有許多其他的命令行工具,它們被用來監...

    Cristic 評論0 收藏0
  • jvm調優-命令篇

    摘要:打印等待回收對象的信息可以看到當前隊列中并沒有等待線程執行方法的對象。一般情況,會到客戶端用工具來分析用于生成虛擬機當前時刻的線程快照。 運用jvm自帶的命令可以方便的在生產監控和打印堆棧的日志信息幫忙我們來定位問題!雖然jvm調優成熟的工具已經有很多:jconsole、大名鼎鼎的VisualVM,IBM的Memory Analyzer等等,但是在生產環境出現問題的時候,一方面工具的使...

    Lsnsh 評論0 收藏0
  • 自動記錄MySQL慢查詢快照腳本

    摘要:完成的一個小程序,用于殺掉上的異常線程,如慢查詢處于狀態的。在這里出現的實例都會被執行檢查,可用注釋,但需要重啟腳本。檢查用公共配置,實時生效。為表示腳本不進行任何檢查,只簡單維護與數據庫的連接存活。試運行模式可用于監控慢查詢并告警。 Python完成的一個小程序,用于殺掉 MySQL 上的異常線程,如慢查詢、處于Sleep狀態的。項目地址:https://github.com/sea...

    alphahans 評論0 收藏0
  • java虛擬機故障處理工具

    摘要:這些工具包括名稱主要作用顯示指定系統內所有的虛擬機進程。虛擬機堆轉存快照分析工具命令用于與搭配使用,用來分析生成的文件。命令格式命令樣例線程堆棧跟蹤工具用于生成虛擬機當前時刻的線程快照。 概述 給系統定位問題的時候,知識、經驗是關鍵基礎,數據是依據,工具是運用知識處理數據的手段。 java開發人員可以在jdk安裝的bin目錄下找到除了java,javac以外的其他命令。這些命令主要是一...

    loonggg 評論0 收藏0
  • 摘記《深入理解Java虛擬機:JVM高級特性與最佳實踐(第2版)》

    摘要:第章內存區域與內存溢出異常運行時數據區域虛擬機在執行程序的過程中會把它所管理的內存劃分為若干個不同的數據區域。即對象指向它的類元數據的指針,虛擬機通過這個指針來確定這個對象是哪個類的實例。 第2章 Java內存區域與內存溢出異常 2.2 運行時數據區域 Java虛擬機在執行Java程序的過程中會把它所管理的內存劃分為若干個不同的數據區域。根據《Java虛擬機規范(Java SE 7版)...

    zoomdong 評論0 收藏0

發表評論

0條評論

IT那活兒

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<