运维面试题, 不知是否正确的答案

1、简述TCP三次握手四次挥手过程及各过程中客户端和服务器端的状态。

握手:

client 发送请求SYN到 server; 状态:server;初始状态为LISTEN,client 发送SYN后变为SYN_SENT

server 发送ACK回应,并发送SYN请求到 client;状态:服务器收到SYN后,变为SYN_RCVD,发送ACK+SYN后,变为ESTAHLISHED

client 发送ACK到服务端,连接建立。 客户端变为ESTABLISHED

挥手:

client 发送断开请求FIN到 server;状态:客户端发送FIN后,变为FIN_WAIT_1

server 发送ACK回应 client;状态:server收到FIN后,变为CLOSE_WAIT,client收到ACK后,变为FIN_WAIT_2

server 发送FIN到 client;状态:server发送FIN后,变为LAST_ACK状态,client收到FIN后,变为TIME_WAIT

client 发送ACK到 server,连接断开;状态:server收到ACK后,变为CLOSED。

2、说说进程和线程的区别

进程是程序在执行过程中的基本单位。每个进程至少包含一个线程,线程之间可以共享变量,进程之间需要使用queue等机制实现变量的共享。

3、查询file.txt以abc结尾的行

grep 'abc$' file.txt

4、删除file.txt文件中的空行

sed -i ‘/^$/d’ file.txt

5、打印file.txt文件中的第10行

sed -n ‘10p’ file.txt

6、对MySQL数据库test进行备份和恢复

备份:mysqldump -uroot -p test > ~/test.sql

恢复:mysql -uroot -p < ~/test.sql

7、用netstat统计系统当前tcp连接的各种状态的连接数。

netstat -an | awk '/^tcp/ {print $NF}' |uniq -c

8、linux下如何将GBK编码格式的test_gbk.txt文件转换成UTF-8编码格式,转化后的文件名为 test_utf8.txt

#!/bin/env python

f_gbk = open(‘test_gbk.txt’, ‘r’)

f_utf = open(‘test_utf8.txt’,’a’)

for line in f_gbk: 

line = line.decode(‘gbk’) 

f_utf.write(line.encode(‘utf-8’))

f_gbk.close()

f_utf.close()

9、说说你用过哪些监控软件,并简述其原理及适用场景

zabbix,原理:agentd搜集被监控服务器的信息,传给服务端,服务端写入数据库。

再通过php的网页将数据展现出来

适用场景:监控支持snmp的设备,监控linux主机,监控mysql redis mangodb的状态

10、写出查看linux系统性能的命令,如cpu、内存、流量、io等

ps top free iostat vmstat netstat iptraf

终极解决方案 阿里巴巴开源的tsar

11、说说nginx的upstream支持的分配策略,并简述其原理

轮询:请求按顺序分配到后端服务器

weight:与轮询相同,对weight增加权重

ip_hash: 根据ip的hash结果分配到固定的后端服务器

url_hash: 与ip_hash相同,不过按照url的hash结果分配到固定的后端服务器

12、crontab定时:在11月份内,每天的早上6点到12点中,每隔2小时执行一次/usr/bin/httpd.sh  怎么实现

echo '*  6-12/2 * 11 * root /usr/bin/httpd.sh' >> /etc/crontab

13、iptables禁止 ip 10.10.10.1 访问本地80端口

iptables -A INPUT -s 10.10.10.1 -p tcp —dport 80 -j DROP

14、找出在文件a中但不在文件b中的内容,用命令后编写脚本实现

#!/bin/bash

diff a b | grep '>' | sed -r 's/>(.*)/\1/g'

15、编写shell循环创建100个用户,用户名格式user_[0~99]

#!/bin/bash

for i in `seq 0 99`; do

useradd "user_$i"

done

原创文章,作者:aaron,如若转载,请注明出处:http://www.178linux.com/18969

(0)
aaronaaron
上一篇 2016-06-23
下一篇 2016-06-23

相关推荐

  • 每日一练–8.2 用户管理,权限管理

    (1)显示/var目录下所有以l开头,以一个小写字母结尾,且中间出现至少一位数字的文件或目录。     ll /var/l*[[:digit:]]*[[:lower:]] (2)显示以/etc目录下以任意一位数字开头,且以非数字结尾的文件或目录      ll /etc/[[:digit:]]*[^[:dig…

    Linux干货 2016-08-05
  • 马哥教育网络班20期+第二周课程练习

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。  答:文件管理类命令有: touch :创建一个新文件 示例:在/tmp/目录下创建一个1.log文件 touch /tmp/1.log mv:移动文件  示例:将/etc/fstab文件移至/tmp/目录中。  mv /etc/fstab /tmp/…

    Linux干货 2016-06-23
  • 第十周

    1、请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情) 1.POST 开机加电自检,对计算机的cpu,硬盘,内存等进行检测。 2.BIOS 对引导程序进行探测,并把控制权交给引导程序。 3.MBR Master bootloader record主引导程序.通常位于硬盘第一扇区/dev/hda(0,0)或/dev/sda(0,0). 此阶…

    Linux干货 2017-03-30
  • 本地yum仓库配置以及创建yum仓库

    如何使用光盘当做本地yum仓库?     1.挂载光盘至某目录,例如/media/cdrom      [root@CentOS7 ~]# mount /dev/cdrom /media/cdrom/ mount: /dev/sr…

    Linux干货 2016-08-23
  • 第九周练习

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash # nologin=$(awk -F: '$NF=="/sbin/nologin"{print $NF}…

    Linux干货 2016-12-21
  • iptables入门到进阶

    netfilter/iptables:        netfilter是存在于内核中的一个防火墙框架,用来管理网络数据包,netfilter在IP数据包处理流程中的5个关键位置放置了5个钩子(hook)函数,当数据包流经相应的位置时,相应的钩子函数会被调用,每个对应的钩子上有对应的表,表中有对应的…

    Linux干货 2017-05-02