JVM命令-java服務器故障排查

一搓侄、top(Linux命令)

執(zhí)行top命令:? (查看進程15477的詳細情況揪罕,下文用到)

系統(tǒng)信息(前五行):

第1行:Top 任務隊列信息(系統(tǒng)運行狀態(tài)及平均負載)四啰,與uptime命令結(jié)果相同歇攻。

第1段:系統(tǒng)當前時間译隘,例如:16:07:37

第2段:系統(tǒng)運行時間亲桥,未重啟的時間,時間越長系統(tǒng)越穩(wěn)定固耘。

格式:up xx days, HH:MM

例如:241 days, 20:11, 表示連續(xù)運行了241天20小時11分鐘

第3段:當前登錄用戶數(shù)题篷,例如:1 user,表示當前只有1個用戶登錄

第4段:系統(tǒng)負載厅目,即任務隊列的平均長度番枚,3個數(shù)值分別統(tǒng)計最近1,5损敷,15分鐘的系統(tǒng)平均負載

系統(tǒng)平均負載:單核CPU情況下葫笼,0.00 表示沒有任何負荷,1.00表示剛好滿負荷拗馒,超過1側(cè)表示超負荷路星,理想值是0.7;

多核CPU負載:CPU核數(shù) * 理想值0.7 = 理想負荷诱桂,例如:4核CPU負載不超過2.8何表示沒有出現(xiàn)高負載洋丐。

第2行:Tasks 進程相關信息

第1段:進程總數(shù)呈昔,例如:Tasks: 231 total, 表示總共運行231個進程

第2段:正在運行的進程數(shù),例如:1 running,

第3段:睡眠的進程數(shù)友绝,例如:230 sleeping,

第4段:停止的進程數(shù)堤尾,例如:0 stopped,

第5段:僵尸進程數(shù),例如:0 zombie

第3行:Cpus CPU相關信息九榔,如果是多核CPU哀峻,按數(shù)字1可顯示各核CPU信息,此時1行將轉(zhuǎn)為Cpu核數(shù)行哲泊,數(shù)字1可以來回切換剩蟀。

第1段:us 用戶空間占用CPU百分比,例如:Cpu(s): 12.7%us,

第2段:sy 內(nèi)核空間占用CPU百分比切威,例如:8.4%sy,

第3段:ni 用戶進程空間內(nèi)改變過優(yōu)先級的進程占用CPU百分比育特,例如:0.0%ni,

第4段:id 空閑CPU百分比,例如:77.1%id,

第5段:wa 等待輸入輸出的CPU時間百分比先朦,例如:0.0%wa,

第6段:hi CPU服務于硬件中斷所耗費的時間總額缰冤,例如:0.0%hi,

第7段:si CPU服務軟中斷所耗費的時間總額,例如:1.8%si,

第8段:st Steal time 虛擬機被hypervisor偷去的CPU時間(如果當前處于一個hypervisor下的vm喳魏,實際上hypervisor也是要消耗一部分CPU處理時間的)

第4行:Mem 內(nèi)存相關信息(Mem: 12196436k total, 12056552k used, 139884k free, 64564k buffers)

第1段:物理內(nèi)存總量棉浸,例如:Mem: 12196436k total,

第2段:使用的物理內(nèi)存總量,例如:12056552k used,

第3段:空閑內(nèi)存總量刺彩,例如:Mem: 139884k free,

第4段:用作內(nèi)核緩存的內(nèi)存量迷郑,例如:64564k buffers

第5行:Swap 交換分區(qū)相關信息(Swap: 2097144k total, 151016k used, 1946128k free, 3120236k cached)

第1段:交換區(qū)總量,例如:Swap: 2097144k total,

第2段:使用的交換區(qū)總量创倔,例如:151016k used,

第3段:空閑交換區(qū)總量嗡害,例如:1946128k free,

第4段:緩沖的交換區(qū)總量,3120236k cached

進程信息:

在top命令中按f按可以查看顯示的列信息畦攘,按對應字母來開啟/關閉列霸妹,大寫字母表示開啟,小寫字母表示關閉知押。帶*號的是默認列叹螟。

A: PID = (Process Id) 進程Id;

E: USER = (User Name) 進程所有者的用戶名朗徊;

H: PR = (Priority) 優(yōu)先級

I: NI = (Nice value) nice值首妖。負值表示高優(yōu)先級,正值表示低優(yōu)先級

O: VIRT = (Virtual Image (kb)) 進程使用的虛擬內(nèi)存總量爷恳,單位kb。VIRT=SWAP+RES

Q: RES = (Resident size (kb)) 進程使用的象踊、未被換出的物理內(nèi)存大小温亲,單位kb棚壁。RES=CODE+DATA

T: SHR = (Shared Mem size (kb)) 共享內(nèi)存大小,單位kb

W: S = (Process Status) 進程狀態(tài)栈虚。D=不可中斷的睡眠狀態(tài),R=運行,S=睡眠,T=跟蹤/停止,Z=僵尸進程

K: %CPU = (CPU usage) 上次更新到現(xiàn)在的CPU時間占用百分比

N: %MEM = (Memory usage (RES)) 進程使用的物理內(nèi)存百分比

M: TIME+ = (CPU Time, hundredths) 進程使用的CPU時間總計袖外,單位1/100秒

b: PPID = (Parent Process Pid) 父進程Id

c: RUSER = (Real user name)

d: UID = (User Id) 進程所有者的用戶id

f: GROUP = (Group Name) 進程所有者的組名

g: TTY = (Controlling Tty) 啟動進程的終端名。不是從終端啟動的進程則顯示為 ?

j: P = (Last used cpu (SMP)) 最后使用的CPU魂务,僅在多CPU環(huán)境下有意義

p: SWAP = (Swapped size (kb)) 進程使用的虛擬內(nèi)存中曼验,被換出的大小,單位kb

l: TIME = (CPU Time) 進程使用的CPU時間總計粘姜,單位秒

r: CODE = (Code size (kb)) 可執(zhí)行代碼占用的物理內(nèi)存大小鬓照,單位kb

s: DATA = (Data+Stack size (kb)) 可執(zhí)行代碼以外的部分(數(shù)據(jù)段+棧)占用的物理內(nèi)存大小,單位kb

u: nFLT = (Page Fault count) 頁面錯誤次數(shù)

v: nDRT = (Dirty Pages count) 最后一次寫入到現(xiàn)在孤紧,被修改過的頁面數(shù)

y: WCHAN = (Sleeping in Function) 若該進程在睡眠豺裆,則顯示睡眠中的系統(tǒng)函數(shù)名

z: Flags = (Task Flags <sched.h>) 任務標志,參考 sched.h

X: COMMAND = (Command name/line) 命令名/命令行

參考? Linux性能分析工具top命令詳解

執(zhí)行top -Hp PID号显,如 top -Hp 15477

查看某進程中的線程? 注:此時PID是線程id

如線程15571有異常需要查看臭猜,使用jstack打印堆棧,查看線程15571狀態(tài)(15571 16進制=3cd3)

二押蚤、jstack

參考 java命令--jstack 工具

? Java命令學習系列(二)——Jstack

需要到JDK安裝目錄下使用(可通過ps x查看java進程蔑歌,得到jdk安裝目錄)

./jstack PID(進程id)? ./jstack 15477

紅框中即為線程15571(16進制=3cd3) 狀態(tài)

分析jstack日志:

監(jiān)視器Monitor:

Monitor是 Java中用以實現(xiàn)線程之間的互斥與協(xié)作的主要手段,它可以看成是對象或者 Class的鎖揽碘。

每一個對象都有次屠,也僅有一個 monitor。

下面這個圖钾菊,描述了線程和Monitor之間關系帅矗,以及線程的狀態(tài)轉(zhuǎn)換:

進入?yún)^(qū)(Entrt Set):表示線程通過synchronized要求獲取對象的鎖。如果對象被鎖住煞烫,則進入擁有者浑此;否則在進入?yún)^(qū)等待。一旦對象鎖被其他線程釋放滞详,立即參與競爭凛俱。

擁有者(The Owner):表示某一線程成功競爭到對象鎖。

等待區(qū)(Wait Set):表示線程通過對象的object.wait()方法,釋放對象的鎖索烹,并在等待區(qū)等待被喚醒肛搬。

從圖中可以看出,一個 Monitor在某個時刻原叮,只能被一個線程擁有,該線程就是 Active Thread,而其它線程都是 Waiting Thread奋隶,分別在兩個隊列 Entry Set和 Wait Set里面等候擂送。

在 Entry Set中等待的線程動作是 Waiting for monitor entry。

在 Wait Set中等待的線程動作是 in Object.wait()唯欣。當一個線程申請進入臨界區(qū)時嘹吨,它就進入了 Entry Set隊列。

(我們稱被 synchronized保護起來的代碼段為臨界區(qū)境氢。當一個線程申請進入臨界區(qū)時蟀拷,它就進入了 “Entry Set ”隊列)

線程狀態(tài):

NEW:未啟動的。不會出現(xiàn)在Dump中萍聊。

RUNNABLE:在虛擬機內(nèi)執(zhí)行的问芬,運行中狀態(tài)。The Owner區(qū)

BLOCKED:受阻塞并等待監(jiān)視器鎖脐区。在Entry Set區(qū)等鎖愈诚。

WATING:無限期等待另一個線程執(zhí)行特定操作。在Wait Set區(qū)等待某個condition或monitor發(fā)生牛隅,一般停留在wait()等語句里炕柔。

TIMED_WATING:有時限的等待另一個線程的特定操作。在Wait Set區(qū)和WAITING的區(qū)別是wait() 等語句加上了時間限制 wait(timeout)媒佣。

TERMINATED:已退出的匕累。

調(diào)用修飾

表示線程在方法調(diào)用時,額外的重要的操作默伍。修飾上方的方法調(diào)用欢嘿。

locked <地址> 目標:使用synchronized申請對象鎖成功,監(jiān)視器的擁有者也糊。The Owner區(qū)炼蹦。

waiting to lock <地址> 目標:使用synchronized申請對象鎖未成功,在Entry Set區(qū)等鎖狸剃。線程狀態(tài)為Blocked

waiting on <地址> 目標:使用synchronized申請對象鎖成功后掐隐,釋放鎖,在Wait Set區(qū)等鎖钞馁。線程狀態(tài)為WAITING或TIMED_WATING

parking to wait for <地址> 目標:調(diào)用了park()虑省,在Wait Set區(qū),等待許可僧凰。

(park是基本的線程阻塞原語探颈,不通過監(jiān)視器在對象上阻塞。

park: 進入WAITING狀態(tài)训措,對比wait不需要獲得鎖就可以讓線程WAITING伪节,通過unpark喚醒)

線程動作

線程狀態(tài)產(chǎn)生的原因光羞。

runnable:The Owner區(qū),狀態(tài)RUNNABLE

in Object.wait():調(diào)用wait()架馋,Wait Set區(qū)狞山,狀態(tài)為WAITING或TIMED_WAITING全闷,修飾waiting on

waiting for monitor entry:等鎖叉寂,Entry Set區(qū),狀態(tài)BLOCKED总珠,修飾waiting to lock

waiting on condition:因某種條件被park屏鳍,Wait Set區(qū),狀態(tài)為parking to wait for

sleeping:休眠的線程局服,調(diào)用了Thread.sleep()

總結(jié)

1钓瞭、查看線程dump,先看線程狀態(tài)/線程動作(比較直觀)淫奔,可以確定線程目前處于哪個階段山涡。然后看調(diào)用修飾及鎖情況,基本就可以確定次線程是否有問題唆迁;

2鸭丛、可以短時間(可能有問題的時間段)內(nèi)多次打印線程快照,然后查看可能有問題的某一線程在這幾次的情況唐责,可以有效查找問題鳞溉。

三、jps

類似Linux命令ps

參考 Java命令學習系列(一)——Jps

./jps

./jps -q

./jps -m

./jps -l

./jps -v

一鼠哥、top(Linux命令)

執(zhí)行top命令:? (查看進程15477的詳細情況熟菲,下文用到)

系統(tǒng)信息(前五行):

第1行:Top 任務隊列信息(系統(tǒng)運行狀態(tài)及平均負載),與uptime命令結(jié)果相同朴恳。

第1段:系統(tǒng)當前時間抄罕,例如:16:07:37

第2段:系統(tǒng)運行時間,未重啟的時間于颖,時間越長系統(tǒng)越穩(wěn)定呆贿。

格式:up xx days, HH:MM

例如:241 days, 20:11, 表示連續(xù)運行了241天20小時11分鐘

第3段:當前登錄用戶數(shù),例如:1 user恍飘,表示當前只有1個用戶登錄

第4段:系統(tǒng)負載榨崩,即任務隊列的平均長度,3個數(shù)值分別統(tǒng)計最近1章母,5母蛛,15分鐘的系統(tǒng)平均負載

系統(tǒng)平均負載:單核CPU情況下,0.00 表示沒有任何負荷乳怎,1.00表示剛好滿負荷彩郊,超過1側(cè)表示超負荷前弯,理想值是0.7;

多核CPU負載:CPU核數(shù) * 理想值0.7 = 理想負荷秫逝,例如:4核CPU負載不超過2.8何表示沒有出現(xiàn)高負載恕出。

第2行:Tasks 進程相關信息

第1段:進程總數(shù),例如:Tasks: 231 total, 表示總共運行231個進程

第2段:正在運行的進程數(shù)违帆,例如:1 running,

第3段:睡眠的進程數(shù)浙巫,例如:230 sleeping,

第4段:停止的進程數(shù),例如:0 stopped,

第5段:僵尸進程數(shù)刷后,例如:0 zombie

第3行:Cpus CPU相關信息的畴,如果是多核CPU,按數(shù)字1可顯示各核CPU信息尝胆,此時1行將轉(zhuǎn)為Cpu核數(shù)行丧裁,數(shù)字1可以來回切換。

第1段:us 用戶空間占用CPU百分比含衔,例如:Cpu(s): 12.7%us,

第2段:sy 內(nèi)核空間占用CPU百分比煎娇,例如:8.4%sy,

第3段:ni 用戶進程空間內(nèi)改變過優(yōu)先級的進程占用CPU百分比,例如:0.0%ni,

第4段:id 空閑CPU百分比贪染,例如:77.1%id,

第5段:wa 等待輸入輸出的CPU時間百分比缓呛,例如:0.0%wa,

第6段:hi CPU服務于硬件中斷所耗費的時間總額,例如:0.0%hi,

第7段:si CPU服務軟中斷所耗費的時間總額抑进,例如:1.8%si,

第8段:st Steal time 虛擬機被hypervisor偷去的CPU時間(如果當前處于一個hypervisor下的vm强经,實際上hypervisor也是要消耗一部分CPU處理時間的)

第4行:Mem 內(nèi)存相關信息(Mem: 12196436k total, 12056552k used, 139884k free, 64564k buffers)

第1段:物理內(nèi)存總量,例如:Mem: 12196436k total,

第2段:使用的物理內(nèi)存總量寺渗,例如:12056552k used,

第3段:空閑內(nèi)存總量匿情,例如:Mem: 139884k free,

第4段:用作內(nèi)核緩存的內(nèi)存量,例如:64564k buffers

第5行:Swap 交換分區(qū)相關信息(Swap: 2097144k total, 151016k used, 1946128k free, 3120236k cached)

第1段:交換區(qū)總量信殊,例如:Swap: 2097144k total,

第2段:使用的交換區(qū)總量炬称,例如:151016k used,

第3段:空閑交換區(qū)總量,例如:1946128k free,

第4段:緩沖的交換區(qū)總量涡拘,3120236k cached

進程信息:

在top命令中按f按可以查看顯示的列信息玲躯,按對應字母來開啟/關閉列,大寫字母表示開啟鳄乏,小寫字母表示關閉跷车。帶*號的是默認列。

A: PID = (Process Id) 進程Id橱野;

E: USER = (User Name) 進程所有者的用戶名朽缴;

H: PR = (Priority) 優(yōu)先級

I: NI = (Nice value) nice值。負值表示高優(yōu)先級水援,正值表示低優(yōu)先級

O: VIRT = (Virtual Image (kb)) 進程使用的虛擬內(nèi)存總量密强,單位kb茅郎。VIRT=SWAP+RES

Q: RES = (Resident size (kb)) 進程使用的、未被換出的物理內(nèi)存大小或渤,單位kb系冗。RES=CODE+DATA

T: SHR = (Shared Mem size (kb)) 共享內(nèi)存大小,單位kb

W: S = (Process Status) 進程狀態(tài)薪鹦。D=不可中斷的睡眠狀態(tài),R=運行,S=睡眠,T=跟蹤/停止,Z=僵尸進程

K: %CPU = (CPU usage) 上次更新到現(xiàn)在的CPU時間占用百分比

N: %MEM = (Memory usage (RES)) 進程使用的物理內(nèi)存百分比

M: TIME+ = (CPU Time, hundredths) 進程使用的CPU時間總計掌敬,單位1/100秒

b: PPID = (Parent Process Pid) 父進程Id

c: RUSER = (Real user name)

d: UID = (User Id) 進程所有者的用戶id

f: GROUP = (Group Name) 進程所有者的組名

g: TTY = (Controlling Tty) 啟動進程的終端名。不是從終端啟動的進程則顯示為 ?

j: P = (Last used cpu (SMP)) 最后使用的CPU距芬,僅在多CPU環(huán)境下有意義

p: SWAP = (Swapped size (kb)) 進程使用的虛擬內(nèi)存中涝开,被換出的大小,單位kb

l: TIME = (CPU Time) 進程使用的CPU時間總計框仔,單位秒

r: CODE = (Code size (kb)) 可執(zhí)行代碼占用的物理內(nèi)存大小,單位kb

s: DATA = (Data+Stack size (kb)) 可執(zhí)行代碼以外的部分(數(shù)據(jù)段+棧)占用的物理內(nèi)存大小拄养,單位kb

u: nFLT = (Page Fault count) 頁面錯誤次數(shù)

v: nDRT = (Dirty Pages count) 最后一次寫入到現(xiàn)在离斩,被修改過的頁面數(shù)

y: WCHAN = (Sleeping in Function) 若該進程在睡眠,則顯示睡眠中的系統(tǒng)函數(shù)名

z: Flags = (Task Flags <sched.h>) 任務標志瘪匿,參考 sched.h

X: COMMAND = (Command name/line) 命令名/命令行

參考? Linux性能分析工具top命令詳解

執(zhí)行top -Hp PID跛梗,如 top -Hp 15477

查看某進程中的線程? 注:此時PID是線程id

如線程15571有異常需要查看,使用jstack打印堆棧棋弥,查看線程15571狀態(tài)(15571 16進制=3cd3)

二核偿、jstack

參考 java命令--jstack 工具

? Java命令學習系列(二)——Jstack

需要到JDK安裝目錄下使用(可通過ps x查看java進程,得到jdk安裝目錄)

./jstack PID(進程id)? ./jstack 15477

紅框中即為線程15571(16進制=3cd3) 狀態(tài)

分析jstack日志:

監(jiān)視器Monitor:

Monitor是 Java中用以實現(xiàn)線程之間的互斥與協(xié)作的主要手段顽染,它可以看成是對象或者 Class的鎖漾岳。

每一個對象都有,也僅有一個 monitor粉寞。

下面這個圖尼荆,描述了線程和Monitor之間關系,以及線程的狀態(tài)轉(zhuǎn)換:

進入?yún)^(qū)(Entrt Set):表示線程通過synchronized要求獲取對象的鎖唧垦。如果對象被鎖住捅儒,則進入擁有者;否則在進入?yún)^(qū)等待振亮。一旦對象鎖被其他線程釋放巧还,立即參與競爭。

擁有者(The Owner):表示某一線程成功競爭到對象鎖坊秸。

等待區(qū)(Wait Set):表示線程通過對象的object.wait()方法麸祷,釋放對象的鎖,并在等待區(qū)等待被喚醒妇斤。

從圖中可以看出摇锋,一個 Monitor在某個時刻丹拯,只能被一個線程擁有,該線程就是 Active Thread荸恕,而其它線程都是 Waiting Thread乖酬,分別在兩個隊列 Entry Set和 Wait Set里面等候。

在 Entry Set中等待的線程動作是 Waiting for monitor entry融求。

在 Wait Set中等待的線程動作是 in Object.wait()咬像。當一個線程申請進入臨界區(qū)時,它就進入了 Entry Set隊列生宛。

(我們稱被 synchronized保護起來的代碼段為臨界區(qū)县昂。當一個線程申請進入臨界區(qū)時,它就進入了 “Entry Set ”隊列)

線程狀態(tài):

NEW:未啟動的陷舅。不會出現(xiàn)在Dump中倒彰。

RUNNABLE:在虛擬機內(nèi)執(zhí)行的,運行中狀態(tài)莱睁。The Owner區(qū)

BLOCKED:受阻塞并等待監(jiān)視器鎖待讳。在Entry Set區(qū)等鎖。

WATING:無限期等待另一個線程執(zhí)行特定操作仰剿。在Wait Set區(qū)等待某個condition或monitor發(fā)生创淡,一般停留在wait()等語句里。

TIMED_WATING:有時限的等待另一個線程的特定操作南吮。在Wait Set區(qū)和WAITING的區(qū)別是wait() 等語句加上了時間限制 wait(timeout)琳彩。

TERMINATED:已退出的。

調(diào)用修飾

表示線程在方法調(diào)用時部凑,額外的重要的操作露乏。修飾上方的方法調(diào)用。

locked <地址> 目標:使用synchronized申請對象鎖成功砚尽,監(jiān)視器的擁有者施无。The Owner區(qū)。

waiting to lock <地址> 目標:使用synchronized申請對象鎖未成功必孤,在Entry Set區(qū)等鎖猾骡。線程狀態(tài)為Blocked

waiting on <地址> 目標:使用synchronized申請對象鎖成功后,釋放鎖敷搪,在Wait Set區(qū)等鎖兴想。線程狀態(tài)為WAITING或TIMED_WATING

parking to wait for <地址> 目標:調(diào)用了park(),在Wait Set區(qū)赡勘,等待許可嫂便。

(park是基本的線程阻塞原語,不通過監(jiān)視器在對象上阻塞闸与。

park: 進入WAITING狀態(tài)毙替,對比wait不需要獲得鎖就可以讓線程WAITING岸售,通過unpark喚醒)

線程動作

線程狀態(tài)產(chǎn)生的原因。

runnable:The Owner區(qū)厂画,狀態(tài)RUNNABLE

in Object.wait():調(diào)用wait()凸丸,Wait Set區(qū),狀態(tài)為WAITING或TIMED_WAITING袱院,修飾waiting on

waiting for monitor entry:等鎖屎慢,Entry Set區(qū),狀態(tài)BLOCKED忽洛,修飾waiting to lock

waiting on condition:因某種條件被park腻惠,Wait Set區(qū),狀態(tài)為parking to wait for

sleeping:休眠的線程欲虚,調(diào)用了Thread.sleep()

總結(jié)

1集灌、查看線程dump,先看線程狀態(tài)/線程動作(比較直觀)苍在,可以確定線程目前處于哪個階段绝页。然后看調(diào)用修飾及鎖情況,基本就可以確定次線程是否有問題寂恬;

2、可以短時間(可能有問題的時間段)內(nèi)多次打印線程快照莱没,然后查看可能有問題的某一線程在這幾次的情況初肉,可以有效查找問題。

三饰躲、jps

類似Linux命令ps

參考 Java命令學習系列(一)——Jps

./jps

./jps -q

./jps -m

./jps -l

./jps -v

四牙咏、jmap

參考? Java命令學習系列(三)——Jmap

? ? java命令--jmap命令使用

jmap -heap PID:堆使用情況

jmap -histo PID:對象情況

(jmap -histo:live 這個命令執(zhí)行,JVM會先觸發(fā)gc嘹裂,然后再統(tǒng)計信息

? 重點看項目上的類:[C是字符串數(shù)組妄壶,String用;[B是字節(jié)數(shù)組寄狼,網(wǎng)絡層用到丁寄。這兩個比較大一般沒關系

[C is a char[]

[S is a short[]

[I is a int[]

[B is a byte[]

[[I is a int[][]

技術在于學習 在于實踐 在于總結(jié) 在于分享

四、jmap

參考? Java命令學習系列(三)——Jmap

? ? java命令--jmap命令使用

jmap -heap PID:堆使用情況

jmap -histo PID:對象情況

(jmap -histo:live 這個命令執(zhí)行泊愧,JVM會先觸發(fā)gc伊磺,然后再統(tǒng)計信息

? 重點看項目上的類:[C是字符串數(shù)組,String用删咱;[B是字節(jié)數(shù)組屑埋,網(wǎng)絡層用到。這兩個比較大一般沒關系

[C is a char[]

[S is a short[]

[I is a int[]

[B is a byte[]

[[I is a int[][]

技術在于學習 在于實踐 在于總結(jié) 在于分享

歡迎工作一到五年的Java工程師朋友們加入Java架構(gòu)開發(fā): 854393687

群內(nèi)提供免費的Java架構(gòu)學習資料(里面有高可用痰滋、高并發(fā)摘能、高性能及分布式续崖、Jvm性能調(diào)優(yōu)、Spring源碼团搞,MyBatis严望,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多個知識點的架構(gòu)資料)合理利用自己每一分每一秒的時間來學習提升自己,不要再用"沒有時間“來掩飾自己思想上的懶惰莺丑!趁年輕著蟹,使勁拼,給未來的自己一個交代梢莽!

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末萧豆,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子昏名,更是在濱河造成了極大的恐慌涮雷,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件轻局,死亡現(xiàn)場離奇詭異洪鸭,居然都是意外死亡,警方通過查閱死者的電腦和手機仑扑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進店門览爵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人镇饮,你說我怎么就攤上這事蜓竹。” “怎么了储藐?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵俱济,是天一觀的道長。 經(jīng)常有香客問我钙勃,道長蛛碌,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任辖源,我火速辦了婚禮蔚携,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘同木。我一直安慰自己浮梢,他們只是感情好,可當我...
    茶點故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布彤路。 她就那樣靜靜地躺著秕硝,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上远豺,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天奈偏,我揣著相機與錄音,去河邊找鬼躯护。 笑死惊来,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的棺滞。 我是一名探鬼主播裁蚁,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼继准!你這毒婦竟也來了枉证?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤移必,失蹤者是張志新(化名)和其女友劉穎室谚,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體崔泵,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡秒赤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了憎瘸。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片入篮。...
    茶點故事閱讀 38,161評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖幌甘,靈堂內(nèi)的尸體忽然破棺而出崎弃,到底是詐尸還是另有隱情,我是刑警寧澤含潘,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站线婚,受9級特大地震影響遏弱,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜塞弊,卻給世界環(huán)境...
    茶點故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一漱逸、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧游沿,春花似錦饰抒、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至眯勾,卻和暖如春枣宫,著一層夾襖步出監(jiān)牢的瞬間婆誓,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工也颤, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留洋幻,地道東北人。 一個月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓翅娶,卻偏偏與公主長得像文留,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子竭沫,可洞房花燭夜當晚...
    茶點故事閱讀 42,916評論 2 344

推薦閱讀更多精彩內(nèi)容