kali linux 升级命令_作为高级Java,你应该了解的Linux知识
原創(chuàng):小姐姐味道(微信公眾號(hào)ID:xjjdog),歡迎分享,轉(zhuǎn)載請(qǐng)保留出處。
作為一個(gè)javaer,我以前寫過很多關(guān)于Linux的文章。但經(jīng)過多年的觀察,發(fā)現(xiàn)其實(shí)對(duì)于大部分人,有些東西壓根就用不著。用的最多的,就是到線上排查個(gè)問題而已,這讓人很是苦惱。那么,我們就將范圍再縮小一下。
Linux命令好像還真不少,根本原因就是軟件多,也有像ag這樣的命令想替代grep,但大多數(shù)命令古老而堅(jiān)挺。不是因?yàn)檫@些軟件設(shè)計(jì)的有多好,原因是一些軟件最開始入駐了系統(tǒng),時(shí)間久了,就變成了一種約定,這種習(xí)慣改變代價(jià)太大,就像把所有鍵盤的L和F換一下一樣。
這篇文章假定你已經(jīng)了解大多數(shù)Linux命令,并了解操作系統(tǒng)的基本元素。如果你現(xiàn)在了解的命令還不足10個(gè),下面的內(nèi)容就不用看了。除了最基本的東西,本文列出一些對(duì)你的面試最常見的最能加分的地方,有些組合可能是你沒見過的技巧。但本文僅僅是給出一個(gè)大致的輪廓和印象,為以后的專題性考察點(diǎn)作一個(gè)序。
本文中出現(xiàn)的所有命令,應(yīng)該熟記并熟練使用。
幾種比較典型的Linux系統(tǒng)
首先對(duì)目前的Linux版本有個(gè)大體的印象,大體分Desktop版和Server版,已經(jīng)是百花齊放。
Ubuntu 最常見的Linux個(gè)人發(fā)行版,一位有情懷的南非富豪,有了錢你也可以這么做
CentOS 最常用Linux服務(wù)器發(fā)新版,RHEL的開放版本,因版權(quán)而生的輪子
Arch ?滾動(dòng)升級(jí),海量二進(jìn)制包,社區(qū)活躍,個(gè)人最愛
Gentoo 安裝軟件需要從源碼開始編譯,穩(wěn)定,但用起來會(huì)很痛
LFS 從零構(gòu)建Linux,跟著做一遍,Linux每根毛都看的清清楚楚
Kali 專做滲透用的,代表了發(fā)行版的一個(gè)發(fā)展路徑,就是領(lǐng)域
首先要了解的概念
KISS Keep it Simple and Stupid,據(jù)說是哲學(xué)
一切皆文件 通常是文件的東西叫文件,進(jìn)程、磁盤等也被抽象成了文件,比較離譜的管道、設(shè)備、socket等,也是文件。
這是Linux最重要的組織方式。
管道 | 分隔,前面命令的輸出作為后面命令的輸入,可以串聯(lián)多個(gè)
重定向
< 將文件做為命令的輸入
> 將命令的輸出輸出到文件
>> 將命令的輸出追加到文件
SHELL 首先確認(rèn)你的shell,一般最常用的是bash,也有不少用csh,zsh等的,通過echo $SHELL可以看到當(dāng)前用戶的shell,對(duì)應(yīng)的配置文件也要相應(yīng)改變。
比如.zshrc,.bashrc
四大元素
進(jìn)入linux,我們首先關(guān)注的是四個(gè)元素:
內(nèi)存,cpu,存儲(chǔ),網(wǎng)絡(luò)。
Linux提供了足夠的命令,讓你窺探它的每個(gè)角落。
接下來的命令都是些最常用的,不管精通不精通,想不起來要打屁股。
CPU
使用top查看cpu的load,使用shift+p按照cpu排序。
需要了解wa,us等都是什么意思
使用uptime查看系統(tǒng)啟動(dòng)時(shí)間和load,load是什么意思呢?
什么算是系統(tǒng)過載?
這是個(gè)高頻問題,別怪我沒告訴你
ps命令勃大莖深,除了查進(jìn)程號(hào)外,你還需要知道R、S、D、T、Z、
top和ps很多功能是相通的,比如watch "ps -mo %cpu,%mem,pid,ppid,command ax" 相當(dāng)于top的進(jìn)程列表;
top -n 1 -bc 和ps -ef的結(jié)果相似。
有生就有死,可以用kill殺死進(jìn)程。
對(duì)java來說,需要關(guān)注kill -9、kill -15、kill -3的含義,kill的信號(hào)太多了,可以用kill -l查看,搞懂大多數(shù)信號(hào)大有裨益。
如果暫時(shí)不想死,可以通過&符號(hào)在后臺(tái)執(zhí)行,比如tail -f a.log &。
jobs命令可以查看當(dāng)前后臺(tái)的列表,想恢復(fù)的話,使用fg回到幕前。
這都是終端作業(yè),當(dāng)你把term關(guān)了你的后臺(tái)命令也會(huì)跟著消失,所以想讓你的程序繼續(xù)執(zhí)行的話,需要nohup命令,此命令需要牢記
mpstat 顯示了系統(tǒng)中 CPU 的各種統(tǒng)計(jì)信
了解cpu親和性
內(nèi)存
free -m 命令,了解free、used、cached、swap各項(xiàng)的含義
cat /proc/meminfo 查看更詳細(xì)的內(nèi)存信息
細(xì)心的同學(xué)可能注意到,CPU和內(nèi)存的信息,通過top等不同的命令顯示的數(shù)值是一樣的。slabtop 用來顯示內(nèi)核緩存占用情況,比如遍歷大量文件造成緩存目錄項(xiàng)。
曾在生產(chǎn)環(huán)境中遇到因執(zhí)行find /造成dentry_cache耗盡服務(wù)器內(nèi)存。
vmstat 命令是我最喜歡也最常用的命令之一,可以以最快的速度了解系統(tǒng)的運(yùn)行狀況。
每個(gè)參數(shù)的意義都要搞懂。
swapon、swapoff 開啟,關(guān)閉交換空間
sar ?又一統(tǒng)計(jì)類輪子,一般用作采樣工具
存儲(chǔ)
使用df -h查看系統(tǒng)磁盤使用概況
lsblk 列出塊設(shè)備信息
du 查看目錄或者文件大小
網(wǎng)絡(luò)
rsync 強(qiáng)大的同步工具,可以增量哦
netstat ?查看Linux中網(wǎng)絡(luò)系統(tǒng)狀態(tài)信息,各種
ss ?它能夠顯示更多更詳細(xì)的有關(guān)TCP和連接狀態(tài)的信息,而且比netstat更快速更高效。
curl、wget 模擬請(qǐng)求工具、下載工具。
如wget -r http://site 將下載整個(gè)站點(diǎn)
ab Apache服務(wù)器的性能測(cè)試工具
ifstat 統(tǒng)計(jì)網(wǎng)絡(luò)接口流量狀態(tài)
nslookup 查詢域名DNS信息的工具,在內(nèi)網(wǎng)根據(jù)ip查詢域名是爽爆了
nc 網(wǎng)絡(luò)工具中的瑞士軍刀,不會(huì)用真是太可惜了
arp 可以顯示和修改IP到MAC轉(zhuǎn)換表
traceroute 顯示數(shù)據(jù)包到主機(jī)間的路徑,俗稱幾跳,跳的越少越快
tcpdump 不多說了,去下載wireshark了
wall 向當(dāng)前所有打開的終端上輸出信息。
使用who命令發(fā)現(xiàn)女神正在終端上,可以求愛
網(wǎng)絡(luò)方面推薦安裝體驗(yàn)一下kaliLinux,上面的工具會(huì)讓你high到極點(diǎn)。
如何組織起來
linux的命令很有意思,除了各種stat來監(jiān)控狀態(tài),也有各種trace來進(jìn)行深入的跟蹤,也有各種top來統(tǒng)計(jì)資源消耗者,也有各種ls來查看系統(tǒng)硬件如lsblk、lsusb、lscpi。基本上跟著你的感覺走,就能找到相應(yīng)的工具,因?yàn)榧s定是系統(tǒng)中最強(qiáng)大的導(dǎo)向。
Linux有個(gè)比較另類的目錄/proc,承載了每個(gè)命令的蹂躪。像sysctl命令,就是修改的/proc/sys目錄下的映射項(xiàng)。不信看看find /proc/sys -type f | wc -l和sysctl -a| wc -l的結(jié)果是不是很像?
/proc文件系統(tǒng)是一個(gè)偽文件系統(tǒng),它只存在內(nèi)存當(dāng)中,而不占用外存空間。只不過以文件系統(tǒng)的方式為訪問系統(tǒng)內(nèi)核數(shù)據(jù)的操作提供接口。系統(tǒng)的所有狀態(tài)都逃不過它的火眼金睛。例如:
cat /proc/vmstat 看一下,是不是和vmstat命令的輸出很像?
cat /proc/meminfo 是不是最全的內(nèi)存信息
cat /proc/slabinfo 這不就是slabtop的信息么
cat /proc/devices 已經(jīng)加載對(duì)設(shè)備們
cat /proc/loadavg load avg原來就躺在這里啊
cat /proc/stat 所有的CPU活動(dòng)信息
ls /proc/$pid/fd 靜靜地躺著lsof的結(jié)果
一般排查問題的方法
一般排查問題也是圍繞著內(nèi)存cpu等幾個(gè)元素去排查。下圖是一張大體的排查故障或者性能問題的過程,看圖,不多說。
應(yīng)用場(chǎng)景舉例
下面舉例從具體應(yīng)用場(chǎng)景來說明各種命令的組合應(yīng)用,此類場(chǎng)景數(shù)不勝數(shù),需要個(gè)人積累。但強(qiáng)烈建議將sed和awk練的熟練一些。
怎么查看某個(gè)Java進(jìn)程里面占用CPU最高的一個(gè)線程具體信息?
獲取進(jìn)程中占用CPU最高的線程,計(jì)為n。
使用top top -H -p pid,肉眼觀察之
使用ps ?ps -mo spid,lwp,stime,time,%cpu -p pid
將線程號(hào)轉(zhuǎn)化成十六進(jìn)制printf 0x%x n
使用jstack找到相應(yīng)進(jìn)程,打印線程后的100行信息 jstack -l pid| grep spid -A 100
統(tǒng)計(jì)每種網(wǎng)絡(luò)狀態(tài)的數(shù)量
netstat -ant | awk '{print $6}' | sort | uniq -c | sort -n -k 1 -r
首先使用netstat查看列表,使用’awk’截取第六列,使用uniq進(jìn)行統(tǒng)計(jì),并對(duì)統(tǒng)計(jì)結(jié)果排序。當(dāng)然,也可以這樣。netstat -ant | awk '{arr[$6]++}END{for(i in arr){print arr[i]" "i }}' | sort -n -k 1 -r
這和“分析apache日志,給出當(dāng)日訪問ip的降序列表”是一樣的問題。
怎么查看哪個(gè)進(jìn)程在用swap
首先要了解/proc/$pid/smaps里有我們所需要的各種信息,其中Swap字段即是我們所需要的。只要循環(huán)遍歷一下即可。
for i in `cd /proc;ls |grep "^[0-9]"|awk ' $0 >100'` ;do awk '/Swap:/{a=a+$2}END{print '"$i"',a/1024"M"}' /proc/$i/smaps ;done |sort -k2nr最后,附上http://www.brendangregg.com/ 的大圖一張
End
軟件領(lǐng)域有兩種人才,一種是工程型的,一種是研究型的。在Linux領(lǐng)域里,相對(duì)于搞內(nèi)核研究的來說,搞命令行的就屬于工程型。工程型也有他自己的苦衷,比如,背誦命令就挺痛苦的,一般來說不太推薦背誦,第一覆蓋的面不廣,第二記的快忘的也快,浪費(fèi)腦細(xì)胞。牛逼的記法就是用,用時(shí)間來沖淡煙云,見微知著,并體驗(yàn)其中的喜悅。愛她并天天抱她上床,真愛才成。
總結(jié)
以上是生活随笔為你收集整理的kali linux 升级命令_作为高级Java,你应该了解的Linux知识的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java 多路归并_归并排序(Java)
- 下一篇: 这段代码什么意思啊?