赞
踩
实现要求:创建用户student1到student50,指定组为student组!而且每个用户需要设定一个不同的密码!
脚本实现如下:
for i in `seq 1 50`
do
useradd -G student student$i ;
echo student$i | password student$i --stdin;
done
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
#!/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!"
日志格式样例如下:
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 -m | head -10
#参数说明
uniq:
-c 显示输出中,在每行行首加上本行在文件中连续出现的次数.
sort:
默认的排序方式是升序, -r参数就会改变成倒叙;
你有没有遇到过10比2小的情况.
出现这种情况是由于排序程序将这些数字按字符来排序了,排序程序会先比较1和2,
显然1小,所以就将10放在2前面喽.
这也是sort的一贯作风.
cat access.log | awk '{print $1}' | sort| uniq -c | sort -m | head -10
a.首先两台机器要建立服务器间的信任关系
b.脚本
#!/bin/bash FSMAX="80" remote_user='root' remote_ip=(ip地址列表) ip_num='0' while [ "$ip_num" -le "$(expr ${#remote_ip[@]} -1)"] 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) read_num=$(expr $read_num + 1) done ip_num=$(expr $ip_num + 1) done
#写入crontab
0/10 * * * * /home/diskcheck.sh 2&>1
#!/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 服务器硬盘告警"
13926778@163.com
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
比如:
本机的IP地址是:
192.168.100.5/255.255.255.0
那么它的网络地址是:
192.168.100.1/255.255.255.0
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 ":"
方法一:
#!/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
方法二:
#!/bin/bash
#Thi 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
(1) 从下午4:50 删除/abc目录下的全部子目录和全部文件;
(2) 从早上8:00~下午6:00每小时读取/xyz目录下x1文件中每行第一个域的全部数据加入到/backup目录下的back01.txt文件内;
(3) 每逢周一下午5:00 将/data/目录下的所有目录和文件归档并压缩为文件
backup.tar.gz;
(4) 在下午5:55将IDE接口的CD-ROM卸载 (假设CD-ROM的设备名为hdc);
(5) 在早上8:00前开机后启动.
(a) 用vi创建编辑一个名为prgx的crontab文件;
(a) prgx文件的内容:
50 16 * * * * rm -r /abc/*
0 8-18/1 * * * cut -f1 /xyz/x1 >> /backup/bak01.txt
50 17 * * * tar czvf backup.tar.gz /data
55 17 * * * umount /dev/hdc
(c) 由超级用户登录, 用crontab执行prgx文件中的内容:
root@xxx:#crontab prgx; 在每日早晨8:00之前开机后即可自动启动crontab
#!/bin/bash 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
#!/bin/bash
i=1
while [ $i -le 50 ]
do
userdel -r stud${i}
i=$(($i+1))
done
(1)编写shell程序fileback
#!/bin/bash
DIRNAME=`ls /root | grep bak`
if [ -z "$DIRNAME" ];then
mkdir /root/bak
cd /root/bak
fi
BACKETC=$(date +%Y%m%d)_etc.tar.gz
tar czvf $BACKETC /etc
echo "fileback finished!"
(2)编写任务定时器:
echo "0 0 1 * * /bin/sh /usr/bin/fileback" >;/root/ectbackcron
crontab /root/etcbakcron
或者使用crontab -e 命令添加定时任务
0 1 * * * /bin/sh /usr/bin/fileback
(1)第一种方法:
用户应使用crontab -e命令创建crontab文件.
格式如下:
0 0 * * sun cp -r /user/backup /tmp
(2)第二种方法:
用户先在自己目录下新建文件file,文件内容如下:
0 * * sun cp -r /user/backup /tmp
然后执行crontab file使生效
#!/bin/bash i=1 while [ i -le 50 ] do if [ -d /userdata ];then mkdir -p -m 754 /userdata/user$i #加上-m 754 就不用写下面那一句了 -p 是递归建立目录 #chmod 754 /userdata/user$i echo "user$i" let "i = i + 1" (或i=$(($i+1))) else mkdir /userdata mkdir -p -m /userdata/user$i #chmod 754 /userdata/user$i echo "user$i" let "i = i + 1" (或i=$(($i+1))) fi done
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。