Linux
Linux的基本思想有兩點(diǎn):第一,一切都是文件;第二,每個(gè)軟件都有確定的用途。其中第一條詳細(xì)來講就是系統(tǒng)中的所有都?xì)w結(jié)為一個(gè)文件,包括命令、硬件和軟件設(shè)備、操作系統(tǒng)、進(jìn)程等等對(duì)于操作系統(tǒng)內(nèi)核而言,都被視為擁有各自特性或類型的文件。至于說Linux是基于Unix的,很大程度上也是因?yàn)檫@兩者的基本思想十分相近。
Linux是一款免費(fèi)的操作系統(tǒng),用戶可以通過網(wǎng)絡(luò)或其他途徑免費(fèi)獲得,并可以任意修改其源代碼。這是其他的操作系統(tǒng)所做不到的。正是由于這一點(diǎn),來自全世界的無數(shù)程序員參與了Linux的修改、編寫工作,程序員可以根據(jù)自己的興趣和靈感對(duì)其進(jìn)行改變,這讓Linux吸收了無數(shù)程序員的精華,不斷壯大。
這使得可以在Linux下通過相應(yīng)的模擬器運(yùn)行常見的DOS、Windows的程序。這為用戶從Windows轉(zhuǎn)到Linux奠定了基礎(chǔ)。許多用戶在考慮使用Linux時(shí),就想到以前在Windows下常見的程序是否能正常運(yùn)行,這一點(diǎn)就消除了他們的疑慮。
Linux支持多用戶,各個(gè)用戶對(duì)于自己的文件設(shè)備有自己特殊的權(quán)利,保證了各用戶之間互不影響。多任務(wù)則是現(xiàn)在電腦最主要的一個(gè)特點(diǎn),Linux可以使多個(gè)程序同時(shí)并獨(dú)立地運(yùn)行。
Linux同時(shí)具有字符界面和圖形界面。在字符界面用戶可以通過鍵盤輸入相應(yīng)的指令來進(jìn)行操作。它同時(shí)也提供了類似Windows圖形界面的X-Window系統(tǒng),用戶可以使用鼠標(biāo)對(duì)其進(jìn)行操作。在X-Window環(huán)境中就和在Windows中相似,可以說是一個(gè)Linux版的Windows。
Linux可以運(yùn)行在多種硬件平臺(tái)上,如具有x86、680x0、SPARC、Alpha等處理器的平臺(tái)。此外Linux還是一種嵌入式操作系統(tǒng),可以運(yùn)行在掌上電腦、機(jī)頂盒或游戲機(jī)上。2001年1月份發(fā)布的Linux 2.4版內(nèi)核已經(jīng)能夠完全支持Intel 64位芯片架構(gòu)。同時(shí)Linux也支持多處理器技術(shù)。多個(gè)處理器同時(shí)工作,使系統(tǒng)性能大大提高。
linux常用命令及技巧
通用命令:
1. date :print or set the system date and time
2. stty -a: 可以查看或者打印控制字符(Ctrl-C, Ctrl-D, Ctrl-Z等)
3. passwd: print or set the system date and time (用passwd -h查看)
4. logout, login: 登錄shell的登錄和注銷命令
5. pwd: print or set the system date and time
6. more, less, head tail: 顯示或部分顯示文件內(nèi)容。
7. lp/lpstat/cancel, lpr/lpq/lprm: 打印文件。
8. 更改文件權(quán)限: chmod u+x.。。
9. 刪除非空目錄:rm -fr dir
10.拷貝目錄: cp -R dir
11. fg jobid :可以將一個(gè)后臺(tái)進(jìn)程放到前臺(tái)。
Ctrl-z 可以將前臺(tái)進(jìn)程掛起(suspend), 然后可以用bg jobid 讓其到后臺(tái)運(yùn)行。
job & 可以直接讓job直接在后臺(tái)運(yùn)行。
12. kill 的作用: send a signal to a process. eg: kill -9 發(fā)送的是SIG_KILL信號(hào)。。。 具體發(fā)送什么信號(hào) 可以通過 man kill 查看。
13. ps 的用法, ps -e 或 ps -o pid,ppid,session,tpgid, comm (其中session顯示的sessionid, tpgid顯示前臺(tái)進(jìn)程組id, comm顯示命令名稱。)
Linux下查看某一個(gè)程序所使用的內(nèi)存方法
第一種方式
top -p 進(jìn)程號(hào)1
?。踶zy@node3 micro-service]$ top -p 20490
top - 16:50:32 up 6 days, 2:18, 1 user, load average: 0.00, 0.01, 0.05
Tasks: 1 total, 0 running, 1 sleeping, 0 stopped, 0 zombie
%Cpu(s): 0.1 us, 0.1 sy, 0.0 ni, 99.8 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem : 65876972 total, 51899292 free, 9988408 used, 3989272 buff/cache
KiB Swap: 32964604 total, 32964604 free, 0 used. 55522228 avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
20490 yzy 20 0 113252 1632 1272 S 0.0 0.0 0:35.50 sh 123456789
第二種方式
ps -aux | grep 進(jìn)程名1
[zhoulu@node3 micro-service]$ ps -aux | grep eureka-auto.sh
zhoulu 3716 0.0 0.0 112640 972 pts/0 S+ 16:49 0:00 grep --color=auto eureka-auto.sh
zhoulu 20490 0.0 0.0 113252 1632 ? S Apr14 0:35 /bin/sh 。/eureka-auto.sh123
第三種方式
cat /proc/進(jìn)程號(hào)/status1
?。踷houlu@node3 micro-service]$ cat /proc/20490/status
Name: sh
State: S (sleeping)
Tgid: 20490
Ngid: 0
Pid: 20490
PPid: 1
TracerPid: 0
Uid: 1019 1019 1019 1019
Gid: 1019 1019 1019 1019
FDSize: 256
Groups: 1019
VmPeak: 113256 kB
VmSize: 113252 kB
VmLck: 0 kB
VmPin: 0 kB
VmHWM: 1632 kB
VmRSS: 1632 kB
VmData: 340 kB
VmStk: 136 kB
VmExe: 884 kB
VmLib: 2044 kB
VmPTE: 52 kB
VmSwap: 0 kB
Threads: 1
SigQ: 0/257254
SigPnd: 0000000000000000
ShdPnd: 0000000000000000
SigBlk: 0000000000010000
SigIgn: 0000000000000005
SigCgt: 0000000000010002
CapInh: 0000000000000000
CapPrm: 0000000000000000
CapEff: 0000000000000000
CapBnd: 0000001fffffffff
Seccomp: 0
Cpus_allowed: ffff
Cpus_allowed_list: 0-15
Mems_allowed: 00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000001
Mems_allowed_list: 0
voluntary_ctxt_switches: 102189
nonvoluntary_ctxt_switches: 170123456789101112131415161718192021222324252627282930313233343536373839404142
VmSize(KB) 任務(wù)虛擬地址空間的大小 (total_vm-reserved_vm),其中total_vm為進(jìn)程的地址空間的大小,reserved_vm:進(jìn)程在預(yù)留或特殊的內(nèi)存間的物理頁
VmLck(KB) 任務(wù)已經(jīng)鎖住的物理內(nèi)存的大小。鎖住的物理內(nèi)存不能交換到硬盤 (locked_vm)
VmRSS(KB) 應(yīng)用程序正在使用的物理內(nèi)存的大小,就是用ps命令的參數(shù)rss的值 (rss)
VmData(KB) 程序數(shù)據(jù)段的大?。ㄋ继摂M內(nèi)存的大小),存放初始化了的數(shù)據(jù); (total_vm-shared_vm-stack_vm)
VmStk(KB) 任務(wù)在用戶態(tài)的棧的大小 (stack_vm)
VmExe(KB) 程序所擁有的可執(zhí)行虛擬內(nèi)存的大小,代碼段,不包括任務(wù)使用的庫 (end_code-start_code)
VmLib(KB) 被映像到任務(wù)的虛擬內(nèi)存空間的庫的大小 (exec_lib)
VmPTE 該進(jìn)程的所有頁表的大小,單位:kb
Threads 共享使用該信號(hào)描述符的任務(wù)的個(gè)數(shù),在POSIX多線程序應(yīng)用程序中,線程組中的所有線程使用同一個(gè)信號(hào)描述符
1、VmRSS是真實(shí)正在占用的內(nèi)存,而VmData是虛擬內(nèi)存,大小差異大并沒有什么問題。
2、VmData是指數(shù)據(jù)段的內(nèi)存大小,存放初始化了的數(shù)據(jù); (total_vm-shared_vm-stack_vm)
3、不調(diào)動(dòng)態(tài)庫的時(shí)候是不計(jì)算的(dlopen方式)
4、靜態(tài)庫會(huì)編譯為程序本身的一部分,不在VmLib的統(tǒng)計(jì)之內(nèi)。
5、參考上面的說明
6、除非有非常明顯的內(nèi)存泄露,如內(nèi)存一直大幅度增長(zhǎng)并長(zhǎng)時(shí)間不釋放,否則單純以來這些值是很判斷真正的內(nèi)在泄露。
評(píng)論