• NO28 第四关考试题


    第4章 第4周课前测试考试题

    4.1 定时任务规则的含义01

    第1题 如果在某用户的crontab文件中有以下记录,该行中的命令多久执行一次(RHCE考试题)?(  ) 30 4 * * 3 mycmd 

    A. 每小时。 B. 每周。 C. 每年三月中每小时一次。

    解答:每周三的4点30分,执行mycmd。

    4.2 定时任务规则的含义02

    第2题 如果在某用户的crontab文件中有以下记录,该行中的命令多久执行一次(RHCE考试题)?( )*/5 * * * * mycmd 

    A. 每5分钟一次。 B. 每小时过5分钟。 C. 不会运行,格式无效。

    解答:每隔5分钟,执行mycmd。

    4.3 如何书写定时任务

    第3题 每隔1分钟,打印一个+号到oldboy.log,请给出crontab完整命令。

    解答:

    1
    2
    3
    crontab -e 
    * * * * * echo '+' >>oldboy.log
    */1 * * * * echo '+' >>oldboy.log# 等价于上一条命令

    4.4 定时任务:按小时打包文件

    第4题 每隔2个小时将/etc/services文件打包备份到/tmp下(最好每次备份成不同的备份包)。

    解答:

    (1) 命令行测试

    1
    2
    [root@lb01 ~]# cd /etc
    [root@lb01 etc]# tar zcf /tmp/services_bak_`date +%F-%H`.tar.gz ./services

    检查

    1
    2
    3
    4
    [root@lb01 etc]# ll /tmp/services_bak_2016-08-26-23.tar.gz
    -rw-r--r-- 1 root root 127304 2016-08-26 23:21 /tmp/services_bak_2016-08-26-23.tar.gz
    [root@lb01 etc]# du -h /tmp/services_bak_2016-08-26-23.tar.gz
    128K    /tmp/services_bak_2016-08-26-23.tar.gz

    (2) 编写脚本

    1
    2
    3
    4
    5
    [root@lb01 etc]# mkdir /server/scripts -p# 规范脚本路径
    [root@lb01 scripts]# vim /server/scripts/services_bak.sh
    #/bin/sh
    cd /etc && 
    /bin/tar zcf /tmp/services_bak_`date +%F-%H`.tar.gz ./services

    (3) 测试脚本

    1
    2
    3
    [root@lb01 scripts]# /bin/sh /server/scripts/services_bak.sh
    [root@lb01 scripts]# ll /tmp/services_bak_2016-08-26-23.tar.gz 
    -rw-r--r-- 1 root root 127304 2016-08-26 23:28 /tmp/services_bak_2016-08-26-23.tar.gz

    (4) 编辑crontab

    1
    2
    3
    [root@lb01 scripts]# crontab -e
    ## tar file '/etc/services' to /tmp every 2 hours by chendianhu at 2016.6.2 ##
    00 */2 * * * /bin/sh /server/scripts/services_bak.sh >/dev/null 2>&1

    (5) 调试crontab:利用date命令调整时间,最好关闭定时任务的时间同步来做测试

    1
    2
    3
    4
    [root@lb01 scripts]# date -s "20160827 06:00:00"
    Sat Aug 27 06:00:00 CST 2016
    [root@lb01 scripts]# date +%F-%X
    2016-08-27-06:00:01

    4.5 定时任务:打包站点目录

    第5题 每天晚上12点,打包站点目录/var/www/html备份到/data目录下(最好每次备份按时间生成不同的备份包)

    思路:

    (1) 命令行测试

    (2) 编写脚本

    (3) 测试脚本

    (4) 编辑crontab

    (5) 调试crontab

    解答:

    (1) 命令行测试

    1
    2
    3
    4
    5
    6
    [root@lb01 ~]# mkdir -p /var/www/html
    [root@lb01 ~]# touch /var/www/html/stu{1..10}.html
    [root@lb01 ~]# cd /var/www/
    [root@lb01 www]# tar zcf /data/html_bak_`date +%F`.tar.gz ./html 
    [root@lb01 www]# ll /data/html_bak_2016-08-27.tar.gz 
    -rw-r--r-- 1 root root 220 2016-08-27 15:26 /data/html_bak_2016-08-27.tar.gz

    (2) 编写脚本

    1
    2
    3
    4
    5
    [root@lb01 www]# cd /server/scripts/
    [root@lb01 scripts]# vim html_bak.sh
    #/bin/sh
    cd /var/www/ && 
    /bin/tar zcf /data/html_bak_`/bin/date +%F -d "-1day"`.tar.gz ./html

    (3) 测试脚本

    1
    2
    3
    4
    [root@lb01 scripts]# /bin/sh html_bak.sh 
    [root@lb01 scripts]# ll /data/
    总用量 4
    -rw-r--r-- 1 root root 220 2016-08-27 15:48 html_bak_2016-08-26.tar.gz

    (4) 编辑crontab

    1
    2
    3
    [root@lb01 scripts]# crontab -e
    ##tar directory '/var/www/html' to /data at 00 hours every night by chendianhu at 2016.6.2##
    00 00 * * * /bin/sh /server/scripts/html_bak.sh >/dev/null 2>&1

    (5)   调试crontab

    1
    2
    3
    4
    5
    6
    7
    8
    [root@lb01 scripts]# date
    2016年 08月 27日 星期六 15:50:08 CST# 当前日期和时间
    [root@lb01 scripts]# date -s "20160827 23:59:58"
    2016年 08月 27日 星期六 23:59:58 CST# 修改日期和时间
    [root@lb01 scripts]# date
    2016年 08月 28日 星期日 00:00:00 CST# 到达零点
    [root@lb01 scripts]# ll /data/html_bak_2016-08-27.tar.gz # 执行定时任务,打包
    -rw-r--r-- 1 root root 220 2016-08-28 00:00 /data/html_bak_2016-08-27.tar.gz

    4.6 定时任务:提示信息

    第6题 每周六、日上午 9:00 和下午14:00 来老男孩这里学习(执行程序/server/script/oldboy.sh 代替学习)。

    解答:

    (1) 命令行测试

    1
    2
    [root@lb01 scripts]# echo 'go to oldboytaining learning linux'
    go to oldboytaining learning linux

     (2)编写脚本

    1
    2
    3
    [root@lb01 scripts]# vim /server/scripts/oldboy.sh 
    #/bin/sh
    echo 'go to oldboytaining learning linux' >>~/message.txt

    (3) 测试脚本

    1
    2
    3
    [root@lb01 scripts]# /bin/sh /server/scripts/oldboy.sh
    [root@lb01 scripts]# cat ~/message.txt 
    go to oldboytaining learning linux

    (4) 编辑crontab

    1
    2
    3
    [root@lb01 scripts]# crontab -e
    ##print message at every weeken by chendianhu at 2016.6.2##
    00 09,14 * * 0,6 /bin/sh /server/scripts/oldboy.sh >/dev/null 2&>1

    (5) 调试crontab:调整时间

    1
    2
    [root@lb01 scripts]# date -s "20160828 08:59:59"
    [root@lb01 scripts]# cat ~/message.txt

    4.7 目录或文件的作用

    第7题 请描述下列路径的内容是做什么的?

    /etc/sysctl.conf

    /etc/rc.local

    /etc/hosts

    /etc/fstab

    /var/log/secure

    解答:

    文件或目录     作用

    /etc/sysctl.conf 优化系统内核参数的文件

    /etc/rc.local     存放开机自启动程序命令的文件

    /etc/hosts     局域网域名解析文件

    /etc/fstab     开机自动挂载文件

    /var/log/secure     系统安全日志文件,依赖于rsyglog服务

    4.8 正则表达式

    第8题 请说出下列 grep 正则表达式的含义 

    .(点号) 

    {n,m} 

    [^t] 

    ^[^t] 

    解答:

    符号 含义

    ^ 以……开头,比如^w,代表以w开头

    $ 以……结尾,比如w$,代表以w结尾

    .(点号) 代表且只能代表任意一个字符

    转义字符,使有着特殊意义的字符,脱掉马甲,恢复成正常字符

    * 重复0个或多个前面的一个字符,比如:grep -n "a*" oldboy.log

    {n,m} 重复字符n到m次,比如:grep -n "a{3,4}" oldboy.log,重复字符“a”3到4次

    [^t] 匹配不包含^后面的任意一个字符,即除了字符t,其它的全部匹配(过滤出来)

    ^[^t] 匹配以(非字符t)开头的字符

    4.9 vi常用命令

    第9题 根据中文给出命令

    (1) 退出并保存

    (2) 退出并强制保存

    (3) 强制退出,但不保存

    (4) 光标移动到文件的最后一行

    (5) 光标移动到文件的第一行

    (6) 从光标所在位置将光标移动到当前行的开头

    (7) 从光标所在位置将光标移动到当前行的结尾

    (8) 取消上一次的动作

    (9) 删除一行

    (10)   向下搜索

    (11)   向上搜索 

    解答:

    命令         作用

    :wq         退出并保存

    :wq!         退出并强制保存

    :q!         强制退出,但不保存

    Shift+g(G)     光标移动到文件的最后一行

    gg         光标移动到文件的第一行

    Shift+6(^) | home | 0 从光标所在位置将光标移动到当前行的开头

    Shift+4($) | end | Shift+a 从光标所在位置将光标移动到当前行的结尾

    u         取消上一次的动作

    dd         删除一行

    /char         向下搜索,继续搜索n,反向搜索N

    ?char         向上搜索, 继续搜索n,反向搜索N

    扩展:

    命令         功能说明

    i         命令模式==>编辑模式,在光标位置前插入字符

    a         命令模式==>编辑模式,在光标位置后插入字符

    o         命令模式==>编辑模式,在当前行下方插入新的一行,并从行首开始

    Esc         编辑模式==>命令模式

    :set nu         显示行号

    :set nonu     不显示行号

    yy         复制光标当前所在行

    3yy         复制光标当前所在行以及下面2行,即复制3行的内容

    p         粘贴

    10dd         删除光标当前所在行,以及下面的两行

    4.10 chmod命令修改文件权限

    第10题 授权oldboy目录及其子目录755的权限,请给出命令。

    思路:

    利用chmod命令可以修改文件的权限,加-R参数可以递归修改目录下的文件和子目录的文件权限。

    解答:

    1
    2
    3
    4
    [root@oldboy ~]# chmod -R 755 /oldboy/# -R参数:递归
    [root@oldboy ~]# ls -ld /oldboy/ /oldboy/a/# 验证
    drwxr-xr-x. 3 root root 4096 May 11 16:46 /oldboy/
    drwxr-xr-x. 3 root root 4096 May 11 16:46 /oldboy/a/

    总结:

    1
    2
    chmod - change file mode bits#修改文件的权限位
    -R, --recursive  change files and directories recursively

    4.11 chown命令修改文件的属主和属组

    第11题 把oldboy目录及其子目录的属主改为oldboy,组改为root,请给出命令。

    思路:

    利用chown命令可以修改文件的属主和属组,加-R参数可以递归修改目录下的文件和子目录的文件属主和属组信息。

    解答:

    1
    2
    3
    4
    5
    [root@oldboy ~]# chown -R oldboy.root /oldboy/# -R参数:递归
    [root@oldboy ~]# chown -R oldboy:root /oldboy/# 格式【属主:属组 == 属主.属组】
    [root@oldboy ~]# ls -ld /oldboy/ /oldboy/a/# 验证
    drwxr-xr-x. 3 oldboy root 4096 May 11 16:46 /oldboy/
    drwxr-xr-x. 3 oldboy root 4096 May 11 16:46 /oldboy/a/

    总结:

    1
    2
    chown - change file owner and group  
    # 修改文件的属主和属主

    4.12 考查umask的作用

    第12题 描述下umask的作用,并举例。

    解答:

    umask:权限掩码。作用:配置文件的默认权限。

    1. root用户umask值默认为:0022

    新建一个文件时,文件的权限肯定是644(666-022)

    新建一个目录时,目录的权限肯定是755(777-022)

    原因:目录权限755和文件权限644是一个目录或普通文件安全的边界。

    1
    2
    3
    4
    5
    [root@oldboy ~]# touch test.txt# 新建文件
    [root@oldboy ~]# mkdir test# 新建目录
    [root@oldboy ~]# ls -ld test.txt test
    drwxr-xr-x. 2 root root 4096 May 11 17:21 test# 目录默认权限755
    -rw-r--r--. 1 root root 0 May 11 17:20 test.txt# 文件默认权限644

    2. 普通用户umask值默认为:0002

    新建一个文件时,文件的权限肯定是664(666-002)

    新建一个目录时,目录的权限肯定是775(777-002)

    原因:普通用户自己创建的文件,属主和属组权限当然可以给大些。

    1
    2
    3
    4
    5
    [oldboy@oldboy ~]$ touch test.txt# 新建文件
    [oldboy@oldboy ~]$ mkdir test1# 新建目录
    [oldboy@oldboy ~]$ ls -ld test.txt test1
    drwxrwxr-x. 2 oldboy oldboy 4096 May 11 17:15 test1# 目录默认权限775
    -rw-rw-r--. 1 oldboy oldboy    0 May 11 17:15 test.txt# 文件默认权限664

    总结:

    1. umask值是可以改的,但一般不改。

    2. 文件权限的计算方法有奇偶之分,当umask是偶数时,目录就用777-umask,文件就用666-umask;当umask是奇数时,计算方法如下:

    假设umask值为:045(哪个数字位是奇数,就要给这个数字位加1处理)

    6 6 6 ==>文件的起始权限值

    0 4 5  -     ==>umask的值

    -----------------

    6 2 1 ==>由于umask的最后一位数字是5,所以,在其他用户位要再加1

    0 0 1  +

    -----------------

    6 2 2

    3. 目录权限的计算方法无奇偶之分,直接相减即可。

    4.13 考查如何添加用户

    第13题 添加一个用户oldboy,并指定属于sa组,要求组ID为801,uid为808,并且不建立家目录及禁止其登录。

    思路:

    先创建用户的属组,再用useradd命令添加用户。

    解答:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    [root@oldboy ~]# groupadd -g 801 sa# 先添加sa组,-g指定组ID
    [root@oldboy ~]# useradd -g sa -u 808 -M -s /sbin/nologin oldboy
    # -g指定主组,-u指定uid,-M代表不创建家目录,-s指定用户的登录shell
    # -G指定所属的附加组,-m代表创建用户的家目录
    [root@oldboy ~]# tail -1 /etc/passwd# 看是否在用户配置文件中有了新用户的记录
    oldboy:x:808:801::/home/oldboy:/sbin/nologin
    # 可以看到用户的家目录,用户的shell为/sbin/nologin
    [root@oldboy ~]# id oldboy# 看用户的uid,所属组(组uid)
    uid=808(oldboy) gid=801(sa) groups=801(sa)
    [root@oldboy ~]# ls -ld /home/oldboy# 验证是否创建家目录
    ls: cannot access /home/oldboy: No such file or directory

    总结:

    1. 用户的登录shell可以用下面这条命令来查看:

    1
    2
    3
    4
    5
    6
    7
    [root@oldboy ~]# cat /etc/shells 
    /bin/sh
    /bin/bash
    /sbin/nologin
    /bin/dash
    /bin/tcsh
    /bin/csh

    2. id + 用户名:可以看到用户的uid和所属(附加)组的gid

    3. useradd命令的常用参数

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    useradd - create a new user or update default new user information
    -c, --comment COMMENT# 描述信息
    -d, --home HOME_DIR# 指定用户的家目录
    -e, --expiredate EXPIRE_DATE(YYYY-MM-DD)# 指定用户的过期时间
    -g, --gid GROUP# 指定用户的主组
    -G, --groups GROUP1[,GROUP2,...[,GROUPN]]# 指定用户的附加组
    -m, --create-home# 强制创建家目录
    -M  Do not create the user's home directory# 不创建家目录
    -s, --shell SHELL# 指定用户的shell
    -u, --uid UID# 指定用户的UID

    4.14 查看用户的uid和所属组

    第14题 如何查看用户的uid及属于的组信息。

    思路:

    id命令搞定。

    解答:

    1
    2
    3
    4
    5
    [root@oldboy ~]# id oldboy
    uid=808(oldboy) gid=801(sa) groups=801(sa),802(teachers)
    [root@oldboy ~]# grep oldboy /etc/passwd
    oldboy:x:808:801::/home/oldboy:/sbin/nologin
    # uid为808;所属主组为sa,gid为801;所属附加组为teachers,gid为802。

    总结:

    1
    2
    id - print real and effective user and group IDs
    # 打印用户和组的ID信息
  • 相关阅读:
    SpringMVC -- 梗概--源码--贰--下载
    SpringMVC -- 梗概--源码--贰--上传
    SpringMVC -- 梗概--源码--贰--拦截器:Interceptor
    SpringMVC -- 梗概--源码--贰--异常管理
    SpringMVC -- 梗概--源码--贰--RestFul收参(了解) @PathVariable
    SpringMVC -- 梗概--源码--贰--静态资源的访问问题
    SpringMVC -- 梗概--源码--贰--mvc:annotation-driven
    SpringMVC -- 梗概--源码--壹--springMVC json处理
    SpringMVC -- 梗概--源码--壹--数据传递
    spring mvc处理方法返回方式
  • 原文地址:https://www.cnblogs.com/sinsenliu/p/9070741.html
Copyright © 2020-2023  润新知