面經七

linux經常使用命令(如何查看啓動的進程,查看一個線程的堆棧信息。查看一個進程堆的gc狀況等)java

一、cd命令linux

這是一個很是基本,也是你們常常須要使用的命令,它用於切換當前目錄,它的參數是要切換到的目錄的路徑,能夠是絕對路徑,也能夠是相對路徑。如:
    1. cd /root/Docements # 切換到目錄/root/Docements  
    2. cd ./path          # 切換到當前目錄下的path目錄中,「.」表示當前目錄    
    3. cd ../path         # 切換到上層目錄中的path目錄中,「..」表示上一層目錄

二、ls命令正則表達式

這是一個很是有用的查看文件與目錄的命令,list之意,它的參數很是多,下面就列出一些我經常使用的參數吧,以下:
    1. -l :列出長數據串,包含文件的屬性與權限數據等  
    2. -a :列出所有的文件,連同隱藏文件(開頭爲.的文件)一塊兒列出來(經常使用)  
    3. -d :僅列出目錄自己,而不是列出目錄的文件數據  
    4. -h :將文件容量以較易讀的方式(GB,kB等)列出來  
    5. -R :連同子目錄的內容一塊兒列出(遞歸列出),等於該目錄下的全部文件都會顯示出來 

注:這些參數也能夠組合使用,下面舉兩個例子:redis

  1. ls -l #以長數據串的形式列出當前目錄下的數據文件和目錄  
  2. ls -lR #以長數據串的形式列出當前目錄下的全部文件  
三、grep命令
該命令經常使用於分析一行的信息,若當中有咱們所須要的信息,就將該行顯示出來,該命令一般與管道命令一塊兒使用,用於對一些命令的輸出進行篩選加工等等,它的簡單語法爲
  1. grep [-acinv] [--color=auto] '查找字符串' filename  
它的經常使用參數以下:
 
    1. -a :將binary文件以text文件的方式查找數據  
    2. -c :計算找到‘查找字符串’的次數  
    3. -i :忽略大小寫的區別,即把大小寫視爲相同  
    4. -v :反向選擇,即顯示出沒有‘查找字符串’內容的那一行  
    5. # 例如:  
    6. # 取出文件/etc/man.config中包含MANPATH的行,並把找到的關鍵字加上顏色  
    7. grep --color=auto 'MANPATH' /etc/man.config  
    8. # 把ls -l的輸出中包含字母file(不區分大小寫)的內容輸出  
    9. ls -l | grep -i file 

四、find命令算法

find是一個基於查找的功能很是強大的命令,相對而言,它的使用也相對較爲複雜,參數也比較多,因此在這裏將給把它們分類列出,它的基本語法以下:
  1. find [PATH] [option] [action]  
  2.   
  3. # 與時間有關的參數:  
  4. -mtime n : n爲數字,意思爲在n天以前的「一天內」被更改過的文件;  
  5. -mtime +n : 列出在n天以前(不含n天自己)被更改過的文件名;  
  6. -mtime -n : 列出在n天以內(含n天自己)被更改過的文件名;  
  7. -newer file : 列出比file還要新的文件名  
  8. # 例如:  
  9. find /root -mtime 0 # 在當前目錄下查找今天以內有改動的文件  
  10.   
  11. # 與用戶或用戶組名有關的參數:  
  12. -user name : 列出文件全部者爲name的文件  
  13. -group name : 列出文件所屬用戶組爲name的文件  
  14. -uid n : 列出文件全部者爲用戶ID爲n的文件  
  15. -gid n : 列出文件所屬用戶組爲用戶組ID爲n的文件  
  16. # 例如:  
  17. find /home/ljianhui -user ljianhui # 在目錄/home/ljianhui中找出全部者爲ljianhui的文件  
  18.   
  19. # 與文件權限及名稱有關的參數:  
  20. -name filename :找出文件名爲filename的文件  
  21. -size [+-]SIZE :找出比SIZE還要大(+)或小(-)的文件  
  22. -tpye TYPE :查找文件的類型爲TYPE的文件,TYPE的值主要有:通常文件(f)、設備文件(b、c)、  
  23.              目錄(d)、鏈接文件(l)、socket(s)、FIFO管道文件(p);  
  24. -perm mode :查找文件權限恰好等於mode的文件,mode用數字表示,如0755;  
  25. -perm -mode :查找文件權限必需要所有包括mode權限的文件,mode用數字表示  
  26. -perm +mode :查找文件權限包含任一mode的權限的文件,mode用數字表示  
  27. # 例如:  
  28. find / -name passwd # 查找文件名爲passwd的文件  
  29. find . -perm 0755 # 查找當前目錄中文件權限的0755的文件  
  30. find . -size +12k # 查找當前目錄中大於12KB的文件,注意c表示byte  
五、cp命令
該命令用於複製文件,copy之意,它還能夠把多個文件一次性地複製到一個目錄下,它的經常使用參數以下:
  1. -a :將文件的特性一塊兒複製  
  2. -p :連同文件的屬性一塊兒複製,而非使用默認方式,與-a類似,經常使用於備份  
  3. -i :若目標文件已經存在時,在覆蓋時會先詢問操做的進行  
  4. -r :遞歸持續複製,用於目錄的複製行爲  
  5. -u :目標文件與源文件有差別時纔會複製  
例如 :
  1. cp -a file1 file2 #連同文件的全部特性把文件file1複製成文件file2  
  2. cp file1 file2 file3 dir #把文件file一、file二、file3複製到目錄dir中  
六、mv命令
該命令用於移動文件、目錄或改名,move之意,它的經常使用參數以下:
  1. -f :force強制的意思,若是目標文件已經存在,不會詢問而直接覆蓋  
  2. -i :若目標文件已經存在,就會詢問是否覆蓋  
  3. -u :若目標文件已經存在,且比目標文件新,纔會更新  
注:該命令能夠把一個文件或多個文件一次移動一個文件夾中,可是最後一個目標文件必定要是「目錄」。
 
例如:
  1. mv file1 file2 file3 dir # 把文件file一、file二、file3移動到目錄dir中  
  2. mv file1 file2 # 把文件file1重命名爲file2  
七、rm命令
該命令用於刪除文件或目錄,remove之間,它的經常使用參數以下:
  1. -f :就是force的意思,忽略不存在的文件,不會出現警告消息  
  2. -i :互動模式,在刪除前會詢問用戶是否操做  
  3. -r :遞歸刪除,最經常使用於目錄刪除,它是一個很是危險的參數  
例如:
  1. rm -i file # 刪除文件file,在刪除以前會詢問是否進行該操做  
  2. rm -fr dir # 強制刪除目錄dir中的全部文件  
八、ps命令
該命令用於將某個時間點的進程運行狀況選取下來並輸出,process之意,它的經常使用參數以下:
  1. -A :全部的進程均顯示出來  
  2. -a :不與terminal有關的全部進程  
  3. -u :有效用戶的相關進程  
  4. -x :通常與a參數一塊兒使用,可列出較完整的信息  
  5. -l :較長,較詳細地將PID的信息列出  
其實咱們只要記住ps通常使用的命令參數搭配便可,它們並很少,以下:
  1. ps aux # 查看系統全部的進程數據  
  2. ps ax # 查看不與terminal有關的全部進程  
  3. ps -lA # 查看系統全部的進程數據  
  4. ps axjf # 查看連同一部分進程樹狀態  
九、kill命令
該命令用於向某個工做(%jobnumber)或者是某個PID(數字)傳送一個信號,它一般與ps和jobs命令一塊兒使用,它的基本語法以下:
  1. kill -signal PID  
signal的經常使用參數以下:
注:最前面的數字爲信號的代號,使用時能夠用代號代替相應的信號。
  1. 1:SIGHUP,啓動被終止的進程  
  2. 2:SIGINT,至關於輸入ctrl+c,中斷一個程序的進行  
  3. 9:SIGKILL,強制中斷一個進程的進行  
  4. 15:SIGTERM,以正常的結束進程方式來終止進程  
  5. 17:SIGSTOP,至關於輸入ctrl+z,暫停一個進程的進行  
例如:
  1. # 以正常的結束進程方式來終於第一個後臺工做,可用jobs命令查看後臺中的第一個工做進程  
  2. kill -SIGTERM %1   
  3. # 從新改動進程ID爲PID的進程,PID可用ps命令經過管道命令加上grep命令進行篩選得到  
  4. kill -SIGHUP PID  
十、killall命令
該命令用於向一個命令啓動的進程發送一個信號,它的通常語法以下:
  1. killall [-iIe] [command name]  
它的參數以下:
  1. -i :交互式的意思,若須要刪除時,會詢問用戶  
  2. -e :表示後面接的command name要一致,但command name不能超過15個字符  
  3. -I :命令名稱忽略大小寫  
  4. # 例如:  
  5. killall -SIGHUP syslogd # 從新啓動syslogd  
十一、file命令
該命令用於判斷接在file命令後的文件的基本數據,由於在Linux下文件的類型並非之後綴爲分的,因此這個命令對咱們來講就頗有用了,它的用法很是簡單,基本語法以下:
  1. file filename  
  2. #例如:  
  3. file ./test  
十二、tar命令
該命令用於對文件進行打包,默認狀況並不會壓縮,若是指定了相應的參數,它還會調用相應的壓縮程序(如gzip和bzip等)進行壓縮和解壓。它的經常使用參數以下:
  1. -c :新建打包文件  
  2. -t :查看打包文件的內容含有哪些文件名  
  3. -x :解打包或解壓縮的功能,能夠搭配-C(大寫)指定解壓的目錄,注意-c,-t,-x不能同時出如今同一條命令中  
  4. -j :經過bzip2的支持進行壓縮/解壓縮  
  5. -z :經過gzip的支持進行壓縮/解壓縮  
  6. -v :在壓縮/解壓縮過程當中,將正在處理的文件名顯示出來  
  7. -f filename :filename爲要處理的文件  
  8. -C dir :指定壓縮/解壓縮的目錄dir  
上面的解說能夠已經讓你暈過去了,可是一般咱們只須要記住下面三條命令便可:
  1. 壓縮:tar -jcv -f filename.tar.bz2 要被處理的文件或目錄名稱  
  2. 查詢:tar -jtv -f filename.tar.bz2  
  3. 解壓:tar -jxv -f filename.tar.bz2 -C 欲解壓縮的目錄  
注:文件名並不定要之後綴tar.bz2結尾,這裏主要是爲了說明使用的壓縮程序爲bzip2
 
1三、cat命令
該命令用於查看文本文件的內容,後接要查看的文件名,一般可用管道與more和less一塊兒使用,從而能夠一頁頁地查看數據。例如:
  1. cat text | less # 查看text文件中的內容  
  2. # 注:這條命令也可使用less text來代替  
1四、chgrp命令
該命令用於改變文件所屬用戶組,它的使用很是簡單,它的基本用法以下:
[plain]  view plain  copy
  1. chgrp [-R] dirname/filename  
  2. -R :進行遞歸的持續對全部文件和子目錄更改  
  3. # 例如:  
  4. chgrp users -R ./dir # 遞歸地把dir目錄下中的全部文件和子目錄下全部文件的用戶組修改成users  
1五、chown命令
該命令用於改變文件的全部者,與chgrp命令的使用方法相同,只是修改的文件屬性不一樣,再也不詳述。
 
1六、chmod命令
該命令用於改變文件的權限,通常的用法以下:
  1. chmod [-R] xyz 文件或目錄  
  2. -R:進行遞歸的持續更改,即連同子目錄下的全部文件都會更改  
同時,chmod還可使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(刪除)、=(設置)跟rwx搭配來對文件的權限進行更改。
 
  1. # 例如:  
  2. chmod 0755 file # 把file的文件權限改變爲-rxwr-xr-x  
  3. chmod g+w file # 向file的文件權限中加入用戶組可寫權限  
1八、vim命令
該命令主要用於文本編輯,它接一個或多個文件名做爲參數,若是文件存在就打開,若是文件不存在就以該文件名建立一個文件。vim是一個很是好用的文本編輯器,它裏面有不少很是好用的命令,在這裏再也不多說。你能夠從這裏下載 vim經常使用操做的詳細說明。
 
1九、gcc命令
對於一個用Linux開發C程序的人來講,這個命令就很是重要了,它用於把C語言的源程序文件,編譯成可執行程序,因爲g++的不少參數跟它很是類似,因此這裏只介紹gcc的參數,它的經常使用參數以下:
  1. -o :output之意,用於指定生成一個可執行文件的文件名  
  2. -c :用於把源文件生成目標文件(.o),並阻止編譯器建立一個完整的程序  
  3. -I :增長編譯時搜索頭文件的路徑  
  4. -L :增長編譯時搜索靜態鏈接庫的路徑  
  5. -S :把源文件生成彙編代碼文件  
  6. -lm:表示標準庫的目錄中名爲libm.a的函數庫  
  7. -lpthread :鏈接NPTL實現的線程庫  
  8. -std= :用於指定把使用的C語言的版本  
  9.   
  10. # 例如:  
  11. # 把源文件test.c按照c99標準編譯成可執行程序test  
  12. gcc -o test test.c -lm -std=c99  
  13. #把源文件test.c轉換爲相應的彙編程序源文件test.s  
  14. gcc -S test.c  
20、time命令
該命令用於測算一個命令(即程序)的執行時間。它的使用很是簡單,就像平時輸入命令同樣,不過在命令的前面加入一個time便可,例如:
  1. time ./process  
  2. time ps aux  
在程序或命令運行結束後,在最後輸出了三個時間,它們分別是:
user:用戶CPU時間,命令執行完成花費的用戶CPU時間,即命令在用戶態中執行時間總和;
system:系統CPU時間,命令執行完成花費的系統CPU時間,即命令在覈心態中執行時間總和;
real:實際時間,從command命令行開始執行到運行終止的消逝時間;
 
注:用戶CPU時間和系統CPU時間之和爲CPU時間,即命令佔用CPU執行的時間總和。實際時間要大於CPU時間,由於Linux是多任務操做系統,每每在執行一條命令時,系統還要處理其它任務。另外一個須要注意的問題是即便每次執行相同命令,但所花費的時間也是不同,其花費時間是與系統運行相關的。
 
 
 

epoll,select的區別,若是服務器上有一個文件你正在下載,有人不當心刪除會發生什麼?spring

瞭解過度布式消息隊列?sql

消息隊列概述 消息隊列中間件是分佈式系統中重要的組件,主要解決應用耦合,異步消息,流量削鋒等問題。實現高性能,高可用,可伸縮和最終一致性架構。是大型分佈式系統不可缺乏的中間件。 目前在生產環境,使用較多的消息隊列有ActiveMQ,RabbitMQ,ZeroMQ,Kafka,MetaMQ,RocketMQ等。數據庫

最主要得應用場景:解耦 異步 削峯編程

(1)解耦vim

傳統模式:系統間得耦合度強 如系統A直接調用系統B系統C得代碼,若是再有系統D接入,則系統A還要修改代碼。

中間件模式:系統A將消息寫入消息隊列,系統B,系統C 訂閱消息隊列,若是再有系統D介入,直接訂閱消息隊列便可 系統A沒必要修改代碼

(2)異步

傳統模式:一些非必要得業務邏輯以同步得方式運行浪費時間

中間件模式:將消息寫入消息隊列 一些非必要得業務邏輯以異步得方式運行 提升響應速度

(3)削峯

傳統模式:併發量大得時候全部請求所有到數據庫,形成數據庫鏈接異常

中間件模式:系統慢慢得按照數據庫能處理得併發量從消息隊列中慢慢拉去消息。在生產環境中這種短暫得高峯期積壓是容許的。

2  使用消息隊列的缺點

  (1) 系統的可用性下降

     消息隊列會掛掉 一但掛掉 就會影響可用性

(2) 系統複雜性增長 

考慮一致性問題 保證消息不被重複消費 保證消息可靠傳輸

3  消息隊列選型

 

 

 

jvm內存區域劃分,哪些垃圾回收器分別適用在什麼場景

遇到過oom,有哪些可能發生oom的區域,如何解決

spring中遇到哪些設計模式

  • 工廠設計模式 : Spring使用工廠模式經過 BeanFactoryApplicationContext 建立 bean 對象。
  • 代理設計模式 : Spring AOP 功能的實現。
  • 單例設計模式 : Spring 中的 Bean 默認都是單例的。
  • 模板方法模式 : Spring 中 jdbcTemplatehibernateTemplate 等以 Template 結尾的對數據庫操做的類,它們就使用到了模板模式。
  • 包裝器設計模式 : 咱們的項目須要鏈接多個數據庫,並且不一樣的客戶在每次訪問中根據須要會去訪問不一樣的數據庫。這種模式讓咱們能夠根據客戶的需求可以動態切換不一樣的數據源。
  • 觀察者模式: Spring 事件驅動模型就是觀察者模式很經典的一個應用。
  • 適配器模式 :Spring AOP 的加強或通知(Advice)使用到了適配器模式、spring MVC 中也是用到了適配器模式適配Controller
  • ……

 

aop是什麼

  • 切面(Aspect):指的就是通用功能的代碼實現,好比咱們上面演示的時間記錄切面,日誌切面,它們都是普通的Java類:TimeRecordingAspectLogAspect

  • 目標對象(Target):要被織入切面的對象,例子中的CtripBookingService,有了AOP,它們能夠專一於核心業務邏輯代碼了!

  • 切入點(Pointcut):定義通知應該切入到什麼地方,Spring支持的切入點就是方法調用,切入點的定義可使用正則表達式,用以描述什麼類型的方法調用。@Pointcut就是用來定義切入點的。

  • 通知(Advice):切面是一個類,而通知就是類裏的方法以及這個方法如何織入到目標方法的方式(用@AfterReturning@Around標註的方法)。咱們的例子中只展現了兩類通知,根據織入到目標方法方式的不一樣,一共能夠分爲5種:

    • 前置通知(Before)
    • 後置通知(AfterReturning)
    • 異常通知(AfterThrowing)
    • 最終通知(After)
    • 環繞通知(Around)
  • 織入(Weaving):AOP實現的過程,即將切面應用到目標對象,從而建立一個新的代理對象的過程,對於Spring來講,就是初始化Context中的對象時,完成織入操做。

 

 

 

mybatis和hibernate框架有什麼區別

1、相同點
Mybatis和Hibernate都是java中ORM框架、屏蔽jdbc api 的底層訪問細節,使用時咱們不用與jdbc api打交道,就能夠完成對數據庫的持久化操做。jdbc api編程流程固定,還將sql語句與java代碼混雜在一塊兒,常常須要拼湊sql語句,細節很繁瑣。
1).Mybatis的優勢
屏蔽jdbc api的底層訪問細節,將sql語句與java代碼進行分離,提供了將結果集自動封裝稱爲實體對象和對象的集合的功能,queryForList返回對象集合,用queryForObject返回單個對象,提供了自動將實體對象的屬性傳遞給SQL語句的參數。
2).Hibernate的優勢
Hibernate是一個全自動的ORM映射工具,它能夠自動生成sql語句,並執行返回java結果。

2、不一樣點
1)
hibernate比Mybatis功能強大,由於hibernate自動生成SQL語句。
2)
Mybatis須要咱們本身在xml配置文件中寫SQL語句,hibernate咱們沒法直接控制該語句,咱們就沒法去寫特定的高效率的SQL,對於一些不太複雜的SQL查詢,hibernate能夠很好幫助咱們完成,可是對於特別複雜的查詢,hibernate就很難適應了,這時候用mybatis就是不錯的選擇,由於mybatis仍是由咱們本身寫SQL語句。
3)
mybatis比hibernate簡單的多,mybatis是面向SQL的,不用考慮對象間一些複雜的映射關係。

 

 

適用mabtis有沒有用到om對象

kafka如何實現消息是有序的?如何實現多線程的消費

hashmap和hashtable有什麼區別

一個場景如今數據庫執行過長,如何對它進行優化

說一下數據庫有哪些索引類型,有什麼優缺點

談一下數據庫的事務(ACID特性)

操做系統的劃分有哪些

tcp協議有哪些計時器,他們分別是作什麼的

操做系統之間有用戶態和內核態,他們之間有什麼區別

爲何須要內核態,何時進入內核態

有用過內存緩存嗎?redis

redis是經過什麼方式進行持久化的?

https協議瞭解嗎

介紹一下常見算法,哪些是穩定的哪些是不穩定的,以及時間複雜度

雲計算有哪些服務和應用場景

相關文章
相關標籤/搜索