【就業福利-259期】美團Linux運維工程師面試真題曝光

作為Linux運維工程師,進入大公司是開啟職業新起點的關鍵,今天馬哥linux運維及云計算智囊團的小伙伴特別分享了其在美團面試Linux運維及云計算工程師的題目和經歷,希望對廣大Linux運維及云計算的求職者有一個幫助。


首先我們來看下美團對Linux運維工程師招聘崗位要求:

【崗位定義】系統運維工程師

【崗位薪資】15K-30K

【基本要求】北京-朝陽區/學歷不限/經驗3-5年

【職位描述】

?1.制定和優化運維解決方案,包括但不限于柔性容災、智能調度、彈性擴容與防攻擊。

2.主導業務架構的可運維性設計,參與業務系統的設計與實施。

3.推動及開發高效的自動化運維、管理工具,提升運維工作效率。

4.全方位的性能優化,將用戶速度體驗提升到極致。

5.精確的容量測算和規劃,優化運營成本。

6.探索、研究新的運維技術方向。

【任職資格】

1.3年以上運維經驗,對立體監控、自動部署、容量管理、自動容災有較深入的理解和實踐經驗;

2.對Linux操作系統原理有深入的理解,熟悉 TCP/IP以及常用RPC協議;

3.熟練掌握C/PHP/Python/SHELL等1至2種語言,并有相關開發經驗;

4.良好的溝通、組織協調、項目管理能力和強烈的責任心;

5.對行業技術敏感度高且細致,善于思考,樂于發現,對解決具有挑戰性問題充滿激情。


美團對Linux運維工程師招聘崗位的面試題:

1、LINUX系統軟件安裝和卸載的常見方法

答: A.rpm包卸載:rpm -e XXX.rpm ? (如果想忽略依賴,可加上–nodeps)

B.yum remove xxx.rpm ?這種方法非常不建議使用,卸載過程會將待卸載的軟件包所依賴的軟件包一并卸載掉,很容易造成系統缺少某些包而崩潰等問題

C.源碼包卸載:cd命令進入編譯后的軟件目錄,即安裝時的目錄,執行make uninstall命令即可;或者直接刪除安裝目錄

2、Windows和LINUX常用的遠程連接工具有那些

答: 命令遠程連接工具:Xshell、SecureCRT、Putty、SSH Secure Shell Client等

圖形遠程連接工具:xmanager(需安裝配置服務并打開177端口)、VNC-Viewer(linux需安裝vncserver)、windows自帶的遠程桌面(linux需安裝xrdp和vnc)

3、如何修改LINUX的IP地址、網關和主機名

答:

A、修改IP地址、網關:編輯/etc/sysconfig/network-scripts/ifcfg-eth0,修改里面IPADDR和GATEWAY內容,沒有這兩行,則添加即可,添加時確保BOOTPROTO=static,靜態地址,如IPADDR=192.168.1.100 ? GATEWAY=192.168.1.1

B、修改主機名稱:編輯/etc/sysconfig/network,修改里面的HOSTNAME內容,如設置主機名稱為mysql,則:HOSTNAME=mysql即可;

4、編寫腳本實現以下功能;

? ?每天早上5點開始做備份

? ?要備份的是/var/mylog里所有文件和目錄可以壓縮進行備份

? ?備份可以保存到別一臺器上192、168、1、2 FTP帳號 aaa 密碼 bbb

? ?要示每天的備份文件要帶有當天的日期標記

答:

[[email protected] ~]#cat /root/mylogbak.sh

#!/bin/bash

#scripts for dirbakup and upload to ftp server.

#author by haojiu?

#create by?

bakdir=mylog

date=`date +%F`

cd /var

tar zcf ${bakdir}_${date}.tar.gz ${bakdir}

sleep 1

ftp -n <<- EOF

open 192.168.142.129 ? ?#遠程ftp服務器IP

user aaa bbb

put mylog_*.tar.gz

bye

EOF ?

rm -rf ?mylog_*.tar.gz ? ? #這步之前可以做一個判斷,判斷文件上傳成功再執行rm,留給各位發揮吧。

添加crontab:

crontab -l

00 05 * * * /bin/bash /root/mylogbak.sh ? ? #每天早上5點開始執行備份腳本

5、IPTABLES相關的命令

(豪鷲不熟悉iptables,這里請網友補充,具體問題還要具體分析)

6、mysql相關的題:新安裝MYSQL后怎樣提升MYSQL的安全級別

答: A.修改mysql默認端口

?B.linux下可以通過iptables來限制訪問mysql端口的IP地址

?C.對所有用戶設置較復雜密碼并嚴格指定對應賬號的訪問IP(可在mysql庫中user表中指定用戶的訪問可訪問IP地址)

?D.root特權賬號的處理(建議給root賬號設置強密碼,并指定只允許本地登錄)

?E.開啟二進制查詢日志和慢查詢日志

?F.mysql安裝目錄及數據存儲目錄權限控制:給mysql安裝目錄讀取權限,給mysql日志和數據所在目錄讀取和寫入權限

?G.刪除無用mysql賬號和刪除無用的數據庫(安裝好的mysql默認會有個test庫,可將其刪除)

MYSQL的主從原理,怎么配置文件

答: ?整體上來說,復制有3個步驟: ??

? ? ? A.master將改變記錄到二進制日志(binary log)中(這些記錄叫做二進制日志事件,binary log events);

? ? ? B.slave將master的binary log events拷貝到它的中繼日志(relay log);

? ? ? C.slave重做中繼日志中的事件,將改變反映它自己的數據。

Mysql復制的基本原理過程如下:

(1)Slave上面的IO線程連接上Master,并請求從指定日志文件的指定位置(或者從最開始的日志)之后的日志內容;

(2)Master接收到來自Slave的IO線程的請求后,通過負責復制的IO線程根據請求信息讀取指定日志指定位置之后的日志信息,返回給Slave端的IO線程。返回信息中除了日志所包含的信息之外,還包括本次返回的信息在Master端binary log文件的名稱以及在Binary log中的位置;

(3)Slave的IO線程收到信息后,將接收到的日志內容依次寫入到Slave端的RelayLog文件(mysql-relay-lin.xxxxx)的最末端,并將讀取到的Master端的bin-log的文件名和位置記錄到master-info文件中,以便在下一次讀取的時候能夠清楚的告訴master“我需要從某個bin-log的哪個位置開始往后的日志內容,請發給我”

(4)Slave的SQL線程檢測到Relay Log中新增加了內容后,會馬上解析該Log文件中的內容成為在Master端真實執行時候的那些可執行的查詢或操作語句,并在自身執行那些查詢或操作語句,這樣,實際上就是在master端和Slave端執行了同樣的查詢或操作語句,所以兩端的數據是完全一樣的。

補充:mysql主從復制的優點————

<1> 如果主服務器出現問題, 可以快速切換到從服務器提供的服務;

<2> 可以在從服務器上執行查詢操作, 降低主服務器的訪問壓力;

<3> 可以在從服務器上執行備份, 以避免備份期間影響主服務器的服務。

? 為MYSQL添加一個用戶

? mysql> grant select,insert,update,delete on book.* to [email protected] identified by “abc”; ? ?#增加test2用戶,密碼為abc。并只能在localhost這臺主機上登錄,并且只能訪問book這個庫中的表,具有查詢,插入,更新,刪除權限;

? 語法:mysql> GRANT <權限> ON <庫>.<表> TO ‘用戶’@’主機名’ identified by “密碼”;

7、WINDOWNS相關的問題

? 你是否對WINDOWNS系統打過補丁,如果有100臺你會怎么做

?答: (題主是一個不專業的MCSE,記得在win2003中,有發布指派這個概念的,請各位網友補充)在域環境中,應該是將一臺服務器作為域控補丁的update服務器,利用“發布與指派”的功能,將補丁批量更新到內網其他服務器;

? WINDOWNS下怎么為MYSQL做定時完全備份

? ?答: 批處理+計劃任務+ftp上傳至遠程服務器

? 在沒有硬件防火墻的情況下,怎樣提高WINDOS系統安全

?? 答: 用ISA防火墻?

8、顯示/test目錄下的所有目錄

答:豪鷲這里提供4種方法:

ls -d */

find . -type d -maxdepth 1 ?(如果不加-maxdepth 參數,將會列出無窮多的子目錄。)

ls -F | grep ‘/$’

ls -l | grep ‘^d’|awk ‘{print $9}’

9、將文件/etc/a 下中除了 b文件外的所有文件壓縮打包放到/home/a下,名字為a.gz

答: tar –exclude /etc/a/b -zPcvf /home/a/a.gz /etc/a ? ? ? (不加P選項會提示:『tar: Removing leading `/’ from member names』)

驗證:

[[email protected] a]# tar tPvf /home/a/a.gz ? ? ? ? (忽略掉b文件)

drwxr-xr-x root/root ? ? ? ? 0 2015-08-21 10:15 /etc/a/

-rw-r–r– root/root ? ? ? ? 0 2015-08-21 10:15 /etc/a/d

-rw-r–r– root/root ? ? ? ? 0 2015-08-21 10:15 /etc/a/f

-rw-r–r– root/root ? ? ? ? 0 2015-08-21 10:15 /etc/a/c

-rw-r–r– root/root ? ? ? ? 0 2015-08-21 10:15 /etc/a/e

10、給一個腳本賦予執行權限的命令及選項

答: chmod +x a.sh

11、umask 022代表什么意思

答: 新建文件夾或文件的權限是由所謂基本碼減去稱之為umask的屏蔽位得到的。

按照規定:文件夾的基本碼是rwxrwxrwx(777),文件的基本碼是rw-rw-rw-(666)

因此新建文件夾是777-022=755(rwxr-xr-x),新建文件是666-022=644(rw-r–r–)。

綜上,umask 022表示默認創建新文件權限為755 也就是 rxwr-xr-x(所有者全部權限,屬組讀寫,其它人讀寫)?

12、如何查看某進程所打開的所有文件

答:取出該進程的進程號,然后用lsof -p pid查看打開的所有文件。(這里以crond進程為例)

[[email protected] a]# ps -ef |grep crond|grep -v grep |awk ‘{print $2}’ ? #取出進程號

2550

[[email protected] a]# lsof -p 2550 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #查看該進程打開的所有文件

COMMAND ?PID USER ? FD ? TYPE ? ? ? ? ? ? DEVICE SIZE/OFF ? ?NODE NAME

crond ? 2550 root ?cwd ? ?DIR ? ? ? ? ? ? ? ?8,2 ? ? 4096 ? ? ? 2 /

crond ? 2550 root ?rtd ? ?DIR ? ? ? ? ? ? ? ?8,2 ? ? 4096 ? ? ? 2 /

crond ? 2550 root ?txt ? ?REG ? ? ? ? ? ? ? ?8,2 ? ?64096 ?820728 /usr/sbin/crond

crond ? 2550 root ?mem ? ?REG ? ? ? ? ? ? ? ?8,2 ? ?65928 ?524319 /lib64/libnss_files-2.12.so

crond ? 2550 root ?mem ? ?REG ? ? ? ? ? ? ? ?8,2 99158576 ?788202 /usr/lib/locale/locale-archive

crond ? 2550 root ?mem ? ?REG ? ? ? ? ? ? ? ?8,2 ? 472064 ?554920 /lib64/libfreebl3.so

crond ? 2550 root ?mem ? ?REG ? ? ? ? ? ? ? ?8,2 ? ?43392 ?554921 /lib64/libcrypt-2.12.so

crond ? 2550 root ?mem ? ?REG ? ? ? ? ? ? ? ?8,2 ?1926800 ?554903 /lib64/libc-2.12.so

crond ? 2550 root ?mem ? ?REG ? ? ? ? ? ? ? ?8,2 ? 115536 ?554937 /lib64/libaudit.so.1.0.0

crond ? 2550 root ?mem ? ?REG ? ? ? ? ? ? ? ?8,2 ? ?22536 ?554909 /lib64/libdl-2.12.so

crond ? 2550 root ?mem ? ?REG ? ? ? ? ? ? ? ?8,2 ? ?58480 ?554938 /lib64/libpam.so.0.82.2

crond ? 2550 root ?mem ? ?REG ? ? ? ? ? ? ? ?8,2 ? 124624 ?554913 /lib64/libselinux.so.1

crond ? 2550 root ?mem ? ?REG ? ? ? ? ? ? ? ?8,2 ? 156928 ?554899 /lib64/ld-2.12.so

crond ? 2550 root ? ?0u ? CHR ? ? ? ? ? ? ? ?1,3 ? ? ?0t0 ? ?4160 /dev/null

crond ? 2550 root ? ?1u ? CHR ? ? ? ? ? ? ? ?1,3 ? ? ?0t0 ? ?4160 /dev/null

crond ? 2550 root ? ?2u ? CHR ? ? ? ? ? ? ? ?1,3 ? ? ?0t0 ? ?4160 /dev/null

crond ? 2550 root ? ?3u ? REG ? ? ? ? ? ? ? ?8,2 ? ? ? ?5 1084973 /var/run/crond.pid

crond ? 2550 root ? ?4u ?unix 0xffff88003b3949c0 ? ? ?0t0 ? 13870 socket

crond ? 2550 root ? ?5r ? DIR ? ? ? ? ? ? ? 0,10 ? ? ? ?0 ? ? ? 1 inotify

13、獲取eth0網卡上80端口的數據包信息

答: [[email protected] ~]# tcpdump -i eth0 port 80

14、刪除 /a/b下的所有文件及目錄

答: [[email protected] ~]# rm -rf /a/b/*

15、常用的網絡管理工具(5種以上)

答: Windows下有:ipcofnig(/all,/renew,/release),ping,tracert,nslookup……

????Linux下有:ifconfig,ping,tracerroute,dig,nslookup……

16、ftp、https、smtp、pops、ssh的端口號

答: ftp(20和21)、https(443)、smtp(25)、pops(110)、ssh(22)

17、如何在windows server 2003/2008上開啟支持內存3-4G

答: 豪鷲沒做過,這里提供網上的做法: 在我的電腦上單擊鼠標右鍵,選擇屬性,點擊“高級”標簽,點擊【啟動和故障恢復】下的“設置”按鈕,點擊“編輯”按鈕,將Boot.ini文件的最后一行后面添加一個開關 “/PAE”(不帶引號),保存后重新啟動機器即可。

18、請用iptables控制來自192.168.1.2主機的80端口請求

答: iptables -A INPUT -p tcp -s 192.168.1.2 –dport 80 -j ACCEPT ? (允許來自192.168.1.2這臺主機訪問80端口)

19、請用shell腳本創建一個組class、一組用戶,用戶名為stdX X從01-30,并歸屬class組

答: 腳本如下

[[email protected] ~]# cat adduser.sh?

#!/bin/bash

#script for adduser.

#create by haojiu

#2015-x-x

groupadd class

user=std

for i in {01..30}

do

useradd -G class ${user}$i

done

20、在mysql客戶端查詢工具中,如何獲取當前的所有連接進程信息

答: mysql> show full processlist;

21、如何刪除已滿的數據庫日志信息

答: 在my.cnf中的[mysqld]段下面加入:expire-logs-days=7(設置自動清除7天錢的logs),重啟mysql;

或者登錄進mysql,執行:purge binary logs to ‘mysql-bin.000003’; ? ? ? ? ?#刪除bin-log(刪除mysql-bin.000003之前的而沒有包含mysql-bin.000003)

如果是mysql主從環境的,刪除日志,語句格式如下: ?

PURGE {MASTER | BINARY} LOGS TO ‘log_name’

PURGE {MASTER | BINARY} LOGS BEFORE ‘date’


【特別說明】
面試真題屬于應試者記憶問題的再現,會與真實面試情況存在差別,馬哥linux建議你參考多家企業的Linux運維面試題目,增加通過率。

相關新聞

聯系我們

400-080-6560

在線咨詢:點擊這里給我發消息

郵件:[email protected]

工作時間:周一至周日,09:00-18:30

QR code
云南快乐10分开奖直播