do some test

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

    三次握手:

        a(syn-send) -> send syn -> b(listen)

        a(syn-send) <- receive syn_ack <- b(sync_recv)

        a(estabilish) -> send ack -> b(estabilish)

    四次挥手:

        a(fin_wait1) -> send fin -> b(close-wait)

        a(fin_wait2)<- receive ack <- b(close-wait)

        a(fin_wait2) <- receive fin <- b(last-ack)

        a(time_wait)-> send ack -> b(closed)

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

    进程是程序运行在内存中的表现。进程都拥有独立地址空间,不同进程之间的资源访问只能通过IPC机制;线程是进程内部的不同执行路径,多个线程除了栈是独立的,其余都共享着进程的内部资源,因此线程占用着更小的内存;进程切换需要保存和切换整个内存空间开销较大,而线程切换仅需要保存和切换线程栈的上下文即可

    

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

    grep 'abc$' file.txt

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

    sed -i '/^[[:space:]]*$/d' file.txt

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

    sed -n '10p' file.txt

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

    backup:

        mysqldump –single-transation -uUSERNAME -p test > db.test.sql

    restore:

        mysql -uUSERNAME -p test < db.test.sql

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

    netstat -tn | awk '$1 ~ /^tcp/ {a[$NF]++;} END {for (state in a) { print state,a[state]}}'

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

    iconv -f gbk -t utf-8 test_gbk.txt -o test_utf8.txt

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

    zabbix:

        使用master、agent模式,agent负责收集被监控节点的数据,根据其设置主动或被动模式,分别由master向agent获取数据或agent上报数据给master,最终数据由master写入数据库保存,并通过web展示接口从数据库中获取数据、绘制图形并展现到用户

        应用场景:

            目前主流的统一监控,能支持分布式监控、自定义监控项及告警、监控数据的图表展现,基本上满足日常监控需要的各种场景

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

    cpu:

        top、htop

    内存:

        free

    流量:

        iftop、nethogs

    io:

        iostat

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

    rr/wrr:

        使用轮询或加权轮询后端server实现负载均衡

    lc/wlc:

        基于后端server的最少连接数来选择要转发至哪个后端server

    一致性会话:

        基于客户端source ip的hash值来选择特定的后端server,相同sip的请求会转发到同一后端server

        基于cookie,在client端植入cookie,每次接收client请求,通过此cookie判断要转发到哪台后端server,因此,同一client的请求会转发到相同的后端server

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

    crontab -e

    * 6-12/2 * 11 * /usr/bin/httpd.sh

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

    iptables -I INPUT -s 10.10.10.1/32 –dport 80 -j DROP

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

    command:

          grep -v -f b.txt a.txt  

    script:

        #!/bin/bash

        

        while read aline; do

            bingo=0

            while read bline; do

                if [[ "$aline" = "$bline" ]]; then

                    bingo=1

                    break

                fi

            done < b.txt

            [ $bingo -eq 0 ] && echo $aline

        done < a.txt

    

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

    for id in {0..99}; do useradd user_$id; done

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

(0)
gateraygateray
上一篇 2016-06-12
下一篇 2016-06-12

相关推荐

  • Redis 3.0.0正式版发布,全新的分布式高可用数据库

    Redis 3.0.0 正式版终于到来了!最重要的新特性是集群(Redis Cluster),提供Redis功能子集(比如不支持多数据库)的分布式、容错的实现(最多支持1000结点)。   Salvatore 'antirez' Sanfilippo在Google Groups里表示,这是Redis的重要时刻。“我相信今天的Redis 3.0…

    Linux干货 2015-04-03
  • N22-第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。     首先用who命令查看所有已登录用户信息,然后用cut命令取出用户名,再用sort -u对用户名排序并删除重复的用户名      2、取出最后登录到当前系统的用户的相关信息。  &n…

    Linux干货 2016-09-05
  • IoC/DIP其实是一种管理思想

    关于IoC的的概念提出来已经很多年了,其被用于一种面象对像的设计。我在这里再简单的回顾一下这个概念。我先谈技术,再说管理。 话说,我们有一个开关要控制一个灯的开和关这两个动作,最常见也是最没有技术含量的实现会是这个样子: 然后,有一天,我们发现需要对灯泡扩展一下,于是我们做了个抽象类: 但是,如果有一天,我们发现这个开关可能还要控制别的不单单是灯泡的东西,我…

    Linux干货 2016-08-15
  • 磁盘管理

    1、设备文件 设备文件:关联至一个设备驱动程序,进而能够跟与之对应硬件设备进行通信 设备号码: 主设备号major number,标识设备类型 次设备号minor number,标识同一类型下的不同设备 [root@localhost ~]# ll /dev/sd* brw-rw—-. 1 root disk 8,  0 Aug 25 …

    Linux干货 2016-09-01
  • linux时间

    linux有两个时间:     系统时间和硬件时间 系统时间: 最简单的使用date命令显示当前系统的时间,命令行输入date。 # date Thu Jun  2 17:11:48 CST 2016 date的具体使用方式:     1. date格式显示:date …

    Linux干货 2016-06-03
  • 域名解析服务(DNS)之bind

    DNS简介 DNS是Domain Name System的简称,DNS的主要作用就是讲主机名解析成ip地址的过程,因为在计算机网络当中是通过ip地址来进行主机间通信的,ipv4的地址是32位,人类记忆起来十分困难,更何况ipv6的128位,所以我们需要一个简单容易记忆的字符串来替换ip地址,当我们访问www.baidu.com它能知道访问的是某个ip地址的服…

    Linux干货 2016-10-09