linux經常使用命令(如何查看啓動的進程,查看一個線程的堆棧信息。查看一個進程堆的gc狀況等)java
一、cd命令linux
這是一個很是基本,也是你們常常須要使用的命令,它用於切換當前目錄,它的參數是要切換到的目錄的路徑,能夠是絕對路徑,也能夠是相對路徑。如:
- cd /root/Docements # 切換到目錄/root/Docements
- cd ./path # 切換到當前目錄下的path目錄中,「.」表示當前目錄
- cd ../path # 切換到上層目錄中的path目錄中,「..」表示上一層目錄
二、ls命令正則表達式
這是一個很是有用的查看文件與目錄的命令,list之意,它的參數很是多,下面就列出一些我經常使用的參數吧,以下:
- -l :列出長數據串,包含文件的屬性與權限數據等
- -a :列出所有的文件,連同隱藏文件(開頭爲.的文件)一塊兒列出來(經常使用)
- -d :僅列出目錄自己,而不是列出目錄的文件數據
- -h :將文件容量以較易讀的方式(GB,kB等)列出來
- -R :連同子目錄的內容一塊兒列出(遞歸列出),等於該目錄下的全部文件都會顯示出來
注:這些參數也能夠組合使用,下面舉兩個例子:redis
- ls -l #以長數據串的形式列出當前目錄下的數據文件和目錄
- ls -lR #以長數據串的形式列出當前目錄下的全部文件
三、grep命令
該命令經常使用於分析一行的信息,若當中有咱們所須要的信息,就將該行顯示出來,該命令一般與管道命令一塊兒使用,用於對一些命令的輸出進行篩選加工等等,它的簡單語法爲
- grep [-acinv] [--color=auto] '查找字符串' filename
它的經常使用參數以下:
- -a :將binary文件以text文件的方式查找數據
- -c :計算找到‘查找字符串’的次數
- -i :忽略大小寫的區別,即把大小寫視爲相同
- -v :反向選擇,即顯示出沒有‘查找字符串’內容的那一行
- # 例如:
- # 取出文件/etc/man.config中包含MANPATH的行,並把找到的關鍵字加上顏色
- grep --color=auto 'MANPATH' /etc/man.config
- # 把ls -l的輸出中包含字母file(不區分大小寫)的內容輸出
- ls -l | grep -i file
四、find命令算法
find是一個基於查找的功能很是強大的命令,相對而言,它的使用也相對較爲複雜,參數也比較多,因此在這裏將給把它們分類列出,它的基本語法以下:
- find [PATH] [option] [action]
-
- # 與時間有關的參數:
- -mtime n : n爲數字,意思爲在n天以前的「一天內」被更改過的文件;
- -mtime +n : 列出在n天以前(不含n天自己)被更改過的文件名;
- -mtime -n : 列出在n天以內(含n天自己)被更改過的文件名;
- -newer file : 列出比file還要新的文件名
- # 例如:
- find /root -mtime 0 # 在當前目錄下查找今天以內有改動的文件
-
- # 與用戶或用戶組名有關的參數:
- -user name : 列出文件全部者爲name的文件
- -group name : 列出文件所屬用戶組爲name的文件
- -uid n : 列出文件全部者爲用戶ID爲n的文件
- -gid n : 列出文件所屬用戶組爲用戶組ID爲n的文件
- # 例如:
- find /home/ljianhui -user ljianhui # 在目錄/home/ljianhui中找出全部者爲ljianhui的文件
-
- # 與文件權限及名稱有關的參數:
- -name filename :找出文件名爲filename的文件
- -size [+-]SIZE :找出比SIZE還要大(+)或小(-)的文件
- -tpye TYPE :查找文件的類型爲TYPE的文件,TYPE的值主要有:通常文件(f)、設備文件(b、c)、
- 目錄(d)、鏈接文件(l)、socket(s)、FIFO管道文件(p);
- -perm mode :查找文件權限恰好等於mode的文件,mode用數字表示,如0755;
- -perm -mode :查找文件權限必需要所有包括mode權限的文件,mode用數字表示
- -perm +mode :查找文件權限包含任一mode的權限的文件,mode用數字表示
- # 例如:
- find / -name passwd # 查找文件名爲passwd的文件
- find . -perm 0755 # 查找當前目錄中文件權限的0755的文件
- find . -size +12k # 查找當前目錄中大於12KB的文件,注意c表示byte
五、cp命令
該命令用於複製文件,copy之意,它還能夠把多個文件一次性地複製到一個目錄下,它的經常使用參數以下:
- -a :將文件的特性一塊兒複製
- -p :連同文件的屬性一塊兒複製,而非使用默認方式,與-a類似,經常使用於備份
- -i :若目標文件已經存在時,在覆蓋時會先詢問操做的進行
- -r :遞歸持續複製,用於目錄的複製行爲
- -u :目標文件與源文件有差別時纔會複製
例如 :
- cp -a file1 file2 #連同文件的全部特性把文件file1複製成文件file2
- cp file1 file2 file3 dir #把文件file一、file二、file3複製到目錄dir中
六、mv命令
該命令用於移動文件、目錄或改名,move之意,它的經常使用參數以下:
- -f :force強制的意思,若是目標文件已經存在,不會詢問而直接覆蓋
- -i :若目標文件已經存在,就會詢問是否覆蓋
- -u :若目標文件已經存在,且比目標文件新,纔會更新
注:該命令能夠把一個文件或多個文件一次移動一個文件夾中,可是最後一個目標文件必定要是「目錄」。
例如:
- mv file1 file2 file3 dir # 把文件file一、file二、file3移動到目錄dir中
- mv file1 file2 # 把文件file1重命名爲file2
七、rm命令
該命令用於刪除文件或目錄,remove之間,它的經常使用參數以下:
- -f :就是force的意思,忽略不存在的文件,不會出現警告消息
- -i :互動模式,在刪除前會詢問用戶是否操做
- -r :遞歸刪除,最經常使用於目錄刪除,它是一個很是危險的參數
例如:
- rm -i file # 刪除文件file,在刪除以前會詢問是否進行該操做
- rm -fr dir # 強制刪除目錄dir中的全部文件
八、ps命令
該命令用於將某個時間點的進程運行狀況選取下來並輸出,process之意,它的經常使用參數以下:
- -A :全部的進程均顯示出來
- -a :不與terminal有關的全部進程
- -u :有效用戶的相關進程
- -x :通常與a參數一塊兒使用,可列出較完整的信息
- -l :較長,較詳細地將PID的信息列出
其實咱們只要記住ps通常使用的命令參數搭配便可,它們並很少,以下:
- ps aux # 查看系統全部的進程數據
- ps ax # 查看不與terminal有關的全部進程
- ps -lA # 查看系統全部的進程數據
- ps axjf # 查看連同一部分進程樹狀態
九、kill命令
該命令用於向某個工做(%jobnumber)或者是某個PID(數字)傳送一個信號,它一般與ps和jobs命令一塊兒使用,它的基本語法以下:
signal的經常使用參數以下:
注:最前面的數字爲信號的代號,使用時能夠用代號代替相應的信號。
- 1:SIGHUP,啓動被終止的進程
- 2:SIGINT,至關於輸入ctrl+c,中斷一個程序的進行
- 9:SIGKILL,強制中斷一個進程的進行
- 15:SIGTERM,以正常的結束進程方式來終止進程
- 17:SIGSTOP,至關於輸入ctrl+z,暫停一個進程的進行
例如:
- # 以正常的結束進程方式來終於第一個後臺工做,可用jobs命令查看後臺中的第一個工做進程
- kill -SIGTERM %1
- # 從新改動進程ID爲PID的進程,PID可用ps命令經過管道命令加上grep命令進行篩選得到
- kill -SIGHUP PID
十、killall命令
該命令用於向一個命令啓動的進程發送一個信號,它的通常語法以下:
- killall [-iIe] [command name]
它的參數以下:
- -i :交互式的意思,若須要刪除時,會詢問用戶
- -e :表示後面接的command name要一致,但command name不能超過15個字符
- -I :命令名稱忽略大小寫
- # 例如:
- killall -SIGHUP syslogd # 從新啓動syslogd
十一、file命令
該命令用於判斷接在file命令後的文件的基本數據,由於在Linux下文件的類型並非之後綴爲分的,因此這個命令對咱們來講就頗有用了,它的用法很是簡單,基本語法以下:
- file filename
- #例如:
- file ./test
十二、tar命令
該命令用於對文件進行打包,默認狀況並不會壓縮,若是指定了相應的參數,它還會調用相應的壓縮程序(如gzip和bzip等)進行壓縮和解壓。它的經常使用參數以下:
- -c :新建打包文件
- -t :查看打包文件的內容含有哪些文件名
- -x :解打包或解壓縮的功能,能夠搭配-C(大寫)指定解壓的目錄,注意-c,-t,-x不能同時出如今同一條命令中
- -j :經過bzip2的支持進行壓縮/解壓縮
- -z :經過gzip的支持進行壓縮/解壓縮
- -v :在壓縮/解壓縮過程當中,將正在處理的文件名顯示出來
- -f filename :filename爲要處理的文件
- -C dir :指定壓縮/解壓縮的目錄dir
上面的解說能夠已經讓你暈過去了,可是一般咱們只須要記住下面三條命令便可:
- 壓縮:tar -jcv -f filename.tar.bz2 要被處理的文件或目錄名稱
- 查詢:tar -jtv -f filename.tar.bz2
- 解壓:tar -jxv -f filename.tar.bz2 -C 欲解壓縮的目錄
注:文件名並不定要之後綴tar.bz2結尾,這裏主要是爲了說明使用的壓縮程序爲bzip2
1三、cat命令
該命令用於查看文本文件的內容,後接要查看的文件名,一般可用管道與more和less一塊兒使用,從而能夠一頁頁地查看數據。例如:
- cat text | less # 查看text文件中的內容
- # 注:這條命令也可使用less text來代替
1四、chgrp命令
該命令用於改變文件所屬用戶組,它的使用很是簡單,它的基本用法以下:
- chgrp [-R] dirname/filename
- -R :進行遞歸的持續對全部文件和子目錄更改
- # 例如:
- chgrp users -R ./dir # 遞歸地把dir目錄下中的全部文件和子目錄下全部文件的用戶組修改成users
1五、chown命令
該命令用於改變文件的全部者,與chgrp命令的使用方法相同,只是修改的文件屬性不一樣,再也不詳述。
1六、chmod命令
該命令用於改變文件的權限,通常的用法以下:
- chmod [-R] xyz 文件或目錄
- -R:進行遞歸的持續更改,即連同子目錄下的全部文件都會更改
同時,chmod還可使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(刪除)、=(設置)跟rwx搭配來對文件的權限進行更改。
- # 例如:
- chmod 0755 file # 把file的文件權限改變爲-rxwr-xr-x
- chmod g+w file # 向file的文件權限中加入用戶組可寫權限
1八、vim命令
該命令主要用於文本編輯,它接一個或多個文件名做爲參數,若是文件存在就打開,若是文件不存在就以該文件名建立一個文件。vim是一個很是好用的文本編輯器,它裏面有不少很是好用的命令,在這裏再也不多說。你能夠從這裏下載
vim經常使用操做的詳細說明。
1九、gcc命令
對於一個用Linux開發C程序的人來講,這個命令就很是重要了,它用於把C語言的源程序文件,編譯成可執行程序,因爲g++的不少參數跟它很是類似,因此這裏只介紹gcc的參數,它的經常使用參數以下:
- -o :output之意,用於指定生成一個可執行文件的文件名
- -c :用於把源文件生成目標文件(.o),並阻止編譯器建立一個完整的程序
- -I :增長編譯時搜索頭文件的路徑
- -L :增長編譯時搜索靜態鏈接庫的路徑
- -S :把源文件生成彙編代碼文件
- -lm:表示標準庫的目錄中名爲libm.a的函數庫
- -lpthread :鏈接NPTL實現的線程庫
- -std= :用於指定把使用的C語言的版本
-
- # 例如:
- # 把源文件test.c按照c99標準編譯成可執行程序test
- gcc -o test test.c -lm -std=c99
- #把源文件test.c轉換爲相應的彙編程序源文件test.s
- gcc -S test.c
20、time命令
該命令用於測算一個命令(即程序)的執行時間。它的使用很是簡單,就像平時輸入命令同樣,不過在命令的前面加入一個time便可,例如:
- time ./process
- 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使用工廠模式經過
BeanFactory
、ApplicationContext
建立 bean 對象。
- 代理設計模式 : Spring AOP 功能的實現。
- 單例設計模式 : Spring 中的 Bean 默認都是單例的。
- 模板方法模式 : Spring 中
jdbcTemplate
、hibernateTemplate
等以 Template 結尾的對數據庫操做的類,它們就使用到了模板模式。
- 包裝器設計模式 : 咱們的項目須要鏈接多個數據庫,並且不一樣的客戶在每次訪問中根據須要會去訪問不一樣的數據庫。這種模式讓咱們能夠根據客戶的需求可以動態切換不一樣的數據源。
- 觀察者模式: Spring 事件驅動模型就是觀察者模式很經典的一個應用。
- 適配器模式 :Spring AOP 的加強或通知(Advice)使用到了適配器模式、spring MVC 中也是用到了適配器模式適配
Controller
。
- ……
aop是什麼
-
切面(Aspect):指的就是通用功能的代碼實現,好比咱們上面演示的時間記錄切面,日誌切面,它們都是普通的Java類:TimeRecordingAspect
和LogAspect
。
-
目標對象(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協議瞭解嗎
介紹一下常見算法,哪些是穩定的哪些是不穩定的,以及時間複雜度
雲計算有哪些服務和應用場景