1. 如何过滤出已知当前目录下oldboy中的所有一级目录?

提示:不包含oldboy目录下面目录的子目录和隐藏目录,只要一级目录即可。

解答:

  • ls -F|grep /   通过ls -F给目录后面加标识,过滤

    • 除了 ls -F加标识外,还可以用 ls -p
  • ls -l|grep '^d'  通过过滤长属性的文件和目录属性标识
  • ls -l|awk '$2!~/1/{print}'   通过判断长属性的第二列(即:硬连接数)不等于1(即大于1)的是目录
    • 不绝对,当文件没有硬连接的时候是对的
  • find . -type d -maxdepth 1  查找目录
  • tree -L 1 -d 只取一级子目录

2. 假如当前目录是/oldboy,现在需要进入到/tmp目录下进行操作,执行的命令为: cd /tmp。操作完毕后,想要快速回到上一次进入的目录,应该如何做?(不能使用 cd /oldboy)

解答:

方法1: “-”表示上一次所在的目录,切换回即可

cd -

原理:环境变量中的OLDPWD会记录上一次的目录。env|grep -i oldpwd

方法2:查看history历史记录命令,找到对应的切换路径的命令,用 !history_command_number,会执行该命令。

[root@oldboy tmp]# history
19 cd /oldboy
20 pwd
21 cd /tmp
22 pwd
23 history
[root@oldboy tmp]# !19
cd /oldboy

3. 一个目录中有很多文件,向快速看到最近最新的文件。如何看?

解答:

文件按照时间顺序排序,倒序正序都可以。

ls -lrt

执行这个命令后,最新的文件会在最下面。

以长格式安装修改时间倒序排序文件和目录,这样最近创建或修改的文件或目录就在窗口最下面了。

4. 在配置apache时,执行了./configure --prefix=/application/apache2.2.17来编译apache,在make install 完成后,希望用户的访问路径更简单,需要给/application/apache2.2.17目录做一个软连接/application/apache2.2.17下的内容,请给出实现的命令。

解答:

ln -s /application/apache2.2.17 /application/apache

5. 已知apache服务的访问日志按天记录在服务器本地目录/app/logs下,由于磁盘空间紧张,现在要求只能保留最近7天访问日志。

解答:

find /app/logs -type f -name "*.log" -mtime +7 -exec rm -f {} \;

6. 调试系统服务时,希望能实时查看系统日志/var/log/messages的更新,如何做

解答:

  • tail -f /var/log/messages
  • taif /var/log/messages
  • tail -F /var/log/messages

注意这三者的区别:

  • tail -f      等同于--follow=descriptor,根据文件描述符进行追踪,当文件改名或被删除,追踪停止
  • tail -F     等同于--follow=name  --retry,根据文件名进行追踪,并保持重试,即该文件被删除或改名后,如果再次创建相同的文件名,会继续追踪
  • tailf        等同于tail -f -n 10(貌似tail -f或-F默认也是打印最后10行,然后追踪文件),与tail -f不同的是,如果文件不增长,它不会去访问磁盘文件,所以tailf特别适合那些便携机上跟踪日志文件,因为它减少了磁盘访问,可以省电。

7. 打印配置文件nginx.conf内容的行号及内容,该如何做?

解答:

  • cat -n nginx.conf
  • nl nginx.conf  nl命令即,number of lines
  • grep -n . nginx.conf (点.表示匹配任意字符,即输出所有内容)
  • vi nginx.conf 命令行模式下 :set nu 查看行号, :set nonu取消行号
  • awk '{print NR,$0}' nginx.conf
  • less -N nginx.conf
  • sed = nginx.conf|sed 'N;s/\n/ /g'
  • sed = nginx.conf|xargs -n2
    • 注意,sed = 的用法,比较少见
[root@oldboy oldboy]# sed = oldboy.txt
1
inet addr:10.0.0.8 Bcast:10.0.0.255 Mask:255.255.255.0

注意,sed = 的“=”前后有空格,否则不会显示出行号和内容。

8. 装完系统后,希望让网络文件共享服务NFS,仅在 3 级别上开机自启动,该如何做?

解答:

方法1:把要启动的服务放在/etc/rc.local里。

### [root@oldboy ~]# vi /etc/rc.local

在文件中添加内容:
# sshd service startup scripts
/etc/init.d/sshd start

方法2:chkconfig --list,查看所有运行的服务以及对应的运行级别。

chkconfig --list nfs

chkconfig nfs off # 全部关闭服务

chkconfig --level 3 nfs on  # 在3运行级别上设置开机自启动

9. Linux系统运行级别一般为0-6,请写出每个级别的含义。

  • 0 关机
  • 1 单用户命令行模式
  • 2 无网络的多用户
  • 3 正常的文本模式下的多用户
  • 4 unused
  • 5 桌面系统模式
  • 6 重启
[root@oldboy etc]# tail /etc/inittab
# Default runlevel. The runlevels used are:
# 0 - halt (Do NOT set initdefault to this)
# 1 - Single user mode
# 2 - Multiuser, without NFS (The same as 3, if you do not have networking)
# 3 - Full multiuser mode
# 4 - unused
# 5 - X11
# 6 - reboot (Do NOT set initdefault to this)
#
id:3:initdefault:

10. Linux系统中查看中文乱码,请问如何解决乱码问题?

解答:

LANG 这个 环境变量 就是控制字符显示的。

  • 临时修改LANG  export LANG='zh_CN.UTF-8'
  • 修改/etc/sysconfig/i18n这个配置文件,永久生效。
[root@oldboy oldboy]# echo 'LANG="zh_CN.UTF-8"'>/etc/sysconfig/i18n
[root@oldboy oldboy]# source /etc/sysconfig/i18n # 如需让配置立即生效需要执行此步。
[root@oldboy oldboy]# echo $LANG
zh_CN.UTF-8

11. 如何优化Linux系统?

  1. 不用root,添加普通用户,通过sudo授权管理
  2. 更改默认的远程连接SSH服务器端口及禁止root用户远程连接
  3. 定时自动更新服务器时间
  4. 配置yum更新源,从国内更新源下载安装rpm包
  5. 关闭selinux及iptables(iptables工作场景如果有 wan ip 一般要打开,高并发除外)
  6. 调整文件描述符的数量,进程及文件的打开都会消耗文件描述符
  7. 定时自动清理/var/spool/clientmqueue/目录垃圾文件,防止 inodes 节点被占满(c6.4默认没有sendmail,因此,可以不配)
  8. 精简开机自启动服务(crond,sshd,network,rsyslog(c5.8 syslog))
  9. Linux内核参数优化/etc/sysctl.conf,执行sysctl -p生效
  10. 更改字符集,支持中文,但还是建议用英文字符集,防止乱码问题,不要使用中文
  11. 锁定关键系统文件 chattr +i /etc/passwd /etc/shadow /etc/group /etc/gshadow /etc/inittab 处理以上内容后,把chattr, lsattr改名为oldboy,这样就安全多了
  12. 清空/etc/issue,去除系统及内核版本登录前的屏幕显示
  13. 清空无用的默认系统账户或组(非必须)。

12. 如何查看/etc/services文件有多少行?

解答:

  • wc -l /etc/services
  • cat -n /etc/services|tail -1

13. /etc/目录为Linux系统的默认配置文件及服务启动命令的目录

  • 请用tar打包/etc/整个目录(打包及压缩)
  • 请用tar打包/etc/整个目录(打包及压缩,但需要排除/etc/services文件)
  • 请把第一个打包好的文件,解压到/tmp的指定目录下

解答:

  • 请用tar打包/etc/整个目录(打包及压缩)

    • tar zcf /tmp/etc.tar.gz /etc/
  • 请用tar打包/etc/整个目录(打包及压缩,但需要排除/etc/services文件)
    • tar zcf /tmp/etc.tar.gz /etc/ --exclude=/etc/services
  • 请把第一个打包好的文件,解压到/tmp的指定目录下
    • tar zxf /tmp/etc.tar.gz /tmp/etc/

14. 现有文件内容如下,需要从文件中过滤出“oldboy”和“1234567890”的字符串。

[root@oldboy oldboy]# cat oldboy.txt
I am oldboy, mysqq is 1234567890

解答:

主要是活用awk,grep,sed,cut等多种文本处理

[root@oldboy oldboy]# cat oldboy.txt|cut -d" " -f 6,3|sed 's#,##g'
oldboy 1234567890 [root@oldboy oldboy]# grep -oE '(oldboy)|[0-9]+' oldboy.txt
oldboy
1234567890 [root@oldboy oldboy]# egrep -o '(oldboy)|[0-9]+' oldboy.txt
oldboy
1234567890 [root@oldboy oldboy]# awk -F "[ ,]+" '{print $3,$NF}' oldboy.txt
oldboy 1234567890 [root@oldboy oldboy]# sed -nr 's#^.*(oldboy).*([0-9]{10,})$#\1 \2#gp' oldboy.txt
oldboy 1234567890

15. 过滤出/etc/services 文件包含3306或1521两数据库端口的行的内容。

解答:

[root@oldboy oldboy]# cat /etc/services|grep -E '3306|1521'
mysql 3306/tcp # MySQL
mysql 3306/udp # MySQL
ncube-lm 1521/tcp # nCube License Manager
ncube-lm 1521/udp # nCube License Manager [root@oldboy oldboy]# egrep '3306|1521' /etc/services
mysql 3306/tcp # MySQL
mysql 3306/udp # MySQL
ncube-lm 1521/tcp # nCube License Manager
ncube-lm 1521/udp # nCube License Manager [root@oldboy oldboy]# awk '/3306|1521/{print }' /etc/services
mysql 3306/tcp # MySQL
mysql 3306/udp # MySQL
ncube-lm 1521/tcp # nCube License Manager
ncube-lm 1521/udp # nCube License Manager [root@oldboy oldboy]# sed -nr '/3306|1521/p' /etc/services
mysql 3306/tcp # MySQL
mysql 3306/udp # MySQL
ncube-lm 1521/tcp # nCube License Manager
ncube-lm 1521/udp # nCube License Manager

【Linux题目】第四关的更多相关文章

  1. 【linux题目】第一关

    详细的解答:https://github.com/Zoe233/Linux/blob/master/[题目]5.Linux了解程度测试题解析.ipynb 1. 创建一个目录/data 解答: mkdi ...

  2. 【Linux题目】第九关

    前言:项目整合 企业项目实战考试: 1. 全网备份解决方案实战 2. NFS集群后段共享存储搭建优化 3. 解决NFS单点实现实时数据同步. 环境: 服务器角色 外网ip 内网ip 主机名 web 1 ...

  3. 【linux题目】第二关

    1.创建目录/data/oldboy,并且在该目录下创建文件oldboy.txt,然后在文件oldboy.txt里写入内容”inet addr:10.0.0.8 Bcast:10.0.0.255 Ma ...

  4. Linux 兴趣小组2016免试题 第四关揭秘

    Linux 兴趣小组2016免试题 点这里 首先贴出第四关链接Linux 兴趣小组2016免试题 第四关 第四关: 进入网址我们看到的是4张扑克牌K,这是什么意思? 要我斗地主?好了,还是乖乖的先查看 ...

  5. 20145233 2016-2017 1 linux题目总结

    20145233 2016-2017 1 linux题目总结 第一周考试知识汇总 判断:实验楼环境中所有的默认系统用户名和密码均为 shiyanlou.(x ). 填空:Linux Bash中,Ctr ...

  6. Linux设备管理(四)_从sysfs回到ktype

    sysfs是一个基于ramfs的文件系统,在2.6内核开始引入,用来导出内核对象(kernel object)的数据.属性到用户空间.与同样用于查看内核数据的proc不同,sysfs只关心具有层次结构 ...

  7. linux安装IPython四种方法

    IPython是Python的交互式Shell,提供了代码自动补完,自动缩进,高亮显示,执行Shell命令等非常有用的特性.特别是它的代码补完功能,例如:在输入zlib.之后按下Tab键,IPytho ...

  8. Python:黑板课爬虫闯关第四关

    第四关地址:http://www.heibanke.com/lesson/crawler_ex03/ 一开始看到的时候有点蒙,不知道啥意思,说密码需要找出来但也没说怎么找啊. 别急,随便输了个昵称和密 ...

  9. SQL注入之Sqli-labs系列第四十一关(基于堆叠注入的盲注)和四十二关四十三关四十四关四十五关

    0x1普通测试方式 (1)输入and1=1和and1=2测试,返回错误,证明存在注入 (2)union select联合查询 (3)查询表名 (4)其他 payload: ,( ,( 0x2 堆叠注入 ...

  10. SQL注入之Sqli-labs系列第三十四关(基于宽字符逃逸POST注入)和三十五关

    开始挑战第三十四关和第三十五关(Bypass add addslashes) 0x1查看源码 本关是post型的注入漏洞,同样的也是将post过来的内容进行了 ' \ 的处理. if(isset($_ ...

随机推荐

  1. 想读Spring源码?先从这篇「 极简教程」开始吧...

    为什么要阅读源码?这是一个有趣的问题,类似的问题还有,为什么要看书?为什么要爬山? 这也是一个哲学问题,我想每个人都有不同的答案,下面我是对阅读源码好处的一些思考. (PS:也欢迎你在评论区留言补充) ...

  2. 自动下载bing当日墙纸,并改变为gnome桌面壁纸

    写了一个手动白嫖当时bing的当日壁纸,并将其改变为gnome的壁纸,还是学到蛮多东东的 下一步的问题是加入到开机自启动项,使得开机后可以自动更新,目前已看到几篇博客 当然,也写了一个脚本使得可以恢复 ...

  3. Nginx知多少系列之(五)Linux下托管.NET Core项目

    目录 1.前言 2.安装 3.配置文件详解 4.Linux下托管.NET Core项目 5.Linux下.NET Core项目负载均衡 6.Linux下.NET Core项目Nginx+Keepali ...

  4. RHCS概述

    RHCS概述 创建RHCS集群环境 创建高可用Apache服务 1 创建RHCS集群环境 1.1 问题 准备四台KVM虚拟机,其三台作为集群节点,一台安装luci并配置iSCSI存储服务,实现如下功能 ...

  5. Cacti监控服务

    Cacti监控服务 案例1:部署Cacti监控平台 案例2:构建Cacti监测系统 1 案例1:部署Cacti监控平台 1.1 问题 本案例要求部署一台Cacti监控主机,并安装相关监控组件,为进一步 ...

  6. 基于 HTML5 WebGL 的 水泥工厂可视化系统

    前言 如今的制造行业,基于数据进行生产策略制定与管理已经成为一种趋势,特别是 工业4.0 的浪潮下,数据战略已经成为很多制造企业的优先战略,而数据可视化以更直观的方式,帮助指导决策,成为数据分析传递信 ...

  7. 微信小程序动态修改页面标题setNavigationBarTitle

    微信小程序是可以动态修改页面标题的. 首先我们来看看静态是怎么实现的 在对应页面的json文件里面加入下面代码就可以实现了 { "navigationBarTitleText": ...

  8. 计算机网络协议,IPV4数据报分析

    一.IP数据报结构分析 1.整体结构 一个IP数据报由首部和数据两部分组成. 首部的前一部分固定长20字节,这是所有IP数据报必须具有的:在首部的固定部分后面是一些可选字段,其长度是可变的. IP数据 ...

  9. 37.3 net--TcpDemo1 大小写转换

    需求:使用TCP协议发送数据,并将接收到的数据转换成大写返回 启动方式:先打开服务端,再打开客户端 客户端 package day35_net_网络编程.tcp传输; import java.io.I ...

  10. SQL基础系列(1)-基本语法--转载w3school

    1.    建原始表 USE [Northwind] GO /****** Object:  Table [dbo].[Persons]    Script Date: 2016/6/8 7:31:5 ...