您的位置:首页 > 运维架构 > Linux

马哥2016全新Linux+Python高端运维班第六周作业

2016-09-12 23:38 555 查看
1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;
cp /etc/rc.d/rc.sysinit /tmp
vi /tmp/rc.sysinit
:%s/^[[:space:]]\+/#&/g
s替换、&引用前面查找到的整个内容、g全文操作
sed -i 's/^[[:space]]\+/#&/g' /tmp/rc.sysinit

2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;
cp /boot/grub/grub.conf /tmp
vi /tmp/grub.conf
:%s/^[[:space:]]\+//
sed -i 's/^[[:space:]]\+//g' /tmp/grub.conf

3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行行的#和空白字符
vi /tmp/rc.sysinit
:%s/^#[[:space:]]\+//
sed -i 's/^[[:space:]]\+//g' /tmp/rc.sysinit

4、为/tmp/grub.conf文件中前三行的行首加#号;
vi /tmp/grub.conf
:1,3s/^/&#/g
sed -i '1,3s/^/&#/g' /tmp/grub.conf

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


6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201608300202
mkdir /backup
mkdir /myshell
vi /myshell/etcbackup4.sh
cd /
tar zcf /backup/etc-`date +/%Y/%m/%n/%H/%M` ./etc
crontab -e
0 */4 * * * /myshell/etcbackup4.sh > /dev/null 2> &1


7、每周2,4,6备份/var/log/messages文件至/backup/messages_logs/目录中,保存的文件名形如messages-20160830
crontab -e
* * * * * 2,4,6 /bin/cp /var/log/messages /backup/messages_logs/messages-`date +%Y%m%d`


8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中
mkdir /stats
touch memory.txt
crontab -e
* */2 * * *  grep "^S" /proc/meminfo >> /stats/memory.txt


9、工作日的工作时间内,每两小时执行一次echo "howdy"
crontab -e
* 9-17/2 * * 1-5  echo "howdy"


脚本编程练习
10、创建目录/tmp/testdir-当前日期时间;
11、在此目录创建100个空文件:file1-file100
#!/bin/bash

testdir1=testdir-`date +%Y%m%d`
mkdir -p /tmp/$testdir1

#

for i in `seq 1 100`; do
# for i in {1..100}; do
touch /tmp/$testdir1/file$i;
if [ $? -eq 0 ]; then
echo "Creat file$i success."
fi
done

#
sed -n 'n;p' /etc/passwd | cut -d: -f1







12、显示/etc/passwd文件中位于第偶数行的用户的用户名;
sed -n 'n;p' /etc/passwd | cut -d: -f1
sed -n '2-2p' /etc/passwd
偶数行-n,仅显示脚本处理后的结果
# sed -n 'p;n' /etc/passwd | cut -d: -f1
#sed -n '1-2p' /etc/passwd
奇数行
n:读取下一行,用下一个命令执行;p:打印

13、创建10用户user10-user19;密码同用户名;
14、在/tmp/创建10个空文件file10-file19;
15、把file10的属主和属组改为user10,依次类推。
#!/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 success."
fi
fi
touch /tmp/file$i
chown user$i:user$i /tmp/file$i
#创建文件不需要进行判断

done


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息