Linux基础知识(六)

本问主要讲述Linux的基础知识,具体包一下内容:

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

cp /etc/rc.d/rc.sysinit /tmp
sed "s/^[[:space:]]\?/#/g" /tmp/rc.sysinit

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

cp /boot/grub/grub.conf /tmp
sed "s/^[[:space:]]//g" /tmp/grub.conf

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

 sed "s/^#[[:space:]]\+//g" /tmp/rc.sysinit 

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

 sed "1.3s/.*/#/" /tmp/grub.conf

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

sed -i "s/(enabled\|gpgcheck)=0/\1=1/g" /etc/repos.d/CentOS-Media.repo 

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

mkdir /backup

crontab -e:

* */4 * * * cp /etc/* /backup/etc\-$(date +"%Y%m%d%H%M" )

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

crontab -e

0 0 * * 2,4,6 cp /var/log/message /backup/message_logs/message\-$(date +"%Y%m%d") 

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

crontab -e 
* */2 * */1 * grep -i -o "^s" /proc/meminfo >>/status/memory.txt

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

crontab -e

* */2 * 1,2,3,4,5 * echo "howdy"

脚本编程练习

10、创建目录/tmp/testdir-当前日期时间; 在此目录创建100个空文件:file1-file100

#!/bin/bash
#author:BaoZhang
#
DIR=/tmp/testdir\-$(date +"%Y%m%d") 
mkdir -p $DIR
if [ $? -eq 0 ];then
  for i in {1..100};
    do
       touch $DIR/file$i
       if [ #? -eq o ];then
         echo "$DIR/file$i create finished"
       else
         echo "the file create failed" #其余文件继续创建,不退出
         
    done
echo "all file create finished"
else
    echo "the girector create failed"
    exit 2
fi

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

#!/bin/bash
#author:BaoZhang
#
echo "all user name  "
awk "NR%2==0" /etc/passwd | cut -d":" -f1

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

#!/bin/bash
if [ $UID -eq 0 ];then #只有root可以创建用户
  for i in {1..10};
  do
    useradd user$i &>/dev/null
    if [ $? -eq 0 ];then
      echo user$i|passwd --stdin &>/dev/null
      if [ $? -eq 0 ];then
        echo " $user$i password add  finished"
      else
        echo "$user$i password add failed"
      fi
    else
       echo "$user$i add filed "
    fi
   done
fi

14、在/tmp/创建10个空文件file10-file19;把file10的属主和属组改为user10,依次类推。

#!/bin/bash
#author BaoZhang
#
if [ $UID -eq 0 ];then
  DIR=/tmp
  cd $DIR
  for i in {10..19};
  do
    touch file$i
    if [ $? -eq 0 ];then
      echo "file$i create finished"
      chown user$i:user$i file$i
    else
      echo "file$i create failed"
    fi
else
  echo "only root can change the file owner"
  exit 1
fi

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

(0)
zhangbaozhangbao
上一篇 2016-10-30 09:54
下一篇 2016-10-30 11:00

相关推荐

  • N25-第三周作业

    1.列出当前系统所有已经登录的用户的用户名,注意同一个用户登录多次,只显示一次即可   who | cut -d" " -f1 |uniq 2.取出最后登录到当前系统的用户的相关信息    w | tail -1 3.取出当前系统上被用户当做其默认shell最多的那个shell &nbsp…

    Linux干货 2016-12-19
  • LVS类型及其调度算法

    LVS类型:     NAT:–>(DNAT) (多目标的DNAT)     DR:     TUN:     FULLNAT: LVS NAT的特性  &nbs…

    Linux干货 2016-10-29
  • LVS常见的类型实现方式

    前言  由于lvs的基础知识已经在第一篇lvs中讲解了,所以在这里只做实验,包括lvs-nat,lvs-dr,以及基于Freiwall标记和实现会话绑定实验。 一、lvs-nat:也是MASQERADING,简称为m(masquerading)    实验图:     地址规划:     …

    Linux干货 2015-06-29
  • 马哥linux第一周学习笔记

    计算机组成 Linux基本命令

    Linux干货 2017-12-17
  • LINUX初次见面

    LINUX的文件系统 在Linux的眼睛中,一切都为文件,这也是Linux的中心哲学思想。正因如此造就了一个性能稳定,功能强大,效率高的操作系统。Linux有自己的层级标准,它定义了每个系统分区的用途,和所需要的最小构成文件目录。由不同的文件来完成不同的功能造就了一个Linux的完整生态。 linux的文件系统格式比较丰富,它的核心系统能支持十多种文件系统类…

    2017-05-18
  • bash(awk递归)N阶【斐波那契数列】多种实现(含递归解析图)

    【版权所有】转载请说明作者【Jev Tes】        【本文导航】        零、关于斐波那契数列        一、输入参数合法性判断       &nbsp…

    Linux干货 2016-11-24