linux下shell脚本⾥写cp,shell常⽤脚本参考
1、⽤shell脚本批量建⽴Linux⽤户
实现要求:创建⽤户student1到student50,指定组为student组!⽽且每个⽤户需要设定⼀个不同的密码!
脚本实现如下:
#!/bin/bash
for i in `seq 1 50`
do
useradd -G student student$i ;
echo student$i | passwd student$i --stdin;
done
【说明:Linux下 Passwd有参数
--stdin
This option is used to indicate that passwd should read the new password from standard input, which can be a pipe.所以linux下⾃动改变⽤户密码的办法就是:
Echo 密码 |passwd –stdin ⽤户名
】
-------------------设置相同的密码------------------------
#!/bin/bash
password="123456"
for USER in user1 user2 user3
do
useradd -m $USER
echo -e "${password}\n${password}" | passwd $USER
done
【说明:
echo -n 不换⾏输出:
$echo -n "123"
$echo "456"
最终输出
123456
⽽不是
123
456
echo -e 处理特殊字符:
\n 换⾏且光标移⾄⾏⾸ 】
ok,就这么⼀个简单的脚本,就可以再系统⾥批量⽣成账号了。⽽且密码跟账号的名字⼀样。
这就是for do done语句⽤法。
2、 编写shell脚本,将/usr/local/test⽬录下⼤于100k的⽂件转移到/tmp⽬录下:
#!/bin/bash
for FILE in `ls /usr/local/test`
do
if [ -f $FILE ] ; then
if [ `ls -l $FILE | awk `{print $5}` -gt 100000 ] ; then
mv $FILE /tmp/
fi
fi
done
================
#!/bin/bash
for FileName in `ls -l /usr/local/test | awk '$5>102400' {print $9}`
do
mv $FileName /tmp/
done
ls -al /tmp/
echo "done!"
3、通过apache访问⽇志access.log 统计IP和每个地址访问的次数,按访问量列出前10名。
⽇志格式样例如下:
192.168.1.247 ---【02/jul/2010:23:44:59 + 8080 】 "GET /HTTP/1/1" 200 19
答案:
cat access.log | awk '{print $1}' |sort| uniq -c |sort -rn |head -10
(uniq 参数说明:– c 显⽰输出中,在每⾏⾏⾸加上本⾏在⽂件中连续出现的次数。
sort参数说明:sort默认的排序⽅式是升序,-r 参数就会改变成倒叙;你有没有遇到过10⽐2⼩的情况。我反正遇到过。
出现这种情况是由于排序程序将这些数字按字符来排序了,排序程序会先⽐较1和2,显然1⼩,所以就将
10放在2前⾯喽。这也是sort的⼀贯作风。)
4、⼀台监控主机,⼀台被监控主机。被监控主机分区使⽤率⼤于80%,就发告警邮件。放到crontab⾥⾯,每10分钟执⾏⼀次。
a、 ⾸先两台机器要建⽴服务器间的信任关系。
b、脚本:
#!/bin/bash
remote_user='root'
remote_ip=(IP地址列表)
ip_num='0'
while [ "$ip_num" -le "$(expr ${#remote_ip[@]} -l)"]
do
read_num='1'
ssh "$remote_user"@"${remote_ip[$ip_num]}" df -h > /tmp/diskcheck_tmp
grep '^/dev/*' /tmp/diskcheck_tmp | awk '{print $5}'|sed 's/\%//g' > /tmp/diskcheck_num_tmp
while [ "$read_num" -le $(wc -l < /tmp/diskcheck_num_tmp) ]
do
size=$(sed -n "$read_num" 'p' /tmp/diskcheck_num_tmp)
if [ "size" -gt "$FSMAX" ]
then
$(grep '^/dev/*' /tmp/diskcheck_tmp |sed -n $read_num'p' > /tmp/disk_check_mail)
$(echo ${remote_ip[$ip_num]}) >> /tmp/disk_check_mail)
$(mail -s "diskcheck_alert" admin < /tmp/disk_check_mail)
fi
read_num=$(expr $read_num + 1)
done
ip_num=$(expr $ip_num + 1)
done
===================写⼊crontab=====================
0/10 * * * * /home/diskcheck.sh 2&>1
5、监控主机的磁盘空间,当使⽤空间超过90%就通过发mail来发警告
#!/bin/bash
#monitor available disk space
#提取本服务器的IP地址信息
IP=`ifconfig eth0 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "`
SPACE=` df -hP | awk '{print int($5)}'`
if [ $SPACE -ge 90 ]
then
echo "$IP 服务器 磁盘空间 使⽤率已经超过90%,请及时处理。"|mail -s "$IP 服务器硬盘告警" fty89@163 fi
#! /bin/bash
ftp -n << END_FTP
open 192.168.1.22
user test testing //⽤户名test 密码:testing
binary
prompt off //关闭提⽰
mput files //上传files⽂件
close
bye
END_FTP
6、编写shell脚本,获取本机的⽹络地址。⽐如:本机的ip地址是:
192.168.100.5/255.255.255.0,
那么他的⽹络地址是:
192.168.100.1/255.255.255.0
⽅法⼀:
#!/bin/bash
IP=ifconfig eth0|grep 'inet addr'|sed 's/^.*addr://g'|awk '{print $1}'
NETMASK=ifconfig eth0 |grep "inet addr"|sed 's/^.*Mask://g'
echo "$IP/&NETMASK"
exit
shell创建文件并写入内容
⽅法⼆:
#!/bin/bash
#This script print ip and network
file="/etc/sysconfig/network-scripts/ifcfg-eth0"
if [ -f $file ] ;then
IP=`grep "IPADDR" $file|awk -F"=" '{ print $2 }'`
MASK=`grep "NETMASK" $file|awk -F"=" '{ print $2 }'`
echo "$IP/$MASK"
exit 1
fi
IP地址也可这样获取:IP=`ifconfig eth0 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "⼦⽹掩码:NETMASK= `ifconfig eth0 | grep "inet addr"|cut -f 4 -d ":"
7、某系统管理员需要每天做⼀定的重复⼯作,编制⼀个解决⽅案:
(1).从下午4:50 删除/abc ⽬录下的全部⼦⽬录和全部⽂件;
(2).从早上8:00~下午6:00 每⼩时读取/xyz ⽬录下x1 ⽂件中每⾏第⼀个域的全部数
据加⼊到/backup ⽬录下的 ⽂件内;
(3).每逢周⼀下午5:50 将/data ⽬录下的所有⽬录和⽂件归档并压缩为⽂件
;
(4).在下午5:55 将IDE 接⼝的CD-ROM 缷载(假设CD-ROM 的设备名为hdc);
(5).在早上8:00 前开机后启动。
(a)⽤vi创建编辑⼀个名为prgx的crontab⽂件;
(b)prgx⽂件的内容:
50 16 * * * rm -r /abc/*
0 8-18/1 * * * cut -f1 /xyz/x1 >> /
50 17 * * * tar zcvf /data
55 17 * * * umount /dev/hdc
(c)由超级⽤户登录,⽤crontab执⾏ prgx⽂件中的内容:
root@xxx:#crontab prgx;在每⽇早晨8:00之前开机后即可⾃动启动crontab
8.设计⼀个shell程序,添加⼀个新组为class1,然后添加属于这个组的30个⽤户,⽤户名的形式为stdxx,其中xx从01到30参考答案:
#!/bin/sh
i=1
groupadd class1
while [ $i -le 30 ]
do
if [ $i -le 9 ] ;then
USERNAME=stu0${i}
else
USERNAME=stu${i}
fi
useradd $USERNAME
mkdir /home/$USERNAME
chown -R $USERNAME /home/$USERNAME
chgrp -R class1 /home/$USERNAME
i=$(($i+1))
done
9.编写shell程序,实现⾃动删除50个账号的功能。账号名为stud1⾄stud50。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论