Linux基础学习总结(六)

一、完成如下练习
1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;
vim:
  1. cp /etc/rc.sysinit /tmp/rc.sysinit
  2. vim/tmp/rc.sysinit
  3. :%s@^[[:space:]]\+@#&@g
sed:
  1. sed "s/\(^ \)/#\1/g" /tmp/rc.sysinit > tmp
  2. cat tmp > /tmp/rc.sysinit
2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;
  1. cp /boot/grub/grub.conf /tmp/
  2. vim /tmp/grub.conf
  3. :%s@^[[:space:]]\+@@g
3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行行的#和空白字符
  1. vim/tmp/rc.sysinit
  2. :%s@^#[[:space:]]\+@@g
4、为/tmp/grub.conf文件中前三行的行首加#号;
vim编辑器
  1. :1,3s/^/#&/
5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;
vim编辑器
  1. :%s@\(enabled\|gpgcheck\)=0@\1=1@g
6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201504020202
  1. 0 */4 * * * cp -r /etc/ /tmp/backup/etc-$(date +%Y%m%d%H%M)
7、每周2,4,6备份/var/log/messages文件至/backup/messages_logs/目录中,保存的文件名形如messages-20150402
  1. 0 0 * * 2,4,6 cp -r /var/log/messages /backup/messages_logs/messages-$(date +%Y%m%d)
8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中
  1. 0 */2 * * * cat /proc/meminfo |grep "^S" >> /starts/menory.txt
9、工作日的工作时间内,每两小时执行一次echo “howdy”
  1. 0 9-18/2 * * 1,2,3,4,5 echo "howdy"
二、脚本编程练习
10、创建目录/tmp/testdir-当前日期时间; 
  1. mkdir -p /tmp/testdir-$(date +%F)
11、在此目录创建100个空文件:file1-file100
  1. #!/bin/bash
  2. cd /tmp
  3. for i in $(seq 1 100);do
  4. touch file-$i
  5. done
12、显示/etc/passwd文件中位于第偶数行的用户的用户名;
命令实现:
  1. sed -n 'n;p' /etc/passwd |awk -F: '{print $1}'
脚本实现:
  1. #!/bin/bash
  2. declare -i i=0;
  3. cat /etc/passwd | while read -r line; do
  4. if [ $[ $i%2 ] == 0 ]; then
  5. echo $(echo $line | cut -d":" -f1);
  6. fi
  7. i=$i+1;
  8. done
13、创建10用户user10-user19;密码同用户名;
  1. #!/bin/bash
  2. for i in {10..19};do
  3. useradd user$i && echo "创建user$i用户成功"|passwd --stdin user$1 &> /dev/null
  4. done
14、在/tmp/创建10个空文件file10-file19; 
  1. #!/bin/bash
  2. for i in {10..19};do
  3. touch /tmp/file$i &> /dev/null
  4. done
15、把file10的属主和属组改为user10,依次类推。
  1. #!/bin/bash
  2. for i in {10..19};do
  3. chown user$i user$i /tmp/file$i &> /dev/null
  4. done

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

(0)
LeexideLeexide
上一篇 2016-10-30
下一篇 2016-10-30

相关推荐

  • Keepalived介绍 , 配置说明 , 及实际应用

    1. Keepalived介绍 Keepalived是一个基于VRRP协议来实现的服务高可用方案,可以利用其来避免IP单点故障,类似的工具还有heartbeat、corosync、pacemaker。但是它一般不会单独出现,而是与其它负载均衡技术(如lvs、haproxy、nginx)一起工作来达到集群的高可用。 1.1 VRRP协议 VRRP全称 Virt…

    Linux干货 2016-11-04
  • ​20151208完成了第二天课程中的第一课:Osey Linux发行版(01)

    完成了第二天课程中的第一课:Osey Linux发行版(01) 今天公司晚上有加班,回来晚了。只完成了第一课:Osey Linux发行版(01) 简要笔记如下: Linux哲学思想:    1、一切皆文件:             把几乎所有的资源,包括硬件设备都组织为文件格式;…

    Linux干货 2015-12-10
  • MongoDB复制集及数据分片详解

    前言 MongoDB是一个由C++语言编写的基于分布式文件存储的数据库,是当前NoSQL数据库中比较热门的一种,旨在为Web应用提供可扩展的高性能数据存储解决方案。本文介绍MongoDB复制集及数据分片。 MongoDB 简介 MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。支持的数据结构非常松散,…

    Linux干货 2015-07-15
  • 网络相关命令

    网络相关命令 常用命令 ifcfg家族:   ifconfig:配置IP,NETMASK   route :路由   netstat : 状态及统计数据查看 iproute2家族     ip  系列 &nbs…

    Linux干货 2016-09-07
  • httpd 基础

      http(1) 开启httpd服务,注意selinux 和防火墙设置。出现错误查看系统日志和http错误日志。 进程间通信:IPC socket:套接字 IP:PORT Client <–> Server     Server: listen  &nb…

    Linux干货 2016-11-01
  • httpd服务

             练习:        (1)基于主机名实现三个虚拟主机              …

    Linux干货 2016-11-11