马哥教育网络班20期+第6周课程练习

1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;

[root@localhost ~]# cp /etc/rc.d/rc.sysinit /tmp
[root@localhost ~]# vim /tmp/rc.sysinit
按Esc进入vim的末行模式,并输入
:%s/^[[:space:]]/#&/g

2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;

[root@localhost ~]# cp /boot/grub/grub.conf /tmp
[root@localhost ~]# vim /tmp/grub.conf
按Esc进入vim的末行模式,并输入
:%s/^[[:space:]]\+//g

3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行的行首的#和空白字符

[root@localhost ~]# vim /tmp/rc.sysinit
按Esc进入vim的末行模式,并输入
:%s/^[[:space:]]\{0,\}#[[:space:]]\+//g

4、为/tmp/grub.conf文件中前三行的行首加#号;

[root@localhost ~]# vim /tmp/grub.conf
按Esc进入vim的末行模式,并输入
:1,+2s/^/#&/g

5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;

[root@localhost ~]# vim /etc/yum.repos.d/CentOS-Media.repo
按Esc进入vim的末行模式
:/enabled=0/s/0/1/g
:/gpgcheck=0/s/0/1/g
或
%s@enabled=0@enabled=1@g
%s@gpgcheck=0@gpgcheck=1@g

6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201504020202

[root@localhost ~]# crontab -e
crontab: installing new crontab
* */4 * * * cp -r /etc/ /backup/etc-`date +%Y%m%d%H%M`
[root@localhost ~]# /etc/init.d/crond start

7、每周2,4,6备份/var/log/messages文件至/backup/messages_logs/目录中,保存的文件名形如messages-20150402

* * * * */2,4,6 cp -r /var/log/messages /backup/messages_logs/messages-`date +%Y%m%d`

8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中

* */2 */1 * * grep "^S" /proc/meminfo >> /stats/memory.txt

9、工作日的工作时间内,每两小时执行一次echo "howdy"

* 9-17/2 * * */1-5 echo "howdy"

脚本编程练习

10、创建目录/tmp/testdir-当前日期时间;

[root@localhost tmp]# vim create.sh
#!/bin/bash
mkdir -pv /tmp/testdir-$(date +%F-%H-%M-%S)
[root@localhost tmp]# bash -n create.sh
[root@localhost tmp]# bash create.sh
mkdir: 已创建目录 "/tmp/testdir-2016-07-13-16-12-37"

11、在此目录创建100个空文件:file1-file100

[root@localhost tmp]# cd /tmp/testdir-2016-07-13-16-12-37/
[root@localhost testdir-2016-07-13-16-12-37]# nano createfile.sh
#!/bin/bash
for i in {1..100};do
    mkdir file$i
done
[root@localhost testdir-2016-07-13-16-12-37]# bash -n createfile.sh
[root@localhost testdir-2016-07-13-16-12-37]# bash createfile.sh
[root@localhost testdir-2016-07-13-16-12-37]# ls
createfile.sh  file19  file3   file40  file51  file62  file73  file84  file95
file1          file2   file30  file41  file52  file63  file74  file85  file96
file10         file20  file31  file42  file53  file64  file75  file86  file97
file100        file21  file32  file43  file54  file65  file76  file87  file98
file11         file22  file33  file44  file55  file66  file77  file88  file99
file12         file23  file34  file45  file56  file67  file78  file89
file13         file24  file35  file46  file57  file68  file79  file9
file14         file25  file36  file47  file58  file69  file8   file90
file15         file26  file37  file48  file59  file7   file80  file91
file16         file27  file38  file49  file6   file70  file81  file92
file17         file28  file39  file5   file60  file71  file82  file93
file18         file29  file4   file50  file61  file72  file83  file94

12、显示/etc/passwd文件中位于第偶数行的用户的用户名;

[root@localhost tmp]# sed -n 'p;n' /etc/passwd | cut -d: -f1

13、创建10用户user10-user19;密码同用户名;

[root@localhost tmp]# vim usercreate.sh
#!/bin/bash
for i in {10..19};do
    if id user$i &>/dev/null;then
    echo "user$i exists."
    else
    useradd user$i
    if [ $? -eq 0 ];then
        echo "user$i" | passwd --stdin user$i &> /dev/null
        echo "Add user$i finished."
    fi
    fi
done
[root@localhost tmp]# bash -n usercreate.sh
[root@localhost tmp]# bash usercreate.sh
Add user10 finished.
Add user11 finished.
Add user12 finished.
Add user13 finished.
Add user14 finished.
Add user15 finished.
Add user16 finished.
Add user17 finished.
Add user18 finished.
Add user19 finished.

14、在/tmp/创建10个空文件file10-file19;

[root@localhost tmp]# vim file.sh
#!/bin/bash
for i in {10..19};do
    mkdir /tmp/file$i
done
[root@localhost tmp]# bash file.sh
[root@localhost tmp]# ls | grep file
file10
file11
file12
file13
file14
file15
file16
file17
file18
file19
file.sh

15、把file10的属主和属组改为user10,依次类推。

[root@localhost tmp]# vim file1.sh
#!/bin/bash
cd /tmp
for i in {10..19};do
    chown user$i:user$i /tmp/file$i
done
[root@localhost tmp]# bash -n file1.sh
[root@localhost tmp]# bash file1.sh
[root@localhost tmp]# ll | grep file
drwxr-xr-x. 2 user10 user10     4096 7月  13 16:38 file10
drwxr-xr-x. 2 user11 user11     4096 7月  13 16:38 file11
drwxr-xr-x. 2 user12 user12     4096 7月  13 16:38 file12
drwxr-xr-x. 2 user13 user13     4096 7月  13 16:38 file13
drwxr-xr-x. 2 user14 user14     4096 7月  13 16:38 file14
drwxr-xr-x. 2 user15 user15     4096 7月  13 16:38 file15
drwxr-xr-x. 2 user16 user16     4096 7月  13 16:38 file16
drwxr-xr-x. 2 user17 user17     4096 7月  13 16:38 file17
drwxr-xr-x. 2 user18 user18     4096 7月  13 16:38 file18
drwxr-xr-x. 2 user19 user19     4096 7月  13 16:38 file19
-rw-r--r--. 1 root   root         77 7月  13 16:47 file1.sh
-rw-r--r--. 1 root   root         77 7月  13 16:46 file.sh

 

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

(0)
二极管二极管
上一篇 2016-07-16 22:29
下一篇 2016-07-16 22:29

相关推荐

  • Linux基础学习总结(三)

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次: [leexide@leeblog ~]$who | cut -d" " -f1 | uniq 2、取出最后登录到当前系统的用户的相关信息。 last -n&nbs…

    Linux干货 2016-10-03
  • 文本处理章练习题

    2017.7.27练习 1、找出ifconfig “网卡名” 命令结果中本机的IPv4地址 ifconfig |head -n 2 |tail -n 1|tr -s ” ” : |cut -d: -f4   2、查出分区空间使用率的最大百分比值 df|tr -s ‘ ‘ %|sort -t% -k5 …

    2017-07-29
  • linux的inode的理解

    一、inode是什么?     理解inode,要从文件储存说起。     文件储存在硬盘上,硬盘的最小存储单位叫做”扇区”(Sector)。每个扇区储存512字节(相当于0.5KB)。     操作系统读取硬盘的时候,不会一个个扇区地读取,这样效率太低,而是一次性连续读取多个扇区,即一次性读取一个”块”(bl…

    Linux笔记 2018-04-01
  • M25 Linux 学习,FHS标准

    FHS FHS(英文:Filesystem Hierarchy Standard 中文:文件系统层次结构标准),多数Linux版本采用这种文件组织形式,FHS定义了系统中每个区域的用途、所需要的最小构成的文件和目录同时还给出了例外处理与矛盾处理。 FHS定义了两层规范,第一层是, / 下面的各个目录应该要放什么文件数据,例如/etc应该要放置设置文件,/bi…

    2017-07-15
  • Tomcat详解

    Tomcat详解 1、tomcat安装 tomcat的组件:<Server> <Service> <connector/> <connector/> <Engine> <Host /> <Host> <Context/> … </Host> &lt…

    2017-04-27
  • 20160804正则表达式作业

    正则表达式表示18位身份证号 正则表达式表示手机号 正则表达式表示邮箱 Ø  截取出ifconfig命令结果中所有的本机的ipv4地址   Ø  查看分区中使用率最大的百分比 Ø  查看UID最大的用户名、UID以及shell类型 Ø  查看/tmp权限,并且以数字方式显示 思路:先找到如何才能查看到/tmp…

    Linux干货 2016-08-08

评论列表(1条)

  • 马哥教育
    马哥教育 2016-07-16 22:35

    写的很好,排版也很漂亮,加油,每天的不要/1,每周的直接写就可以