Linux-基础题

Posted 任伟

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux-基础题相关的知识,希望对你有一定的参考价值。

Linux-基础题

  1. Linux命令格式是什么样?

    Linux命令			可选的参数			你要操作的对象
    #显示根目录下的文件内容
    ls /
    #显示根目录下文件内容的详细信息,以及文件大小
    ls -l -h /
    #显示当前目录下的文件大小
    ls   其实这个命令后面跟了一个文件夹 ls .
    
  2. Linux命令必须添加参数才能执行吗?

    不是,参数可选
    
  3. 理解Linux的命令提示符,如何用Linux命令解析

    whoami #显示当前机器的登录用户
    hostname #查看主机名字
    hostnamectl set-hostname  新的主机名  #更改主机名,需要重新登录
    ~ 代表用户家目录
    # 超级用户身份提示符
    $ 普通用户身份提示符
    
  4. Linux的目录分隔符是什么

    是正斜杠 /
    / 在开头就是根目录,除了开头都是目录分隔符
    
  5. 简述Linux的目录结构

    Linux目录结果是一颗倒状的一个树
    以 / 根目录为起点
    /root
    /home
    /opt
    /usr
    linux 类似于Windows中只有一个C盘
    
  6. 切换到上一级目录

    cd ..
    
    . 	当前工作目录
    ..	上一级工作目录
    -		上一次工作目录
    ~		当前系统登录用户的家目录
    
  7. 切换到上一次目录

    cd -
    
  8. 切换到用户家目录

    cd ~
    
  9. 查看当前工作目录

    pwd
    
  10. 当前目录是/home,以绝对、相对两种路径进行进入/opt目录

    绝对路径:路径以根目录为起点,就是绝对路径 cd /opt
    相对路径:非根目录为起点都是相对路径	cd ../opt
    
  11. 列出/opt/下所有文件,包括隐藏文件,且显示详细信息(时间和文件大小)

    ls -a -l /opt
    
  12. 以树状结果显示文件夹内容

    tree /opt #树状显示opt下的内容
    
  13. 一条命令创建/tmp/chaoge/linux文件夹

    mkdir -p /tmp/chaoge/linux
    
  14. 创建Python脚本first.py

    touch first.py
    
  15. 一条命令创建/tmp/chaoge1.txt 、/tmp/chaoge2.txt

    touch /tmp/chaoge1.txt 、/tmp/chaoge2.txt   #第一种方式
    touch /tmp/chaoge1..2.txt 							 # 第二种方式
    
  16. 复制/data/下所有的内容移动到/tmp/下

    cp -r /data/* /tmp/   #递归拷贝data整个文件夹,放入tmp下
    cp -r /data /tmp/			 #递归拷贝data中所有的内容,放入tmp下
    
  17. 更改文件名first.txt为second.txt

    mv first.txt second.txt
    
  18. 把/opt/下所有内容移动到/tmp下

    mv /opt/* /tmp
    
  19. 强制删除/tmp下所有内容

    rm -rf /tmp/*
    
  20. 查看ls命令的帮助信息

    ls --help  #命令简短帮助信息
    man ls		 #ls命令的帮助手册
    info ls		 #ls命令的帮助手册
    
  21. 立即重启命令

    reboot
    shutdonw -r now
    
    #关机命令
    poweroff
    shutdonw -h now
    
  22. 如何永久设置Linux环境变量

    $PATH  代表Linux的环境变量名
    echo $PATH  #查看当前PATH的值
    PATH="环境变量的路径"  #执行一次,是临时生效
    
    #永久生效需要修改Linux的全局环境变量文件 /etc/profile
    用vim打开/etc/profile写入 如下内容
    PATH="新的环境变量"
    
  23. Linux的常见配置文件目录是

    etc/nginx.conf		#是Nginx配置文件
    etc/my.conf				#是MySQL配置文件
    
  24. vim三种模式是?使用流程是?

    1.vim filename.txt 打开文件,此时进入命令魔兽
    2.在命令模式下,输入a(在光标后面开始编辑)、i(在光标当前位置开始编辑)、o(在光标下一行开始编辑) 都可以进入编辑模式
    3.在编辑模式下写完代码之后,按下esc,退出编辑模式,输入冒号,进入底线命令模式。输入:wq!
    :wq! 强制写入文件内容且保存退出
    : q! 不写入内容,直接强制退出
    
  25. 查看文件且显示行号

    cat -n file.txt
    
  26. 如何清空文件内容,注意不是空内容,而非空空格

    利用重定向符号,输出重定向
    > 重定向覆盖输出符
    >> 重定向追加输出符
    
    > file.txt		#完全清楚文件内容
    
  27. 显示文件前30行

    head -n 30 filename.txt
    
  28. 显示文件后50行

    tail -n 50 filename.txt
    
  29. 实时刷新文件内容

    # 常用查看日志文件内容
    tail -f filename.txt  #tail是重文件结尾开始读取,f参数是刷新文件内容
    
  30. 读取文件内容且倒序排序

    cat filename.txt | sort -nr   #r 是反转排序
    
  31. 读取文件内容进行排序后去重

    cat 查看文件内容
    sort 对文件内容排序
    uniq 对文件内容去重
    
    cat file.txt | sort -n | uniq 
    
  32. 读取文件内容进行排序后,统计重复行的次数

    cat file.txt | sort -n | uniq -c
    sort -n # 排序
    uniq -c # 统计重复行数量
    
  33. 统计文件一共有多少行

    wc -l file.text
    
  34. 如何查看文件的详细信息(inonde号,访问,修改事件,连接数)

    stat file.txt
    
  35. 找出服务器上所有以“.py”结尾的文件

    find -type -name		
    #find 你要从哪里找
    #-type 指定文件的类型(文件,文件夹)
    #-name 你要找的文件叫什么
    
    find / -type f  -name \'*.py\'
    
  36. 找出服务器2天内被访问过的文件

    -atime -2  #在2天内被访问过的文件
    
    find / -atime 2 -type f -name \'*.txt\'
    
  37. 找出服务器大于50的文件

    find /  -type f -size +50M
    
  38. 找出/tmp/目录下所有的txt文件,然后删除

    find . -type f -name "*.txt" -ok rm  \\;
    
  39. 把/data/html/文件夹打包压缩成data_html.tgz文件

    tar 打包和压缩的命令
    -c	打包
    -x	解包
    -v	显示过程
    -f  指定文件名 
    tar -czvf data_html.tgz  /data/html/
    
  40. 如果解压缩alltmp.gz文件

    gzip -d alltmp.gz
    
  41. 如何解压缩data.zip文件

    unzip data.zip
    
  42. 显示具体系统事件,时:分:秒

    date +%T
    
  43. 如何彻底粉碎文件

    shred -u text.txt
    

linux运维基础题

1、Linux挂载Winodws共享文件夹
  # mount -t cifs //1.1.1.254/ok /var/tmp/share/ -o username=administrator,password=yourpass

2、查看http的并发请求数及其TCP连接状态:
  netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}‘

3.用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

4、统计指定目录的文件个数
  find / -type f | wc -l

5、查看IP连接数
  netstat -n | awk ‘/^tcp/ {print $5}‘| awk -F: ‘{print $1}‘ | sort | uniq -c | sort -rn

6、【shell下32位随机密码生成】
  tr -dc \~\`\[email protected]#\\$\\%\\^\\&\*\-\_\+\=\|\\\?\/\.\>\,\<A-Za-z0-9_ < /dev/urandom|head -c 32|xargs

7、统计出apache的access.log中访问量最多的5个IP
  cat access.log |awk ‘{print $1}‘|uniq -c|sort -rn |head -n 5

8、如何查看二进制文件的内容
    echo /etc/passwd | hexdump -C      <== 规范的十六进制和ASCII码显示(Canonical hex+ASCII display )

9、ps aux 中VSZ代表什么意思 RSS代表什么  
     aux
     a 显示所有与终端相关的进程,由终端发起的.
     x 显示所有与终端无关的进程.
     u 显示用户导向的用户列表.
  VSZ   虚拟内存集,进程占用的虚拟内存空间
  RSS   物理内存集,进程战用实际物理内存空间.

10、检测并修复/dev/hda5
  e2fsck -p /dev/hda5       //e2fsck针对ext2 ext3 类型文件系统

11、Linux开机启动顺序
启动顺序:
POST(加电自检)-->由BIOS决定启动设备次序-->MBR(bootloader)-->解压kernel,加载Kernel到内存-->加载init进程(/etc/inittab)

12、符号链接和硬链接的区别
硬链接:不同路径的文件指定的是同一个inode
     硬链接不能跨分区存在
     硬链接不能链接到目录(要避免循环引用)
     删除硬链接只会减少文件被硬链接的次数,源文件不会动.
软链接:是一个独立的文件,有自己独立的inode
     引用的是路径本身,不是inode
     删除软链接,跟源文件没任何关系
     软链接没有存储任何数据,只是存储了访问文件的另一种路径.
     软链接可以对目录创建,也可以跨分区
     源文件被删除,软连接将不可用.

13、保存当前磁盘分区的分区表
  # sfdisk -d /dev/sdb >/etc/sdbpar.bak          //保存分区表
  # sfdisk /dev/sdb


14、检测并自动修复文件系统
e2fsck - check a Linux ext2/ext3 file system
     -B     指定块大小
     -f     强制检测.
     -p     自动修复文件系统

15、手动安装grub
手动安装grub
# grub-install --root-directory=(指定boot目录) DEVICE
或者
grub
grub>root (hd0,0)
grub>setup (hd0)

16、改内核参数
# sysctl
     -p     不用重启系统,让内核重读/etc/sysctl.conf文件
     -a     显示所有内核参数及其正在使用的值.
     -w     临时设置/etc/sysctl.conf参数     sysctl -w net.ipv4.ip_froward=0

17、在指定范围内取随机数
  echo $[$RANDOM%39] 对39进行取余,余数肯定是39以内的数字.
不限定范围 echo $RANDOM

18、限定apache每秒钟连接数为1,峰值为3
   iptables -A INPUT -d 172.16.100.1 -p tcp --dport 80 -m limit --limit 1/second --limit-burst 3 -j ACCEPT

19、FTP主动与被动模式
主动模式
    1. 任何大于1024的端口到FTP服务器的21端口。(客户端初始化的连接)
    2. FTP服务器的21端口到大于1024的端口。 (服务器响应客户端的控制端口)
    3. FTP服务器的20端口到大于1024的端口。(服务器端初始化数据连接到客户端的数据端口)
    4. 大于1024端口到FTP服务器的20端口(客户端发送ACK响应到服务器的数据端口)
被动模式
    1. 从任何大于1024的端口到服务器的21端口(客户端初始化的连接)
    2. 服务器的21端口到任何大于1024的端口(服务器响应到客户端的控制端口的连接)
    3. 从任何大于1024端口到服务器的大于1024端口(客户端初始化数据连接到服务器指定的任意端口)
    4. 服务器的大于1024端口到远程的大于1024的端口(服务器发送ACK响应和数据到客户端的数据端口)

客户端与服务端建立连接,经过TCP三次握手,连接建立完成之后,客户端就可以通过建立的连接通道向服务器发送命令了,服务器根据客户端的命令,

向客户端发送数据,发送数据的时候,服务端会再跟客户端建立一个TCP连接,用于专门的传输数据,这个连接就是数据连接。
数据连接有两种工作模式:主动模式和被动模式
主动模式指的是服务器是主动的
被动模式指的是服务器是被动的
主动模式:
服务器端自动打开20号端口,即数据传输端口。主动的去连接客户端的命令端口+1的端口。当数据传输完成后,数据连接自动断开。
被动模式:
服务器端向客户端通知自己打开的端口,通知客户端来连接自己的数据端口,客户端使用命令端口+1的端口,去连接服务器端的数据端口。
被动模式下,服务器的数据连接端口使用的是一个随机端口。主动模式服务端使用的是20端口。



20、显示/etc/inittab中以#开头,且后面跟一个或多个空白字符,而后又跟了任意非空白字符的行;
   grep "^\#[[:space:]]\{1,\}.\{1,\}" /etc/inittab

21、显示/etc/inittab中包含了:一个数字:(即两个冒号中间一个数字)的行;
   grep "\:[0-9]\{1\}\:" /etc/inittab

22、怎么把自己写的脚本添加到服务里面,即可以使用service命令来调用
  #!/bin/bash
   chkconfig: - 90 10
   description: just a test
   echo "Hello,$1"

   mv test /etc/init.d/
   chmod +x /etc/init.d/test
   chkconfig --add test
   service test start        //可以看到Hello,start表示成功

23、写一个脚本,实现批量添加20个用户,用户名为user1-20,密码为user后面跟5个随机字符
#!/bin/bash
for i in {1..20}; do
    pass=$(tr -dc \~\`\[email protected]#\\$\\%\\^\\&\*\-\_\+\=\|\\\?\/\.\>\,\<a-za-z0-9_ <="" dev="" urandom|head="" -c="" 5)
    useradd user${i}
    echo $pass | passwd user${i} --stdin
    echo "user${i} <=============> $pass" >> ./userlist.out
done
echo ‘Sucess,passwd is in userlist.out‘

24、写一个脚本,实现判断192.168.1.0/24网络里,当前在线的IP有哪些,能ping通则认为在线
#!/bin/bash
ips="192.168.1."
for i in {1..254}; do
    ping -W 1 -c 1 ${ips}${i} &>/dev/null && echo "${ips}${i} is up" | tee -a uplog || echo "${ips}${i} is down"
done
echo "Please read uplog to know which host is online. "

 












































































































































以上是关于Linux-基础题的主要内容,如果未能解决你的问题,请参考以下文章

Linux基础知识题解答

Linux基础知识题解答

9道基础Linux运维面试题

linux运维基础题

Linux基础面试题二

linux运维基础题