2019年1月2日 第1轮

  1. 下列哪些命令可以测试网络通不通:ping
    扩展:
    ping是一种电脑网络工具,用来测试数据包能否通过IP协议到达特定主机。ping的运作原理是向目标主机传出一个ICMP echo@要求数据包,并等待接收echo回应数据包。程序会按时间和成功响应的次数估算丢失数据包率(丢包率)和数据包往返时间(网络时延,Round-trip delay time)。
    traceroute,现代Linux系统称为tracepath,Windows系统称为tracert,是一种电脑网络工具。它可显示数据包在IP网络经过的路由器的IP地址。
    Netstat是在内核中访问网络及相关信息的程序,它能提供TCP连接,TCP和UDP监听,进程内存管理的相关报告。Netstat是控制台命令,是一个监控TCP/IP网络的非常有用的工具,它可以显示路由表、实际的网络连接以及每一个网络接口设备的状态信息。Netstat用于显示与IP、TCP、UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况。
  2. 在 linux 下,如何查看物理内存的大小? cat /proc/meminfo
    扩展:
    方式一:free
    直观的展示linux系统内存使用及交换区的容量大小等
    方式二:top
    动态实时查看系统中每一个进程的资源使用情况
    方式三:cat /proc/meminfo
    方式四:gnome-system-monitor 一个显示最近一段时间内的CPU、内存、交换区及网络使用情况的视图工具
    方式五:ps aux –sort -rss
    各个线程的资源使用情况
    方式六:vmstat -s
    vmstat命令显示实时的和平均的统计,覆盖CPU、内存、I/O等内容。
  3. 在Shell环境下,如何查看远程Linux系统运行了多少时间:ssh user@被监控主机ip “uptime”
    ssh命令用于远程登录上Linux主机。
    常用格式:ssh [-l login_name] [-p port] [user@]hostname
    scp是 secure copy的缩写, scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令。
    scp [可选参数] file_source file_target
    uptime命令能够打印系统总共运行了多长时间和系统的平均负载。uptime命令可以显示的信息显示依次为:现在时间、系统已经运行了多长时间、目前有多少登陆用户、系统在过去的1分钟、5分钟和15分钟内的平均负载。
  4. 可以用于获取本机cpu使用率的是:top
    扩展:
    ifconfig是linux中用于显示或配置网络设备(网络接口卡)的命令
    uptime显示开机时间
    top显示当前系统资源使用情况,相当于任务管理器
    netstat命令用于显示与IP、TCP、UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况。
  5. 使用 dpkg 命令安装的软件为:.deb
    扩展:
    dpkg ---- deb
    yum -----rpm
    apt-get — deb
    tar ----- bz2
    unzip ------ zip
  6. 新建一个管理员用户admin,需要使用的参数:useradd -u 0 -o admin
    解析:
    -u 表示指定用户的用户号,由于系统用户的用户号是0,所以指定用户号为0。如果同时有-o选项,则可以重复使用其他用户的标识号;即-u 0 -o admin的到相同的效果。但是系统本身勋在用户号为0 的系统用户,则这里应该使用-o admin参数;
  7. 若一台计算机的内存为128MB ,则交换分区的大小通常是:256MB。
    解析:
    交换分区,就是windows中虚拟内存在linux中的叫法;其空间的分配的推荐做法是:
    目前Red Hat(红帽官方)推荐交换分区的大小应当与系统物理内存的大小保持线性比例关系。
    在小于2GB物理内存的系统中,交换分区大小应该设置为内存大小的两倍;
    如果内存大小多于2GB,交换分区大小应该是物理内存大小加上2GB;
    原则上,由于交换分区读写速度比真正内存区慢的多,因此在实际应用中如果不是特别需要应该设置的越小越好。一般是内存*1.5或者2。
  8. 下列关于makefile描述正确的有:
  • makefile文件保存了编译器和连接器的参数选项
  • 主要包含了五个东西:显式规则、隐晦规则、变量定义、文件指示和注释
  • 默认的情况下,make命令会在当前目录下按顺序找寻文件名为“GNUmakefile”、“makefile”、“Makefile”的文件, 找到了解释这个文件
  • 在Makefile使用include关键字可以把别的Makefile包含进来
    解析:
    makefile文件保存了编译器和连接器的参数选项,还表述了所有源文件之间的关系(源代码文件需要的特定的包含文件,可执行文件要求包含的目标文件模块及库等).创建程序(make程序)首先读取makefile文件,然后再激活编译器,汇编器,资源编译器和连接器以便产生最后的输出,最后输出并生成的通常是可执行文件.创建程序利用内置的推理规则来激活编译器,以便通过对特定CPP文件的编译来产生特定的OBJ文件.
    Makefile里主要包含了五个东西:显式规则、隐晦规则、变量定义、文件指示和注释。
    1、显式规则。显式规则说明了,如何生成一个或多的的目标文件。这是由Makefile的书写者明显指出,要生成的文件,文件的依赖文件,生成的命令。
    2、隐晦规则。由于我们的make有自动推导的功能,所以隐晦的规则可以让我们比较粗糙地简略地书写Makefile,这是由make所支持的。
    3、变量的定义。在Makefile中我们要定义一系列的变量,变量一般都是字符串,这个有点你C语言中的宏,当Makefile被执行时,其中的变量都会被扩展到相应的引用位置上。
    4、文件指示。其包括了三个部分,一个是在一个Makefile中引用另一个Makefile,就像C语言中的include一样;另一个是指根据某些情况指定Makefile中的有效部分,就像C语言中的预编译#if一样;还有就是定义一个多行的命令。有关这一部分的内容,我会在后续的部分中讲述。
    5、注释。Makefile中只有行注释,和UNIX的Shell脚本一样,其注释是用“#”字符,这个就像C/C++中的“//”一样。如果你要在你的Makefile中使用“#”字符,可以用反斜框进行转义,如:“#”。
    默认的情况下,make命令会在当前目录下按顺序找寻文件名为“GNUmakefile”、“makefile”、“Makefile”的文件,找到了解释这个文件。在这三个文件名中,最好使用“Makefile”这个文件名,因为,这个文件名第一个字符为大写,这样有一种显目的感觉。最好不要用 “GNUmakefile”,这个文件是GNU的make识别的。有另外一些make只对全小写的“makefile”文件名敏感,但是基本上来说,大多数的make都支持“makefile”和“Makefile”这两种默认文件名。
    在Makefile使用include关键字可以把别的Makefile包含进来,这很像C语言的#include,被包含的文件会原模原样的放在当前文件的包含位置。include的语法是:
    include ; filename可以是当前操作系统Shell的文件模式(可以保含路径和通配符)
  1. 在RHEL5系统中使用vi编辑文件时,要将某文本文件第1行到5行的内容复制到文件中的指定位置,以下( )操作能实现该功能。
  • 将光标移到第1行,在vi命令模式下输入5yy,然后将光标移到制定位置,按p键
  • 使用末行命令1,5y,然后将光标移到制定位置,按p键
    扩展:
    nyy:复制以下n行
    n,my:指定n到m行复制
    p:在光标下一行粘贴
    P(大写):在光标上一行粘贴(插入)
  1. 编译内核时,可以使用哪些命令对内核进行配置?
  • make config
  • make menuconfig
  • make oldconfig
  • make xconfig

2019年1月2日 第2轮

  1. 增加一个用户的命令是什么:useradd
    扩展:
    useradd 增加用户
    usermod 修改用户账号信息
    groupadd 添加组账号
    userdel 删除用户
  2. Linux文件系统的文件都按其作用分门别类地放在相关的目录中,对于外部设备文件,一般应将其放在(dev)目录中。
    扩展:
    /bin 二进制可执行命令
    /dev 设备特殊文件
    /etc 系统管理和配置文件
    /etc/rc.d 启动的配置文件和脚本
    /home 用户主目录的基点,比如用户user的主目录就是/home/user,可以用~user表示
    /lib 标准程序设计库,又叫动态链接共享库,作用类似windows里的.dll文件
    /sbin 超级管理命令,这里存放的是系统管理员使用的管理程序
    /tmp 公共的临时文件存储点
    /root 系统管理员的主目录
    /mnt 系统提供这个目录是让用户临时挂载其他的文件系统
    /lost+found这个目录平时是空的,系统非正常关机而留下“无家可归”的文件(windows下叫什么.chk)
    /proc 虚拟的目录,是系统内存的映射。可直接访问这个目录来获取系统信息。
    /var 某些大文件的溢出区,比方说各种服务的日志文件
    /usr 最庞大的目录,要用到的应用程序和文件几乎都在这个目录,其中包含:
    /usr/x11R6存放x window的目录
    /usr/bin众多的应用程序
    /usr/sbin超级用户的一些管理程序
    /usr/doclinux文档
    /usr/includelinux下开发和编译应用程序所需要的头文件
    /usr/lib常用的动态链接库和软件包的配置文件
    /usr/man帮助文档
    /usr/src源代码,linux内核的源代码就放在/usr/src/linux里
    /usr/local/bin本地增加的命令
  3. 如何获取上一条命令执行的返回码:$?
    扩展:
    $0 # 脚本启动名(包括路径)
    $n # 第n个参数,n=1,2,…9
    $* # 所有参数列表(不包括脚本本身)
    $@ # 所有参数列表(独立字符串)
    $# # 参数个数(不包括脚本本身)
    $$ # 当前程式的PID
    $! # 执行上一个指令的PID
    $? # 执行上一个指令的返回值
  4. tar命令用于解压的参数是 : -x
    -c: 创建新的档案文件。如果用户想备份一个目录或是一些文件,就要选择这个选项。相当于打包。
    -x: 从档案文件中释放文件。相当于拆包。
    -z :是否同时具有 gzip 的属性?亦即是否需要用 gzip 压缩或解压? 一般格式为xx.tar.gz或xx. tgz
    -j :是否同时具有 bzip2 的属性?亦即是否需要用 bzip2 压缩或解压?一般格式为xx.tar.bz2
    -v :压缩的过程中显示文件!这个常用
    -f :使用档名,请留意,在 f 之后要立即接档名喔!不要再加其他参数!
    -p :使用原文件的原来属性(属性不会依据使用者而变)
  5. 在OSI模型中,HTTP协议工作在第(7)层,交换机工作在第(2)层。
    解析:
    物理层: RJ45 、 CLOCK 、 IEEE802.3 (中继器,集线器,网关) -
    数据链路: PPP 、 FR 、 HDLC 、 VLAN 、 MAC (网桥,交换机) -
    网络层: IP 、 ICMP 、 ARP 、 RARP 、 OSPF 、 IPX 、 RIP 、 IGRP 、 (路由器) -
    传输层: TCP 、 UDP 、 SPX -
    会话层: NFS 、 SQL 、 NETBIOS 、 RPC -
    表示层: JPEG 、 MPEG 、 ASII -
    应用层: FTP 、 DNS 、 Telnet 、 SMTP 、 HTTP 、 WWW 、 NFS
    扩展:
  6. 在UNIX系统中,目录结构采用:带链接树形目录结构。
    解析:
    带链接树形目录结构又称非循环图目录结构,它是指访问一文件(或目录)可以有多条路径。一般常说UNIX的文件系统是树形结构,其实是指带链接的树形结构,而不是纯树形目录结构。
    扩展:
    带连接树形结构是指目录呈现树形,树的叶子节点则是指向文件的指针。
    分为两种:
    硬链接:每一条路径下存放文件的指针,该指针指向了一个记录节点结构(该结点还有文件指针指向了文件A,并且有A被链接的次数n),当删除某目录下的该文件(之指针)时,n–,当n=0时,该文件彻底删除。
    软链接:某条路径下存放真实文件,该路径称为该文件的owner,其它路径链向它时则被视为快捷方式,若owner路径下的该真实文件被删除,则所有的快捷方式失效,提示是否清楚掉此快捷方式。
  7. 下列程序代码在Linux系统执行后"*"会被输出多少次(14)
void main()
{
int i;
for(i=0;i<3;i++)
{
fork();
printf("*\n");
}
return;
}

解析:

1.linux刷题_编译器

  1. 以下关于读屏障、写屏障、通用屏障和优化屏障说法正确的是:
    优化屏障则用于限制编译器的指令重排
    通用屏障则对读写操作都有作用
    读屏障用于保证读操作有序。屏障之前的读操作一定会先于屏障之后的读操作完成,写操作不受影响
    分析:
    内存屏障主要有:读屏障、写屏障、通用屏障、优化屏障几种。
    以读屏障为例,它用于保证读操作有序。屏障之前的读操作一定会先于屏障之后的读操作完成,写操作不受影响,同属于屏障的某一侧的读操作也不受影响。
    类似的,写屏障用于限制写操作。
    而通用屏障则对读写操作都有作用。而优化屏障则用于限制编译器的指令重排,不区分读写。前三种屏障都隐含了优化屏障的功能。
  2. 以下哪个是linux日志文件系统(ext3,ext4)
    扩展:
    JFS:IBM的 Journaled File System, 最早的日志文件系统[1]。
    Ext4/Ext3文件系统:Ext2文件系统演化而成的日志文件系统,广泛用于Linux系统。
    ReiserFS:用B+树作为数据结构的日志文件系统,在处理小文件时有较好的性能。
    Btrfs:用B树作为数据结构,被认为是下一代Linux文件系统[2]。
    NTFS:微软的NTFS也是日志文件系统,也是Windows NT下最常用的文件系统。
    HFS+:苹果公司发展的OS X操作系统下主要使用的文件系统。
  3. 在Red Hat Linux系统中,DHCP服务器可以提供的服务包括( )
    提供DNS、网关信息
    为特定客户机提供固定IP地址(当你把 dhcp 状态设置为 static 时就可以设置固定 IP 了)
    为主机提供动态的IP地址
    扩展:
    DHCP服务:根据UDP协议实现。分为DHCP服务器端和DHCP客户端,其中DHCP服务器端就是设置对应的IP地址池以及DNS服务器地址等信息以动态分配给客户端;DHCP客户端就是从服务器端动态获取IP地址、子网掩码、网关地址、DNS服务器地址等信息。