shell 常用-阿里云开发者社区

开发者社区> 开发与运维> 正文
登录阅读全文

shell 常用

简介: ./sss xxx $1 $2 $# $0 $? tail -1 head -1 awk '{ if ($1=="FIND") print $2 }' 如何调试bash脚本 #!/bin/bash -xv function aa(){ echo "xx" } let $a=$b+$c $a=(($b+$c)) if[ -f /xx/xx ] then xxx fi for i in $(ls) do ccc done head -10 xx|tail -1 命令“export” 有什么用 ? 使变量在子shell 中可用。

./sss xxx

$1 $2

$#

$0

$?

tail -1

head -1

awk '{ if ($1=="FIND") print $2 }'

如何调试bash脚本

#!/bin/bash -xv

function aa(){

echo "xx"

}

let $a=$b+$c

$a=(($b+$c))

if[ -f /xx/xx ]

then

xxx

fi


for i in $(ls)

do

ccc

done


head -10 xx|tail -1

命令“export” 有什么用 ?

使变量在子shell 中可用。


nohup command&

'和" 引号有什么区别 ?

' - 当我们不希望把变量转换为值的时候使用它。

" - 会计算所有变量的值并用值代替。

exec >xxx.txt 2>&1

echo ${variable:x:y} 

 如果给定字符串variable="User:123:321:/home/dir",如何只用echo命令获取home_dir ?

echo ${variable#*:*:*:}

echo ${variable##*:}

 如何从上面的字符串中获取“User” ?

echo ${variable%:*:*:*}

echo ${variable%%:*}

awk -F: '$3<100' /etc/passwd

IFS=":"

OFS=":"


${#variable}

${variable:-10}和${variable: -10} 有什么区别?

${variable:-10} - 如果之前没有给 variable 赋值则输出 10;如果有赋值则输出该变量

${variable: -10} - 输出 variable 的最后 10 个字符


如何只用echo 命令替换字符串的一部分 ?

echo ${variable//pattern/replacement}

tr '{:lower:}' '{:upper:}'


cat /etc/passwd|wc -l

 不用 wc 命令如何计算字符串中的单词数目 ?

set ${string}

echo $#


"export $variable"或"export variable" 哪个正确 ?

export variable

ls ?[ab]*

echo $string|tr -d ""

for((i=0;i<=100;i=i+3));doecho"Welcome $i times";done

for ((i=0;i<=100;i=i+3))

do

echo $i

done

如何打印传递给脚本的所有参数 ?

echo $*

[ $a == $b ]和[ $a -eq $b ] 有什么区别

[ $a == $b ] - 用于字符串比较

[ $a -eq $b ] - 用于数字比较

[ $a -gt 12]

$a -lt 12

$a -le 12

[[ == abc*]]

egrep"^ab|^xy"/etc/passwd|cut-d:-f1

cut -d: -f1

$*和$@ 有什么区别*

$* - 以一个字符串形式输出所有传递到脚本的参数

$@ - 以 $IFS 为分隔符列出所有传递到脚本中的参数

array=("" "" "")

echo $(array[0])

echo $(array[@])

unset array[2]

array[333]="New_element"

read -p "xxx" aa

/usr/bin/expect<

EOD


cat a.txt|awk '{ print $1}'|sort|uniq >aip.txt

cat a.txt|awk '{ print $1}'|sort|uniq >bip.txt

wc -l aip.txt

cat aip.txt bip.txt>cip.txt

cat cip.txt|sort|uniq

diff ipA.txt ipB.txt | grep \>


cata.txt b.txt | awk'{print $2}'> name.txt


sed -i '23s/test/tests/g' xx.txt

awk -F " " 'NR=25{print $3}' /xxx

   head–n25 /web.log | tail –n1 | cut –d “ ” –f3

sed -i "1,3d" /xxx

#!/bin/bash

   i=1

   while[ $i -le 100 ];do

       ret=1

       for(( j=2;j<$i;j++ ));do

   if [ $(($i%$j))-eq 0  ];then

ret=0

break

   fi

       done

       if[ $ret -eq 1 ];then

           echo-n "$i "

       fi

       i=$((i+1 ))

   done


echo 0 23,1,3,5,7 * * * date>>/etc/crontab

find . -size +10k -exec mv /tmp {} \;

find . -size +10k -print0|xargs -0 mv  {} /tmp;


iptables -t nat -A PREROUTING -p tcp --dport 80 -j DNAT --to 192.168.2.1:8080

iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to 8080


echo "2 6-12/2 * * * root /usr/bin/httpd.sh">>/etc/crontab

ps aux|grep|cut -f?


awk -F "," 'if($2>56789){print $0}' file.txt

sed -n "1p;3p;5p;" file.txt

awk 'NR==1|NR==2|NR==3{print $0}' file.txt


sed -i "s#\t#\|#g" xxx.txt

find . -name  "*.sh" -exec mv {}

useradd stu

iptables -A input -p tcp --dport 22 -s 10xxxx -j ACCEPT

iptables -A input -t udp --dport 22 -s xx   -j ACCEPT

iptables -A input -j DROP


grep -n ^$ file1

grep abc$ file1

head -n 3 file1

sed -n "1,3p" file1


vim 

:%d

:%s/shutdown/reboot/g


iptables -t nat -A PREROUTING -p tcp --dport 80 -j DNAT --to xxxx

find / -size +50k -size -100k


b=${a/123/321};将${a}里的第一个123替换为321

b=${a//123/321};将${a}里的所有123替换为321

${a//sss/ggg}

${a/sss/ggg}

Q:4 如何将标准输出和错误输出同时重定向到同一位置?

答:这里有两个方法来实现:

方法一:

2>&1 (# ls /usr/share/doc > out.txt 2>&1 )

方法二:

&> (# ls /usr/share/doc &> out.txt )

10 告诉我shell脚本中Case语句的语法 ?

答:基础语法如下:

img_58f168d64e237652413f5a383fb83576.png

如何调试shell脚本 ?

答:使用’-x’参数(sh -x myscript.sh)可以调试shell脚本。另一个种方法是使用‘-nv’参数( sh -nv myscript.sh)。

rename "oldboy" "oldgirl" *.html|rename "html" "HTML" *.html

#!/bin/bash

cd /oldboy

for i in `ls *.HTML`

do

mv $i `echo $i|sed -e 's#oldboy#oldgirl#g;s#html#HTML#g'`

done


echo $a|cut -c1-8

$ MYVAR=foodforthought.jpg

$ echo ${MYVAR##*fo}

rthought.jpg

$ echo ${MYVAR#*fo}

odforthought.jpg


echo ${string:4}//2342341  从第4位开始截取后面所有字符串    

echo ${string:3:3}//123      从第3位开始截取后面3位    

echo ${string:3:6}//123423   从第3位开始截取后面6位    

echo ${string: -4}//2341  :右边有空格   截取后4位   


echo ${string#a*3}//42341  从$string左边开始,去掉最短匹配子串    

echo ${string#c*3}//abc12342341  这样什么也没有匹配到    

echo ${string#*c1*3}//42341  从$string左边开始,去掉最短匹配子串    

echo ${string##a*3}//41     从$string左边开始,去掉最长匹配子串    

echo ${string%3*1}//abc12342  从$string右边开始,去掉最短匹配子串    

echo ${string%%3*1}//abc12     从$string右边开始,去掉最长匹配子串  


mount –t cifs –ousername=“”,passwd=“”//192.168.1.1/共享文件夹/ /mnt/

[root@new-web7 ~17:39:55]#netstat -na | awk'/^tcp/ {++S[$NF]} END {for(i in S) print i, S[i]}'TIME_WAIT 3460FIN_WAIT1 17FIN_WAIT2 6ESTABLISHED 430LAST_ACK 24LISTEN 18

查看IP连接数(访问本机的远程主机数量):

netstat -n | awk '/^tcp/ {print $5}'| awk -F: '{print $1}' |sort | uniq -c | sort –rn

1)netstat –n:列出本机的所有网络连接,包括TCP/UDP和Unix socket两部分。

2)awk '/^tcp/ {print $5}':/^tcp/:条件是以tcp开头的行,^:在此处代表行首的意思。{print $5:将第5个字段打印出来,代表远程主机的IP和port,默认是以tab作为分隔域。

3)awk -F: '{print $1}':“-F:”:以:作为分隔域;打印第一个字段,将port去掉,只显示IP。

4)sort:将IP进行排序。

5)uniq –c:将相同行合并,并统计相同行的数量。

6)sort –nr:以相同行数量进行排序,反向排序,最大的放在最前面。

cat /proc/sys/kernel/random/uuid| md5sum| cut –c 1 -32

cat /proc/sys/kernel/random/uuid|md5sum|cut -c 1-32

cat xx|awk '{print $1}'|uniq -c|sort -rn|head -n 5

e2fsck -p xxx

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享: