天天看點

跳槽季到了,Linux運維跳槽40道面試精華題

1、什麼是運維?什麼是遊戲運維?

1)運維是指大型組織已經建立好的網絡軟硬體的維護,就是要保證業務的上線與運作的正常,

在他運轉的過程中,對他進行維護,他集合了網絡、系統、資料庫、開發、安全、監控于一身的技術

運維又包括很多種,有DBA運維、網站運維、虛拟化運維、監控運維、遊戲運維等等

2)遊戲運維又有分工,分為開發運維、應用運維(業務運維)和系統運維

開發運維:是給應用運維開發運維工具和運維平台的

應用運維:是給業務上線、維護和做故障排除的,用開發運維開發出來的工具給業務上線、維護、做故障排查

系統運維:是給應用運維提供業務上的基礎設施,比如:系統、網絡、監控、硬體等等

總結:開發運維和系統運維給應用運維提供了“工具”和“基礎設施”上的支撐

開發運維、應用運維和系統運維他們的工作是環環相扣的

2、在工作中,運維人員經常需要跟營運人員打交道,請問營運人員是做什麼工作的?

遊戲營運要做的一個事情除了協調工作以外

還需要與各平台溝通,做好開服的時間、開服數、使用者導量、活動等計劃

3、現在給你三百台伺服器,你怎麼對他們進行管理?

管理3百台伺服器的方式:

1)設定跳闆機,使用統一賬号登入,便于安全與登入的考量。

2)使用salt、ansiable、puppet進行系統的統一排程與配置的統一管理。

3)建立簡單的伺服器的系統、配置、應用的cmdb資訊管理。便于查閱每台伺服器上的各種資訊記錄。

4、簡述raid0 raid1 raid5 三種工作模式的工作原理及特點

RAID,可以把硬碟整合成一個大磁盤,還可以在大磁盤上再分區,放資料

還有一個大功能,多塊盤放在一起可以有備援(備份)

RAID整合方式有很多,常用的:0 1 5 10

RAID 0,可以是一塊盤和N個盤組合

其優點讀寫快,是RAID中最好的

缺點:沒有備援,一塊壞了資料就全沒有了

RAID 1,隻能2塊盤,盤的大小可以不一樣,以小的為準

10G+10G隻有10G,另一個做備份。它有100%的備援,缺點:浪費資源,成本高

RAID 5 ,3塊盤,容量計算10*(n-1),損失一塊盤

特點,讀寫性能一般,讀還好一點,寫不好

備援從好到壞:RAID1 RAID10 RAID 5 RAID0

性能從好到壞:RAID0 RAID10 RAID5 RAID1

成本從低到高:RAID0 RAID5 RAID1 RAID10

單台伺服器:很重要盤不多,系統盤,RAID1

資料庫伺服器:主庫:RAID10 從庫 RAID5RAID0(為了維護成本,RAID10)

WEB伺服器,如果沒有太多的資料的話,RAID5,RAID0(單盤)

有多台,監控、應用伺服器,RAID0 RAID5

我們會根據資料的存儲和通路的需求,去比對對應的RAID級别

5、LVS、Nginx、HAproxy有什麼差別?工作中你怎麼選擇?

LVS: 是基于四層的轉發

HAproxy: 是基于四層和七層的轉發,是專業的代理伺服器

Nginx: 是WEB伺服器,緩存伺服器,又是反向代理伺服器,可以做七層的轉發

差別: LVS由于是基于四層的轉發是以隻能做端口的轉發

而基于URL的、基于目錄的這種轉發LVS就做不了

工作選擇:

HAproxy和Nginx由于可以做七層的轉發,是以URL和目錄的轉發都可以做

在很大并發量的時候我們就要選擇LVS,像中小型公司的話并發量沒那麼大

選擇HAproxy或者Nginx足已,由于HAproxy由是專業的代理伺服器

配置簡單,是以中小型企業推薦使用HAproxy

6、Squid、Varinsh和Nginx有什麼差別,工作中你怎麼選擇?

Squid、Varinsh和Nginx都是代理伺服器

什麼是代理伺服器:

能當替使用者去通路公網,并且能把通路到的資料緩存到伺服器本地,等使用者下次再通路相同的資

源的時候,代理伺服器直接從本地回應給使用者,當本地沒有的時候,我代替你去通路公網,我接

收你的請求,我先在我自已的本地緩存找,如果我本地緩存有,我直接從我本地的緩存裡回複你

如果我在我本地沒有找到你要通路的緩存的資料,那麼代理伺服器就會代替你去通路公網

差別:

1)Nginx本來是反向代理/web伺服器,用了插件可以做做這個副業

但是本身不支援特性挺多,隻能緩存靜态檔案

2)從這些功能上。varnish和squid是專業的cache服務,而nginx這些是第三方子產品完成

3)varnish本身的技術上優勢要高于squid,它采用了可視化頁面緩存技術

在記憶體的利用上,Varnish比Squid具有優勢,性能要比Squid高。

還有強大的通過Varnish管理端口,可以使用正規表達式快速、批量地清除部分緩存

它是記憶體緩存,速度一流,但是記憶體緩存也限制了其容量,緩存頁面和圖檔一般是挺好的

4)squid的優勢在于完整的龐大的cache技術資料,和很多的應用生産環境

工作中選擇:

要做cache服務的話,我們肯定是要選擇專業的cache服務,優先選擇squid或者varnish。

7、Tomcat和Resin有什麼差別,工作中你怎麼選擇?

差別:Tomcat使用者數多,可參考文檔多,Resin使用者數少,可考慮文檔少

最主要差別則是Tomcat是标準的java容器,不過性能方面比resin的要差一些

但穩定性和java程式的相容性,應該是比resin的要好

工作中選擇:現在大公司都是用resin,追求性能;而中小型公司都是用Tomcat,追求穩定和程式的相容

8、什麼是中間件?什麼是jdk?

中間件介紹:

中間件是一種獨立的系統軟體或服務程式,分布式應用軟體借助這種軟體在不同的技術之間共享資源

中間件位于客戶機/ 伺服器的作業系統之上,管理計算機資源和網絡通訊

是連接配接兩個獨立應用程式或獨立系統的軟體。相連接配接的系統,即使它們具有不同的接口

但通過中間件互相之間仍能交換資訊。執行中間件的一個關鍵途徑是資訊傳遞

通過中間件,應用程式可以工作于多平台或OS環境。

jdk:jdk是Java的開發工具包

它是一種用于建構在 Java 平台上釋出的應用程式、applet 群組件的開發環境

9、講述一下Tomcat8005、8009、8080三個端口的含義?

8005==》 關閉時使用

8009==》 為AJP端口,即容器使用,如Apache能通過AJP協定通路Tomcat的8009端口

8080==》 一般應用使用

10、什麼叫CDN?

即内容分發網絡

其目的是通過在現有的Internet中增加一層新的網絡架構,将網站的内容釋出到
最接近使用者的網絡邊緣,使使用者可就近取得所需的内容,提高使用者通路網站的速度
           

11、什麼叫網站灰階釋出?

灰階釋出是指在黑與白之間,能夠平滑過渡的一種釋出方式

AB test就是一種灰階釋出方式,讓一部使用者繼續用A,一部分使用者開始用B

如果使用者對B沒有什麼反對意見,那麼逐漸擴大範圍,把所有使用者都遷移到B上面 來

灰階釋出可以保證整體系統的穩定,在初始灰階的時候就可以發現、調整問題,以保證其影響度

12、簡述DNS進行域名解析的過程?

使用者要通路www.baidu.com,會先找本機的host檔案,再找本地設定的DNS伺服器,如果也沒有的話,就去網絡中找根伺服器,根伺服器回報結果,說隻能提供一級域名伺服器.cn,就去找一級域名伺服器,一級域名伺服器說隻能提供二級域名伺服器.com.cn,就去找二級域名伺服器,二級域伺服器隻能提供三級域名伺服器.baidu.com.cn,就去找三級域名伺服器,三級域名伺服器正好有這個網站www.baidu.com,然後發給請求的伺服器,儲存一份之後,再發給用戶端

13、RabbitMQ是什麼東西?

RabbitMQ也就是消息隊列中間件,消息中間件是在消息的傳息過程中儲存消息的容器

消息中間件再将消息從它的源中到它的目标中标時充當中間人的作用

隊列的主要目的是提供路由并保證消息的傳遞;如果發送消息時接收者不可用

消息隊列不會保留消息,直到可以成功地傳遞為止,當然,消息隊列儲存消息也是有期限地

14、講一下Keepalived的工作原理?

在一個虛拟路由器中,隻有作為MASTER的VRRP路由器會一直發送VRRP通告資訊,

BACKUP不會搶占MASTER,除非它的優先級更高。當MASTER不可用時(BACKUP收不到通告資訊)

多台BACKUP中優先級最高的這台會被搶占為MASTER。這種搶占是非常快速的(<1s),以保證服務的連續性

由于安全性考慮,VRRP包使用了加密協定進行加密。BACKUP不會發送通告資訊,隻會接收通告資訊

15、講述一下LVS三種模式的工作過程?

LVS 有三種負載均衡的模式,分别是VS/NAT(nat 模式) VS/DR(路由模式) VS/TUN(隧道模式)

一、NAT模式(VS-NAT)

原理:就是把用戶端發來的資料包的IP頭的目的位址,在負載均衡器上換成其中一台RS的IP位址

并發至此RS來處理,RS處理完後把資料交給負載均衡器,負載均衡器再把資料包原IP位址改為自己的IP

将目的位址改為用戶端IP位址即可期間,無論是進來的流量,還是出去的流量,都必須經過負載均衡器

優點:叢集中的實體伺服器可以使用任何支援TCP/IP作業系統,隻有負載均衡器需要一個合法的IP位址

缺點:擴充性有限。當伺服器節點(普通PC伺服器)增長過多時,負載均衡器将成為整個系統的瓶頸

因為所有的請求包和應答包的流向都經過負載均衡器。當伺服器節點過多時

大量的資料包都交彙在負載均衡器那,速度就會變慢!

二、IP隧道模式(VS-TUN)

原理:首先要知道,網際網路上的大多Internet服務的請求包很短小,而應答包通常很大

那麼隧道模式就是,把用戶端發來的資料包,封裝一個新的IP頭标記(僅目的IP)發給RS

RS收到後,先把資料包的頭解開,還原資料包,處理後,直接傳回給用戶端,不需要再經過

負載均衡器。注意,由于RS需要對負載均衡器發過來的資料包進行還原,是以說必須支援

IPTUNNEL協定,是以,在RS的核心中,必須編譯支援IPTUNNEL這個選項

優點:負載均衡器隻負責将請求包分發給後端節點伺服器,而RS将應答包直接發給使用者

是以,減少了負載均衡器的大量資料流動,負載均衡器不再是系統的瓶頸,就能處理很巨大的請求量

這種方式,一台負載均衡器能夠為很多RS進行分發。而且跑在公網上就能進行不同地域的分發。

缺點:隧道模式的RS節點需要合法IP,這種方式需要所有的伺服器支援”IP Tunneling”

(IP Encapsulation)協定,伺服器可能隻局限在部分Linux系統上

三、直接路由模式(VS-DR)

原理:負載均衡器和RS都使用同一個IP對外服務但隻有DR對ARP請求進行響應

所有RS對本身這個IP的ARP請求保持靜默也就是說,網關會把對這個服務IP的請求全部定向給DR

而DR收到資料包後根據排程算法,找出對應的RS,把目的MAC位址改為RS的MAC(因為IP一緻)

并将請求分發給這台RS這時RS收到這個資料包,處理完成之後,由于IP一緻,可以直接将資料返給客戶

則等于直接從用戶端收到這個資料包無異,處理後直接傳回給用戶端

由于負載均衡器要對二層標頭進行改換,是以負載均衡器和RS之間必須在一個廣播域

也可以簡單的了解為在同一台交換機上

優點:和TUN(隧道模式)一樣,負載均衡器也隻是分發請求,應答包通過單獨的路由方法傳回給用戶端

與VS-TUN相比,VS-DR這種實作方式不需要隧道結構,是以可以使用大多數作業系統做為實體伺服器。

缺點:(不能說缺點,隻能說是不足)要求負載均衡器的網卡必須與實體網卡在一個實體段上。

16、mysql的innodb如何定位鎖問題,mysql如何減少主從複制延遲?

mysql的innodb如何定位鎖問題:

在使用 show engine innodb status檢查引擎狀态時,發現了死鎖問題

在5.5中,information_schema 庫中增加了三個關于鎖的表(MEMORY引擎)

innodb_trx ## 目前運作的所有事務

innodb_locks ## 目前出現的鎖

innodb_lock_waits ## 鎖等待的對應關系

mysql如何減少主從複制延遲:

如果延遲比較大,就先确認以下幾個因素:

從庫硬體比主庫差,導緻複制延遲

主從複制單線程,如果主庫寫并發太大,來不及傳送到從庫
就會導緻延遲。更高版本的mysql可以支援多線程複制

慢SQL語句過多

網絡延遲

master負載
主庫讀寫壓力大,導緻複制延遲,架構的前端要加buffer及緩存層

slave負載
一般的做法是,使用多台slave來分攤讀請求,再從這些slave中取一台專用的伺服器
           

隻作為備份用,不進行其他任何操作.另外, 2個可以減少延遲的參數:

–slave-net-timeout=seconds 機關為秒 預設設定為 3600秒

參數含義:當slave從主資料庫讀取log資料失敗後,等待多久重建立立連接配接并擷取資料
           

–master-connect-retry=seconds 機關為秒 預設設定為 60秒

參數含義:當重建立立主從連接配接時,如果連接配接建立失敗,間隔多久後重試
           

通常配置以上2個參數可以減少網絡問題導緻的主從資料同步延遲

MySQL資料庫主從同步延遲解決方案

最簡單的減少slave同步延時的方案就是在架構上做優化,盡量讓主庫的DDL快速執行

還有就是主庫是寫,對資料安全性較高,比如sync_binlog=1,innodb_flush_log_at_trx_commit

= 1 之類的設定,而slave則不需要這麼高的資料安全,完全可以講sync_binlog設定為0或者關閉binlog

innodb_flushlog也可以設定為0來提高sql的執行效率。另外就是使用比主庫更好的硬體裝置作為slave

17、如何重置mysql root密碼?

一、 在已知MYSQL資料庫的ROOT使用者密碼的情況下,修改密碼的方法:

1、 在SHELL環境下,使用mysqladmin指令設定:

mysqladmin –u root –p password “新密碼” 回車後要求輸入舊密碼

2、 在mysql>環境中,使用update指令,直接更新mysql庫user表的資料:

Update mysql.user set password=password(‘新密碼’) where user=’root’;

flush privileges;

注意:mysql語句要以分号”;”結束

3、 在mysql>環境中,使用grant指令,修改root使用者的授權權限。

grant all on . to [email protected]’localhost’ identified by ‘新密碼’;

二、 如查忘記了mysql資料庫的ROOT使用者的密碼,又如何做呢?方法如下:

1、 關閉目前運作的mysqld服務程式:service mysqld stop(要先将mysqld添加為系統服務)

2、 使用mysqld_safe腳本以安全模式(不加載授權表)啟動mysqld 服務

/usr/local/mysql/bin/mysqld_safe –skip-grant-table &

3、 使用空密碼的root使用者登入資料庫,重新設定ROOT使用者的密碼

#mysql -u root

Mysql> Update mysql.user set password=password(‘新密碼’) where user=’root’;

Mysql> flush privileges;

18、lvs/nginx/haproxy優缺點

Nginx的優點是:

1、工作在網絡的7層之上,可以針對http應用做一些分流的政策,比如針對域名、目錄結構

它的正則規則比HAProxy更為強大和靈活,這也是它目前廣泛流行的主要原因之一

Nginx單憑這點可利用的場合就遠多于LVS了。

2、Nginx對網絡穩定性的依賴非常小,理論上能ping通就就能進行負載功能,這個也是它的優勢之一

相反LVS對網絡穩定性依賴比較大,這點本人深有體會;

3、Nginx安裝和配置比較簡單,測試起來比較友善,它基本能把錯誤用日志列印出來

LVS的配置、測試就要花比較長的時間了,LVS對網絡依賴比較大。

4、可以承擔高負載壓力且穩定,在硬體不差的情況下一般能支撐幾萬次的并發量,負載度比LVS相對小些。

5、Nginx可以通過端口檢測到伺服器内部的故障,比如根據伺服器處理網頁傳回的狀态碼、逾時等等,并且會把傳回錯誤的請求重新送出到另一個節點,不過其中缺點就是不支援url來檢測。比如使用者正在上傳一個檔案,而處理該上傳的節點剛好在上傳過程中出現故障,Nginx會把上傳切到另一台伺服器重新處理,而LVS就直接斷掉了

如果是上傳一個很大的檔案或者很重要的檔案的話,使用者可能會是以而不滿。

6、Nginx不僅僅是一款優秀的負載均衡器/反向代理軟體,它同時也是功能強大的Web應用伺服器

LNMP也是近幾年非常流行的web架構,在高流量的環境中穩定性也很好。

7、Nginx現在作為Web反向加速緩存越來越成熟了,速度比傳統的Squid伺服器更快,可考慮用其作為反向代理加速器

8、Nginx可作為中層反向代理使用,這一層面Nginx基本上無對手,唯一可以對比Nginx的就隻有lighttpd了

不過lighttpd目前還沒有做到Nginx完全的功能,配置也不那麼清晰易讀,社群資料也遠遠沒Nginx活躍

9、Nginx也可作為靜态網頁和圖檔伺服器,這方面的性能也無對手。還有Nginx社群非常活躍,第三方子產品也很多

Nginx的缺點是:

1、Nginx僅能支援http、https和Email協定,這樣就在适用範圍上面小些,這個是它的缺點

2、對後端伺服器的健康檢查,隻支援通過端口來檢測,不支援通過url來檢測

不支援Session的直接保持,但能通過ip_hash來解決

LVS:使用Linux核心叢集實作一個高性能、高可用的負載均衡伺服器

它具有很好的可伸縮性(Scalability)、可靠性(Reliability)和可管理性(Manageability)

LVS的優點是:

1、抗負載能力強、是工作在網絡4層之上僅作分發之用,沒有流量的産生

這個特點也決定了它在負載均衡軟體裡的性能最強的,對記憶體和cpu資源消耗比較低

2、配置性比較低,這是一個缺點也是一個優點,因為沒有可太多配置的東西

是以并不需要太多接觸,大大減少了人為出錯的幾率

3、工作穩定,因為其本身抗負載能力很強,自身有完整的雙機熱備方案

如LVS+Keepalived,不過我們在項目實施中用得最多的還是LVS/DR+Keepalived

4、無流量,LVS隻分發請求,而流量并不從它本身出去,這點保證了均衡器IO的性能不會收到大流量的影響。

5、應用範圍較廣,因為LVS工作在4層,是以它幾乎可對所有應用做負載均衡,包括http、資料庫、線上聊天室等

LVS的缺點是:

1、軟體本身不支援正規表達式處理,不能做動靜分離

而現在許多網站在這方面都有較強的需求,這個是Nginx/HAProxy+Keepalived的優勢所在

2、如果是網站應用比較龐大的話,LVS/DR+Keepalived實施起來就比較複雜了

特别後面有Windows Server的機器的話,如果實施及配置還有維護過程就比較複雜了

相對而言,Nginx/HAProxy+Keepalived就簡單多了。

HAProxy的特點是:

1、HAProxy也是支援虛拟主機的。

2、HAProxy的優點能夠補充Nginx的一些缺點,比如支援Session的保持,Cookie的引導

同時支援通過擷取指定的url來檢測後端伺服器的狀态

3、HAProxy跟LVS類似,本身就隻是一款負載均衡軟體

單純從效率上來講HAProxy會比Nginx有更出色的負載均衡速度,在并發處理上也是優于Nginx的

4、HAProxy支援TCP協定的負載均衡轉發,可以對MySQL讀進行負載均衡

對後端的MySQL節點進行檢測和負載均衡,大家可以用LVS+Keepalived對MySQL主從做負載均衡

5、HAProxy負載均衡政策非常多,HAProxy的負載均衡算法現在具體有如下8種:

①roundrobin,表示簡單的輪詢,這個不多說,這個是負載均衡基本都具備的;

② static-rr,表示根據權重,建議關注;

③leastconn,表示最少連接配接者先處理,建議關注;

④ source,表示根據請求源IP,這個跟Nginx的IP_hash機制類似

我們用其作為解決session問題的一種方法,建議關注;

⑤ri,表示根據請求的URI;

⑥rl_param,表示根據請求的URl參數’balance url_param’ requires an URL parameter name;

⑦hdr(name),表示根據HTTP請求頭來鎖定每一次HTTP請求;

⑧rdp-cookie(name),表示根據據cookie(name)來鎖定并哈希每一次TCP請求。

19、mysql資料備份工具

mysqldump工具

mysqldump是mysql自帶的備份工具,目錄在bin目錄下面:/usr/local/mysql/bin/mysqldump

支援基于innodb的熱備份,但是由于是邏輯備份,是以速度不是很快,适合備份資料比較小的場景

Mysqldump完全備份+二進制日志可以實作基于時間點的恢複。

基于LVM快照備份

在實體備份中,有基于檔案系統的實體備份(LVM的快照),也可以直接用tar之類的指令對整個資料庫目錄

進行打包備份,但是這些隻能進行泠備份,不同的存儲引擎備份的也不一樣,myisam自動備份到表級别

而innodb不開啟獨立表空間的話隻能備份整個資料庫。

tar包備份

percona提供的xtrabackup工具

支援innodb的實體熱備份,支援完全備份,增量備份,而且速度非常快,支援innodb存儲引起的資料在不同

資料庫之間遷移,支援複制模式下的從機備份恢複備份恢複,為了讓xtrabackup支援更多的功能擴充

可以設立獨立表空間,打開 innodb_file_per_table功能,啟用之後可以支援單獨的表備份

20、keepalive的工作原理和如何做到健康檢查

keepalived是以VRRP協定為實作基礎的,VRRP全稱Virtual Router Redundancy Protocol,即虛拟路由備援協定。

虛拟路由備援協定,可以認為是實作路由器高可用的協定,即将N台提供相同功能的路由器組成一個路由器組

這個組裡面有一個master和多個backup,master上面有一個對外提供服務的vip(該路由器所在區域網路内

其他機器的預設路由為該vip),master會發多點傳播,當backup收不到vrrp包時就認為master宕掉了

這時就需要根據VRRP的優先級來選舉一個backup當master。這樣就可以保證路由器的高可用了

keepalived主要有三個子產品,分别是core、check和vrrp。core子產品為keepalived的核心,負責主程序的啟動、維護

及全局配置檔案的加載和解析。check負責健康檢查,包括常見的各種檢查方式,vrrp子產品是來實作VRRP協定的

Keepalived健康檢查方式配置

HTTP_GET|SSL_GET

HTTP_GET | SSL_GET

{

url {

path /# HTTP/SSL 檢查的url可以是多個

digest # HTTP/SSL 檢查後的摘要資訊用工具genhash生成

status_code 200# HTTP/SSL 檢查傳回的狀态碼

}

connect_port 80 # 連接配接端口

bindto

connect_timeout 3 # 連接配接逾時時間

nb_get_retry 3 # 重連次數

delay_before_retry 2 #連接配接間隔時間

}

21、統計ip通路情況,要求分析nginx通路日志,找出通路頁面數量在前十位的ip

cat access.log | awk ‘{print $1}’ | uniq -c | sort -rn | head -10

22、使用tcpdump監聽主機為192.168.1.1,tcp端口為80的資料,同時将輸出結果儲存輸出到tcpdump.log

tcpdump ‘host 192.168.1.1 and port 80’ > tcpdump.log

23、如何将本地80 端口的請求轉發到8080 端口,目前主機IP 為192.168.2.1

iptables -A PREROUTING -d 192.168.2.1 -p tcp -m tcp -dport 80 -j DNAT-to-destination 192.168.2.1:8080

24、簡述raid0 raid1 raid5 三種工作模式的工作原理及特點

RAID 0:等量磁碟區,連續以位或位元組為機關分割資料,并行讀/寫于多個磁盤上,是以具有很高的資料傳輸率

但它沒有資料備援,RAID 0 隻是單純地提高性能,并沒有為資料的可靠性提供保證

而且其中的一個磁盤失效将影響到所有資料。是以,RAID 0 不能應用于資料安全性要求高的場合

RAID 1:鏡像卷,它是通過磁盤資料鏡像實作資料備援,在成對的獨立磁盤上産生互為備份的資料

不能提升寫資料效率。當原始資料繁忙時,可直接從鏡像拷貝中讀取資料,是以RAID1 可以提高讀取性能

RAID 1 是磁盤陣列中機關成本最高的,鏡像卷可用容量為總容量的1/2,但提供了很高的資料安全性和可用性

當一個磁盤失效時,系統可以自動切換到鏡像磁盤上讀寫,而不需要重組失效的資料

RAID5:至少由3塊硬碟組成,分布式奇偶校驗的獨立磁盤結構,它的奇偶校驗碼存在于所有磁盤上

任何一個硬碟損壞,都可以根據其它硬碟上的校驗位來重建損壞的資料(最多允許1塊硬碟損壞)

是以raid5可以實作資料備援,確定資料的安全性,同時raid5也可以提升資料的讀寫性能

25、你對現在運維工程師的了解和以及對其工作的認識

運維工程師在公司當中責任重大,需要保證時刻為公司及客戶提供最高、最快、最穩定、最安全的服務

運維工程師的一個小小的失誤,很有可能會對公司及客戶造成重大損失

是以運維工程師的工作需要嚴謹及富有創新精神

26、實時抓取并顯示目前系統中tcp 80端口的網絡資料資訊,請寫出完整操作指令

tcpdump -nn tcp port 80

27、伺服器開不了機怎麼解決一步步的排查

A、造成伺服器故障的原因可能有以下幾點:

B、如何排查伺服器故障的處理步驟如下:

28、Linux系統中病毒怎麼解決

1)最簡單有效的方法就是重裝系統

2)要查的話就是找到病毒檔案然後删除

中毒之後一般機器cpu、記憶體使用率會比較高

機器向外發包等異常情況,排查方法簡單介紹下

top 指令找到cpu使用率最高的程序

一般病毒檔案命名都比較亂,可以用 ps aux 找到病毒檔案位置

rm -f 指令删除病毒檔案

檢查計劃任務、開機啟動項和病毒檔案目錄有無其他可以檔案等

3)由于即使删除病毒檔案不排除有潛伏病毒,是以最好是把機器備份資料之後重裝一下

29、發現一個病毒檔案你删了他又自動建立怎麼解決

公司的内網某台linux伺服器流量莫名其妙的劇增,用iftop檢視有連接配接外網的情況

針對這種情況一般重點檢視netstat連接配接的外網ip和端口。

用lsof -p pid可以檢視到具體是那些程序,哪些檔案

經查勘發現/root下有相關的配置conf.n hhe兩個可疑檔案,rm -rf後不到一分鐘就自動生成了

由此推斷是某個母程序産生的這些檔案。是以找到母程序就是找到罪魁禍首

清除病毒最好斷掉外網通路,還好是内網伺服器,可以通過内網通路

斷了内網,病毒就失去外聯的能力,殺掉它就容易的多

怎麼找到呢,找了半天也沒有看到蛛絲馬迹,沒辦法隻有ps axu一個個排查

方法是檢視可以的使用者和和系統相似而又不是的冒牌貨,果然,看到了如下程序可疑

看不到圖檔就是/usr/bin/.sshd

于是我殺掉所有.sshd相關的程序,然後直接删掉.sshd這個可執行檔案

然後才删掉了文章開頭提到的自動複活的檔案

總結一下,遇到這種問題,如果不是太嚴重,盡量不要重裝系統

一般就是先斷外網,然後利用iftop,ps,netstat,chattr,lsof,pstree這些工具順藤摸瓜

一般都能找到元兇。但是如果遇到諸如此類的問題

/boot/efi/EFI/redhat/grub.efi: Heuristics.Broken.Executable FOUND,個人覺得就要重裝系統了

30、說說TCP/IP的七層模型

應用層 (Application):

網絡服務與最終使用者的一個接口。

協定有:HTTP FTP TFTP SMTP SNMP DNS TELNET HTTPS POP3 DHCP

表示層(Presentation Layer):

資料的表示、安全、壓縮。(在五層模型裡面已經合并到了應用層)

格式有,JPEG、ASCll、DECOIC、加密格式等

會話層(Session Layer):

建立、管理、終止會話。(在五層模型裡面已經合并到了應用層)

對應主機程序,指本地主機與遠端主機正在進行的會話

傳輸層 (Transport):

定義傳輸資料的協定端口号,以及流控和差錯校驗。

協定有:TCP UDP,資料包一旦離開網卡即進入網絡傳輸層

網絡層 (Network):

進行邏輯位址尋址,實作不同網絡之間的路徑選擇。

協定有:ICMP IGMP IP(IPV4 IPV6) ARP RARP

資料鍊路層 (Link):

建立邏輯連接配接、進行硬體位址尋址、差錯校驗等功能。(由底層網絡定義協定)

将比特組合成位元組進而組合成幀,用MAC位址通路媒體,錯誤發現但不能糾正

實體層(Physical Layer):

是計算機網絡OSI模型中最低的一層

實體層規定:為傳輸資料所需要的實體鍊路建立、維持、拆除

而提供具有機械的,電子的,功能的和規範的特性

簡單的說,實體層確定原始的資料可在各種實體媒體上傳輸。區域網路與廣域網皆屬第1、2層

實體層是OSI的第一層,它雖然處于最底層,卻是整個開放系統的基礎

實體層為裝置之間的資料通信提供傳輸媒體及互連裝置,為資料傳輸提供可靠的環境

如果您想要用盡量少的詞來記住這個第一層,那就是“信号和媒體”

31、你常用的Nginx子產品,用來做什麼

rewrite子產品,實作重寫功能

access子產品:來源控制

ssl子產品:安全加密

ngx_http_gzip_module:網絡傳輸壓縮子產品

ngx_http_proxy_module 子產品實作代理

ngx_http_upstream_module子產品實作定義後端伺服器清單

ngx_cache_purge實作緩存清除功能

32、請列出你了解的web伺服器負載架構

Nginx

Haproxy

Keepalived

LVS

33、檢視http的并發請求數與其TCP連接配接狀态

netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}’

還有ulimit -n 檢視linux系統打開最大的檔案描述符,這裡預設1024

不修改這裡web伺服器修改再大也沒用,若要用就修改很幾個辦法,這裡說其中一個:

修改/etc/security/limits.conf

soft nofile 10240

hard nofile 10240
重新開機後生效
           

34、用tcpdump嗅探80端口的通路看看誰最高

tcpdump -i eth0 -tnn dst port 80 -c 1000 | awk -F”.” ‘{print $1″.”$2″.”$3″.”$4}’| sort | uniq -c | sort -nr |head -20

35、寫一個腳本,實作判斷192.168.1.0/24網絡裡,目前線上的IP有哪些,能ping通則認為線上

!/bin/bash

for ip in seq 1 255

do

{

ping -c 1 192.168.1.$ip > /dev/null 2>&1

if [ ? − e q 0 ] ; t h e n e c h o 192.168.1. ? -eq 0 ]; then echo 192.168.1. ?−eq0];thenecho192.168.1.ip UP

else

echo 192.168.1.$ip DOWN

fi

}&

done

wait

36、已知 apache 服務的通路日志按天記錄在伺服器本地目錄/app/logs 下,由于磁盤空間緊張現在要求隻能保留最近 7 天的通路日志!請問如何解決? 請給出解決辦法或配置或處理指令

建立檔案腳本:

!/bin/bash

for n in seq 14

do

date -s “11/0$n/14”

touch access_www_(date +%F).log

done

解決方法:

pwd/application/logs

ll

-rw-r–r–. 1 root root 0 Jan 1 00:00 access_www_2015-01-01.log

-rw-r–r–. 1 root root 0 Jan 2 00:00 access_www_2015-01-02.log

-rw-r–r–. 1 root root 0 Jan 3 00:00 access_www_2015-01-03.log

-rw-r–r–. 1 root root 0 Jan 4 00:00 access_www_2015-01-04.log

-rw-r–r–. 1 root root 0 Jan 5 00:00 access_www_2015-01-05.log

-rw-r–r–. 1 root root 0 Jan 6 00:00 access_www_2015-01-06.log

-rw-r–r–. 1 root root 0 Jan 7 00:00 access_www_2015-01-07.log

-rw-r–r–. 1 root root 0 Jan 8 00:00 access_www_2015-01-08.log

-rw-r–r–. 1 root root 0 Jan 9 00:00 access_www_2015-01-09.log

-rw-r–r–. 1 root root 0 Jan 10 00:00 access_www_2015-01-10.log

-rw-r–r–. 1 root root 0 Jan 11 00:00 access_www_2015-01-11.log

-rw-r–r–. 1 root root 0 Jan 12 00:00 access_www_2015-01-12.log

-rw-r–r–. 1 root root 0 Jan 13 00:00 access_www_2015-01-13.log

-rw-r–r–. 1 root root 0 Jan 14 00:00 access_www_2015-01-14.log

find /application/logs/ -type f -mtime +7 -name “*.log”|xargs rm –f

也可以使用-exec rm -f {} ;進行删除

ll

-rw-r–r–. 1 root root 0 Jan 7 00:00 access_www_2015-01-07.log

-rw-r–r–. 1 root root 0 Jan 8 00:00 access_www_2015-01-08.log

-rw-r–r–. 1 root root 0 Jan 9 00:00 access_www_2015-01-09.log

-rw-r–r–. 1 root root 0 Jan 10 00:00 access_www_2015-01-10.log

-rw-r–r–. 1 root root 0 Jan 11 00:00 access_www_2015-01-11.log

-rw-r–r–. 1 root root 0 Jan 12 00:00 access_www_2015-01-12.log

-rw-r–r–. 1 root root 0 Jan 13 00:00 access_www_2015-01-13.log

-rw-r–r–. 1 root root 0 Jan 14 00:00 access_www_2015-01-14.log

37、如何優化 Linux系統(可以不說太具體)?

不用root,添加普通使用者,通過sudo授權管理

更改預設的遠端連接配接SSH服務端口及禁止root使用者遠端連接配接

定時自動更新伺服器時間

配置國内yum源

關閉selinux及iptables(iptables工作場景如果有外網IP一定要打開,高并發除外)

調整檔案描述符的數量

精簡開機啟動服務(crond rsyslog network sshd)

核心參數優化(/etc/sysctl.conf)

更改字元集,支援中文,但建議還是用英文字元集,防止亂碼

鎖定關鍵系統檔案

清空/etc/issue,去除系統及核心版本登入前的螢幕顯示

38、請執行指令取出 linux 中 eth0 的 IP 位址(請用 cut,有能力者也可分别用 awk,sed 指令答)

cut方法1:

ifconfig eth0|sed -n ‘2p’|cut -d “:” -f2|cut -d ” ” -f1

192.168.20.130

awk方法2:

ifconfig eth0|awk ‘NR==2’|awk -F “:” ‘{print $2}’|awk ‘{print $1}’

192.168.20.130

awk多分隔符方法3:

ifconfig eth0|awk ‘NR==2’|awk -F “[: ]+” ‘{print $4}’

192.168.20.130

sed方法4:

ifconfig eth0|sed -n ‘/inet addr/p’|sed -r ‘s#^.ddr:(.)Bc.*$##g’

192.168.20.130

39、請寫出下面 linux SecureCRT 指令行快捷鍵指令的功能?

Ctrl + a

Ctrl + c

Ctrl + d

Ctrl + e

Ctrl + l

Ctrl + u

Ctrl + k

tab

Ctrl+shift+c

Ctrl+shift+v

解答:

Ctrl + a —->光标移動到行首

Ctrl + e —->光标移動到行尾

Ctrl + c —->終止目前程式

Ctrl + d —->如果光标前有字元則删除,沒有則退出目前中斷

Ctrl + l —->清屏

Ctrl + u —->剪切光标以前的字元

Ctrl + k —->剪切光标以後的字元

Ctrl + y —->複制u/k的内容

Ctrl + r —->查找最近用過的指令

tab —->指令或路徑補全

Ctrl+shift+c —->複制

Ctrl+shift+v —->粘貼

40、每天晚上 12 點,打包站點目錄/var/www/html 備份到/data 目錄下(最好每次備份按時間生成不同的備份包)

cat a.sh

/bin/bash

cd /var/www/ && /bin/tar zcf /data/html-date +%m-%d%H.tar.gz html/

crontab –e

00 00 * * * /bin/sh /root/a.sh

繼續閱讀