天天看点

shell练习comment = Share Allpath = ""browseable = yespublic = yeswritable = no

1、

[root@centos7 shell]# cat test.sh 

#!/bin/bash

#1.取出www.aaa.com/root/123.htm

echo $var|awk -F "//" '{print $2}'

#2.取出123.htm

echo $var|awk -F "/" '{print $5}'

#3.取出http://www.aaa.com/root

echo $var|awk -F "/123" '{print $1}'

#4.取出http:

echo $var|awk -F "://" '{print $1}'

#5.取出http://

echo $var|awk -F "www" '{print $1}'

#6.取出123

echo $var|awk -F "[/ .]+" '{print $6}'

#7.取出123.htm

echo $var|awk -F "[/ ]+" '{print $4}'

2、

我们使用的云主机,购买一块云盘后,默认并不是挂载状态的,用shell写一个脚本,只要把盘符和挂载点以参数的形式提供给脚本,该脚本就可以自动格式化、挂载。

要求:

1 不用分区,直接格式化

2 格式化为ext4文件系统类型

echo "Useage $0 盘符 挂载点, 如: $0 /dev/xvdb /data"

if [ $# -ne 2 ]

then

exit

fi

if [ ! -b $1 ]

then 

echo "你提供的盘符不正确,请检查后再操作"

exit 1

mkfs -t ext4 $1

if [ ! -d $2 ] ;then

mkdir -p $2

n=<code>egrep " $2 " /etc/fstab|wc -l</code>

if [ $n -eq 0 ]

echo "$1 $2 ext4 defaults 0 0" &gt;&gt; /etc/fstab

mount -a

else

mount $1 $2

echo "配置文件/etc/fstab中已经存在挂载点$2,请检查一下."

3、需求背景:

discuz论坛,每天有很多注册机注册的用户,然后发垃圾广告帖子。虽然使用了一些插件但没有效果。分析访问日志,发现有几个ip访问量特别大,所以想到可以写个shell脚本,通过分析访问日志,把访问量大的ip直接封掉。

但是这个脚本很有可能误伤,所以还需要考虑到自动解封这些ip。

思路:

1 可以每分钟分析1次访问日志,设定一个阈值,把访问量大的ip用iptables封掉80端口

2 每20分钟检测一次已经被封ip的请求数据包数量,设定阈值,把没有请求的或者请求量很小的解封

4、脚本安装samba服务

is_samba_installed=<code>rpm -qa|grep samba|wc -l</code>

if [ $is_samba_installed != 0 ]

echo "You had already installed Samba."

exit 0

echo "It will install Samba."

sleep 1

cnfdir="/etc/samba/smb.conf"

chkok(){

if [ $? != 0 ]

echo "Error, Please try again."

}

yum install -y samba

chkok

sed -i 's/MYGROUP/WORKGROUP/' $cnfdir

sed -i 's/user/share/' $cnfdir

#在最后一行新增[fish]

sed -i '$a[fish]' $cnfdir

if [ -d $1 ]

cd $1

echo "test" &gt; test.txt

sed -i '$a[fish]\n\tcomment = Share All\n\tpath = "'$1'"\n\tbrowseable = yes\n\tpublic = yes\n\twritable = no' $cnfdir

#类似:\n换行 \t tab键

#[fish]

mkdir $1

/etc/init.d/smb start

echo "Please input [\sambaIP\sharename] to access the share dir."

本文转自方向对了,就不怕路远了!51CTO博客,原文链接: http://blog.51cto.com/jacksoner/2045286,如需转载请自行联系原作者