Chinaunix首页 | 论坛 | 博客
  • 博客访问: 384052
  • 博文数量: 114
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1219
  • 用 户 组: 普通用户
  • 注册时间: 2015-02-07 21:23
文章分类

全部博文(114)

文章存档

2018年(1)

2017年(5)

2016年(87)

2015年(21)

我的朋友

分类: 系统运维

2017-03-12 22:25:49


  1. 1、用shell脚本批量建立Linux用户
  2. 实现要求:创建用户student1到student50,指定组为student组!而且每个用户需要设定一个不同的密码!
  3. 脚本实现如下:
  4. #!/bin/bash
  5. for i in `seq 1 50`
  6. do
  7.     useradd -G student student$i ; 
  8.     echo student$i | passwd student$i --stdin;
  9. done
  10.  
  11. 【说明:Linux下 Passwd有参数

  12.   --stdin

  13.   This option is used to indicate that passwd should read the new password from standard input, which can be a pipe.

  14.   所以linux下自动改变用户密码的办法就是:

  15.   Echo 密码 |passwd –stdin 用户名

  16. -------------------设置相同的密码------------------------

  17. #!/bin/bash
  18. password="123456"
  19. for USER in user1 user2 user3
  20. do
  21.      useradd -m $USER
  22.      echo -e "${password}\n${password}" | passwd $USER
  23. done
  24.  【说明:
  25.      echo -n 不换行输出:
  26. $echo -n "123"
  27. $echo "456"
  28. 最终输出 
  29. 123456
  30. 而不是
  31. 123
  32. 456
  33.     echo -e 处理特殊字符:
  34.         \n 换行且光标移至行首 】 

  35. ok,就这么一个简单的脚本,就可以再系统里批量生成账号了。而且密码跟账号的名字一样。
  36. 这就是for do done语句用法。

  37. 2、 编写shell脚本,将/usr/local/test目录下大于100k的文件转移到/tmp目录下:

  38. #!/bin/bash

  39. for FILE in `ls /usr/local/test`
  40. do
  41.     if [ -f $FILE ] ; then
  42.         if [ `ls -l  $FILE | awk `{print $5}` -gt 100000 ] ; then
  43.             mv $FILE  /tmp/
  44.         fi
  45.     fi
  46. done

  47. ================

  48. #!/bin/bash
  49. for FileName in `ls -l  /usr/local/test | awk '$5>102400' {print $9}`
  50. do
  51.         mv $FileName  /tmp/
  52. done
  53. ls -al  /tmp/
  54. echo  "done!"


  55. 3、通过apache访问日志access.log 统计IP和每个地址访问的次数,按访问量列出前10名。
  56.      日志格式样例如下:
  57.      192.168.1.247  ---【02/jul/2010:23:44:59 + 8080 】 "GET /HTTP/1/1"   200 19

  58.      答案:
  59.          cat  access.log | awk '{print  $1}' |sort| uniq -c |sort -rn |head -10
  60.  (uniq 参数说明:– c 显示输出中,在每行行首加上本行在文件中连续出现的次数。
  61.      sort参数说明:sort默认的排序方式是升序,-r 参数就会改变成倒叙;你有没有遇到过10比2小的情况。我反正遇到过。
  62.                              出现这种情况是由于排序程序将这些数字按字符来排序了,排序程序会先比较1和2,显然1小,所以就将
  63.                             10放在2前面喽。这也是sort的一贯作风。)

  64. 4、一台监控主机,一台被监控主机。被监控主机分区使用率大于80%,就发告警邮件。放到crontab里面,每10分钟执行一次。
  65.         a、 首先两台机器要建立服务器间的信任关系。
  66.         b、脚本:
  67.               #!/bin/bash
  68.               
  69.                 FSMAX="80"
  70.                 remote_user='root'
  71.                 remote_ip=(IP地址列表)
  72.                  ip_num='0'
  73.                 while [ "$ip_num" -le "$(expr ${#remote_ip[@]} -l)"]
  74.                 do
  75.                         read_num='1'
  76.                         ssh "$remote_user"@"${remote_ip[$ip_num]}"  df -h > /tmp/diskcheck_tmp
  77.                         grep '^/dev/*'  /tmp/diskcheck_tmp | awk '{print $5}'|sed 's/\%//g'  > /tmp/diskcheck_num_tmp
  78.                    

  79.                             while [ "$read_num" -le $(wc -l < /tmp/diskcheck_num_tmp) ]
  80.                             do
  81.                                     size=$(sed -n "$read_num" 'p'  /tmp/diskcheck_num_tmp)
  82.                                             if [ "size" -gt "$FSMAX" ]
  83.                                             then
  84.                                                     $(grep '^/dev/*'  /tmp/diskcheck_tmp |sed -n $read_num'p'  > /tmp/disk_check_mail)
  85.                                                     $(echo ${remote_ip[$ip_num]}) >> /tmp/disk_check_mail)
  86.                                                     $(mail  -s "diskcheck_alert"  admin  <  /tmp/disk_check_mail)
  87.                                             fi
  88.                                     read_num=$(expr  $read_num + 1)
  89.                             done
  90.                         ip_num=$(expr  $ip_num + 1)
  91.               done
  92.               ===================写入crontab=====================
  93.                 0/10 * * * *   /home/diskcheck.sh   2&>1

  94. 5、监控主机的磁盘空间,当使用空间超过90%就通过发mail来发警告
  95. #!/bin/bash
  96. #monitor available disk space

  97. #提取本服务器的IP地址信息  
  98. IP=`ifconfig eth0 | grep "inet addr" | cut -f 2 -":" | cut -f 1 -" "`    

  99. SPACE=` df -hP | awk '{print int($5)}'`
  100. if [ $SPACE -ge 90 ]
  101. then
  102.   echo "$IP 服务器 磁盘空间 使用率已经超过90%,请及时处理。"|mail -"$IP 服务器硬盘告警"   fty89@163.com
  103. fi


  104. 6、自动ftp上传
  105.      
  106.    #! /bin/bash
  107.     ftp -n << END_FTP
  108.     open 192.168.1.22
  109.     user  test testing      //用户名test  密码:testing
  110.     binary
  111.     prompt  off    //关闭提示
  112.     mput   files     //上传files文件
  113.     close
  114.     bye
  115.     END_FTP

  116. 6、编写shell脚本,获取本机的网络地址。比如:本机的ip地址是:
  117. 192.168.100.5/255.255.255.0,
  118. 那么他的网络地址是:
  119. 192.168.100.1/255.255.255.0
  120. 方法一:
  121. #!/bin/bash
  122. IP=ifconfig eth0|grep 'inet addr'|sed 's/^.*addr://g'|awk  '{print $1}'
  123.  NETMASK=ifconfig eth0 |grep "inet addr"|sed 's/^.*Mask://g'
  124. echo "$IP/&NETMASK"
  125. exit

  126. 方法二:
  127. #!/bin/bash
  128.  #This script print ip and network
  129.  file="/etc/sysconfig/network-scripts/ifcfg-eth0"
  130.  if [ -f $file ] ;then
  131.      IP=`grep "IPADDR" $file|awk -F"=" '{ print $2 }'`
  132.      MASK=`grep "NETMASK" $file|awk -F"=" '{ print $2 }'`
  133.  echo "$IP/$MASK"
  134.  exit 1
  135.  fi

  136. IP地址也可这样获取:IP=`ifconfig eth0 | grep "inet addr" | cut -f 2 -":" | cut -f 1 -" "
  137. 子网掩码:NETMASK= `ifconfig eth0 | grep "inet addr"|cut -f 4 -d ":"

  138.  7、某系统管理员需要每天做一定的重复工作,编制一个解决方案:
  139. (1).从下午4:50 删除/abc 目录下的全部子目录和全部文件;
  140. (2).从早上8:00~下午6:00 每小时读取/xyz 目录下x1 文件中每行第一个域的全部数
  141. 据加入到/backup 目录下的back01.txt 文件内;
  142. (3).每逢周一下午5:50 将/data 目录下的所有目录和文件归档并压缩为文件
  143. backup.tar.gz;
  144. (4).在下午5:55 将IDE 接口的CD-ROM 缷载(假设CD-ROM 的设备名为hdc);
  145. (5).在早上8:00 前开机后启动。

  146. (a)用vi创建编辑一个名为prgx的crontab文件;
  147. (b)prgx文件的内容:
  148.             50 16 * * * rm -r /abc/*
  149.             0 8-18/1 * * * cut -f1 /xyz/x1 >>  /backup/bak01.txt
  150.             50 17 * * * tar zcvf backup.tar.gz /data
  151.             55 17 * * * umount /dev/hdc
  152. (c)由超级用户登录,用crontab执行 prgx文件中的内容:
  153.             root@xxx:#crontab prgx;在每日早晨8:00之前开机后即可自动启动crontab

  154. 8.设计一个shell程序,添加一个新组为class1,然后添加属于这个组的30个用户,用户名的形式为stdxx,其中xx从01到30
  155.  
  156. 参考答案:
  157.  
  158. #!/bin/sh
  159.  
  160. i=1
  161.  
  162. groupadd class1
  163.  
  164. while [ $i -le 30 ]
  165.  
  166. do
  167.  
  168. if [ $i -le 9 ] ;then
  169.  
  170. USERNAME=stu0${i}
  171.  
  172. else
  173.  
  174. USERNAME=stu${i}
  175.  
  176. fi
  177.  
  178. useradd $USERNAME
  179.  
  180. mkdir /home/$USERNAME
  181.  
  182. chown -R $USERNAME /home/$USERNAME
  183.  
  184. chgrp -R class1 /home/$USERNAME
  185.  
  186. i=$(($i+1))
  187.  
  188. done
  189.  
  190. 9.编写shell程序,实现自动删除50个账号的功能。账号名为stud1至stud50。
  191.  
  192. 参考程序:
  193.  
  194. #!/bin/sh
  195.  
  196. i=1
  197.  
  198. while [ $i -le 50 ]
  199.  
  200. do
  201.  
  202. userdel -r stud${i}
  203.  
  204. i=$(($i+1 ))
  205.  
  206. done
  207.  
  208. 10.设计一个shell程序,在每月第一天备份并压缩/etc目录的所有内容,存放在/root/bak目录里,且文件名为如下形式yymmdd_etc,yy为年,mm为月,dd为日。Shell程序fileback存放在/usr/bin目录下。
  209.  
  210. 参考答案:
  211.  
  212. (1)编写shell程序fileback:
  213.  
  214. #!/bin/sh 
  215. DIRNAME=`ls /root | grep bak` 
  216. if [ -z "$DIRNAME" ] ; then 
  217. mkdir /root/bak 
  218. cd /root/bak 
  219. fi
  220. BACKETC=$(date +%Y%m%d)_etc.tar.gz 
  221. tar zcvf  $BACKETC  /etc 
  222. echo "fileback finished!"
  223.  
  224. (2)编写任务定时器:
  225.  
  226. echo "0 0 1 * * /bin/sh /usr/bin/fileback" >; /root/etcbakcron
  227.  
  228. crontab /root/etcbakcron
  229.  
  230. 或使用crontab -e 命令添加定时任务:
  231.  
  232. 0 1 * * * /bin/sh /usr/bin/fileback
  233.  
  234. 11.有一普通用户想在每周日凌晨零点零分定期备份/user/backup到/tmp目录下,该用户应如何做?
  235.  
  236. 参考答案:(1)第一种方法:
  237.  
  238. 用户应使用crontab –e 命令创建crontab文件。格式如下:
  239.  
  240. 0 0 * * sun cp –r /user/backup /tmp
  241.  
  242. (2)第二种方法:
  243.  
  244. 用户先在自己目录下新建文件file,文件内容如下:
  245.  
  246. 0 * * sun cp –r /user/backup /tmp
  247.  
  248. 然后执行 crontab file 使生效。
  249.  
  250. 12.设计一个Shell程序,在/userdata目录下建立50个目录,即user1~user50,并设置每个目录的权限,其中其他用户的权限为:读;文件所有者的权限为:读、写、执行;文件所有者所在组的权限为:读、执行。
  251.  
  252. 参考答案: 建立程序 Pro16如下:
  253.  
  254. #!/bin/sh
  255.  
  256. i=1
  257.  
  258. while [ i -le 50 ]
  259.  
  260. do
  261.  
  262. if [ -d /userdata ];then
  263.  
  264. mkdir -p -m 754 /userdata/user$i   加上-m 754 就不用写下面那一句了  -p 是递归建立目录
  265.  
  266. #chmod 754 /userdata/user$i
  267.  
  268. echo "user$i"
  269.  
  270. let "i = i + 1" (或i=$(($i+1))
  271.  
  272. else
  273.  
  274. mkdir /userdata
  275.  
  276. mkdir -p -m /userdata/user$i
  277.  
  278. #chmod 754 /userdata/user$i
  279.  
  280. echo "user$i"
  281.  
  282. let "i = i + 1" (或i=$(($i+1))
  283.  
  284. fi
  285.  
  286. done

阅读(879) | 评论(0) | 转发(0) |
0

上一篇:ipset - linux防火墙的扩展

下一篇:cat命令

给主人留下些什么吧!~~