shell常用命令

find
-name
find . -name "*.log" -a -size +2k  -print 
-type
find . -type f -name "*log"  -print
-size
find . -type f -name "*log" -size +337c -print
-print
find . -name "*.log"  -print 
-exec(-ok会有提示)
find . -name "*.log" -exec mv {} cdr  \;
find . -name "*.log" –ok rm –r {} \;
-atime -mtime
find . -type f -atime +10 -mtime +10
-maxdepth

find . -maxdepth 1 -type f -print

不查询子目录



find . -type f -mtime +10 -exec rm -rf {} \;

删除10天以前的文件,不包括10天当天

find . -type f -mtime 10 -exec rm -rf {} \;

删除10天前当天文件。

find . -type f -mtime -10 -exec rm -rf {} \;

删除10天以内,包括今天,不包括10天当天


xargs
xargs是给命令传递参数的一个过滤器,也是组合多个命令的一个工具.它把一个数据流分割为一些足够小的块,以方便过滤器和命令进行处理

-n:

传递参数个数 

一次查看多个.tar.gz文件 find . -name "*gz" | xargs -n 1 tar -tvf

-i:

表示 find 传递给xargs的结果 由{}来代替 

一次重命名多个文件 find . -type f | xargs -t -i mv {} {}.bak

-p:

交互式提问y来确认命令的每次执行

-t:

在执行前回显各个command 



mtime/ctime/atime

mtime:

 修改时间,这个时间指的是文件内容修改的时间,而不是文件属性的修改,当数据内容修改时,这个时间就会改变,用命令ls -l默认显示的就是这个时间。

ctime: 

改变时间,当一个文件的状态改变时,这个时间就会改变,例如更改了文件的权限与属性等,它就会改变。

atime: 

当读取文件内容时,就会更改这个时间,例如使用cat 去读取/etc/man.config,那么该文件的atime就会改变。


grep

-c :

计算找到 '搜寻字符串' 的次数

-i :

忽略大小写的不同,所以大小写视为相同

-n :

顺便输出行号

-v :

反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行!

-A :

搜索行之后 n 行

-B : 

搜索行之前 n 行

-E : 

扩展的正则(ps -ef | grep -E 'ycq|CMD')

  --text 


tar gzip 压缩解压
.gz

gzip: 

用来压缩文件

zcat: 

用来查看压缩过的文本文件的内容

gunzip: 

用来解压文件

gzip file_name 

将文件压缩为file_name.gz 并删除原文件file_name

gunzip file_name.gz

将 file_name.gz解压缩,然后删除。



.zip

zip:

 创建一个压缩文件,包含指定的文件和目录 # zip -r shell.tar /home/prm/shell

zipcloak:

 创建一个加密的压缩文件,包含指定的文件和目录

zipnote:

从zip文件中提取批注

unzip:

从压缩过的zip文件中提取文件和目录



.tar
tar 命令(一次只能选一个):

-c --create 

创建一个新的tar归档文件 tar -cvf name.tar dir1 dir2tar -czvf name.tar.gz dir1 dir2

-t --list 

列出已有tar归档文件的内容 tar -tvf name.tar.gz

-x --extract

从已有tar归档文件中提取文件 tar -xzvf name.tar.gz [file1]

file 是可选的,如果有file,则直接解压该file,不全部解压。

tar 命令选项:

-f 

输出结果到文件或设备file

-v 

在处理文件时显示文件

-z 

将输出重定向给gzip命令来压缩内容

--strip-components=4 

解压后,删除目录层数



split 
将一个大的文件拆分成小的文件:

-a :

 指定后缀长度

-b :

 每个文件多少字节

-d : 

使用数字后缀而不是字母

-l : 

指定每个文件的行数



文本文件,按行
split -l 10000 large_file.txt file_prefix


二进制文件,按大小
split -b 10m large_file.log file_prefix


spc

本地到远程:

scp /home/prm/shell/start.sh [email protected]:/home/prm/shell

复制目录: 

 scp -r local_folder remote_username@remote_ip:remote_folder 

远程到本地:

scp [email protected]:/home/prm/shell /home/prm/shell/start.sh



ssh
安装ssh-server
sudo apt-get install openssh-server


安装ssh-client
sudo apt-get install openssh-client


确认
ps -ef | grep ssh  如果看到ssd,那说明ssh-server已经启动。如果只ssh-agent说明ssh-server还没启动。


启动
/etc/init.d/ssh start 其他命令输入/etc/init.d/ssh


修改ssh端口
修改配置文件/etc/ssh/sshd_config  默认port22 可以修改为其他,然后重启


ssh双机信任:
 首先在客户端上创建一对公私钥(公钥文件:~/.ssh/id_rsa.pub;私钥文件:~/.ssh/id_rsa,然后把公钥放到服务器上(~/.ssh/authorized_keys,自己保留好私钥。当ssh登录时,ssh程序会
发送私钥去和服务器上的公钥做匹配。如果匹配成功就可以登录了。


A: 10.75.169.135(prm1a)
B: 10.75.169.138(prm1b)


1. 在A机prm1a用户下执行
ssh-keygen -t rsa # 一路回车
   
  查看结果:
cd ~/.ssh
ll
-rw------- 1 prm1a user 1675 NOV 27 23:34 id_rsa
-rw-r--r-- 1 prm1a user 398  NOV 27 23:34 id_rsa.pub
-rw-r--r-- 1 prm1a user 398  NOV 27 23:34 known_hosts


 2. 将公钥证书复制到B机prm1b家目录的.ssh目录下,同时将文件名改为authorized_keys
scp id_rsa.pub [email protected]:/home/prm1b/.ssh/authorized_keys # 此时需要输入密码因为还没有建立信任关系


 3. 现在prm1a登录prm1b就不需要密码了
远程复制: ssh [email protected]
远程执行命令: ssh [email protected] 'hostname'


 4.同样在B机执行ssh-keygen -t rsa 然后将公钥复制到A机同时将文件名改为authorized_keys,这样prm1b登录prm1a就不需要密码。


ftp

ftp 192.168.3.2 输入:用户名密码


下载文件:

 get [remote_file] [local_file]

 ftp>get /home/prm/shell/start.sh /home/prm/shell/start.sh


 mget [remote_files] 

文件将下载到当前主机运行ftp目录下,如果你在/home/prm/shell目录下执行,则下载到本地该目录(关闭交互:prompt on/off)

ftp>cd /home/prm/shell
 ftp>mget *.sh 
    
上传文件:
 put [local_file] [remote_file]
    ftp>put /home/prm/shell/start.sh /home/prm/shell/start.sh

mput [local_files] 

将当前目录下文件上传到远端,如果你在/home/prm/shell目录下执行,则上传到远端该目录

ftp>cd /home/prm/shell
ftp>mput *.sh 

bye

退出



sudo

如何在普通用户下切换到root,并且不需要输入密码


root 用户下:

cat /etc/sudoers 

一定不要用vi 编辑这个文件

visudo 

要使用这个命令编辑,这个命令会检查语法。



visudo后得到的格式为
账户名                 主机名称=(可切换的身份)              可用的指令
root                      ALL=(ALL)                             ALL


例如:
prm    ALL(root)    ALL
prm    ALL(root)    NOPASSWD:    /sbin/ifconfig #以后不用输入密码


普通用户下:
sudo -s #切换到root用户


mailx
基本用法:cat message | mailx -s "subject" -r "[email protected]" -c "[email protected]" -b "[email protected]" "[email protected]

多个人之间用逗号分隔。


-s: 指定主题
-r: 指定发件人
-c: 指定抄送人
-b: 指定密送人


ls 排序
ls -rt 按mtime时间升序
ls -S 按大小排序


df 
-h   方便阅读方式显示
-T   文件系统类型


du
du 参数 选项

-a

为每个制定文件显示磁盘使用情况, 或者为目录中每个文件显示各自磁盘使用情况

-b 

显示目录或文件大小时, 以byte 为单位

-c 

除了显示目录或文件的大小外, 同时也显示所有目录和文件的总和

-h 

humanreadable 以K,M,G 为单位,提高信息的可读性

-H 

以K,M,G为单位, 以1000 换算而不是1024

-s

summarize 显示当前目录大小,不检查子目录

-m 

以兆为单位

例子:显示当前目录下各个子目录占用空间大小:du -sh *

wc
wc  选项  文件

-c 

显示文件的Bytes数(字节数)及文件名输出到屏幕上 

-l 

将每个文件的行数及文件名输出到屏幕上 

-m 

将每个文件的字符数及文件名输出到屏幕上,如果当前系统不支持多字节字符其将显示与-c参数相同的结果 

-w 

将每个文件含有多少个词及文件名输出到屏幕上 


cut 裁剪

cut -b 

按字节,中文3字节.

echo "123456789" | cut -b 1-3 # 123
echo "123456789" | cut -b 1-3,6-7 # 12367
echo "123456789" | cut 5,1-3 # 1235  cut会先把-b后面所有的定位进行从小到大排序,然后再提取.


cut -c 按字符,汉4个字一个字符.
echo "123456789" | cut -c 2,6-7 # 267


cut -f 按域,-d 默认制表符
echo "192.168.3.2" | cut -d . -f 1,3 # 192.3


-b: 

指定以字节为单位显示选中内容

-c: 

指定以字符为单位显示选中内容

-f: 

指定以字段为单位显示选中内容

-d:

指定字段的分界符,默认为制表符



n: 

第n个字节/字符/字段

n-: 

从第n个字节/字符/字段到最后一个字节/字符/字段

n-m: 

从第n个字节/字符/字段到第m个字节/字符/字段,包括m

-m:

从行的开头到第m个字节/字符/字段,包括m

-: 

从行开头到行的最后s


tr  

tr的所有功能都能够用sed来实现


tr -c -d -s ["string1_to_translate_from"] ["string2_to_translate_to"]

-c 

用to替换from

-d 

删除字符串中的字符

-s 

删除重复字符序列,保留一个



echo "hello world" | tr  "[a-z]" "[A-Z]" # HELLO WORLD
echo "1223445" | tr -d 2 # 13445
echo "1223445" | tr -s 2 # 123445

sort

-f  : 

忽略大小写的差异,例如 A 与 a 视为编码相同

-b  : 

忽略最前面的空格符部分

-M  :

以月份的名字来排序,例如 JAN, DEC 等等的排序方法

-n  : 

使用『纯数字』进行排序(默认是以文字型态来排序的)

-r  : 

反向排序

-u  : 

就是 uniq ,相同的数据中,仅出现一行代表

-t  : 

分隔符,默认是用 [tab] 键来分隔

-k  : 

以那个区间 (field) 来进行排序的意思


uniq

命令可以去除排序过的文件中的重复行,uniq经常和sort合用。为了使uniq起作用,所有的重复行必须是相邻的。


-i: 

忽略大小写字符的不同;

-c: 

进行计数

-u: 

只显示唯一的行 # cat file | uniq -uc

-d: 

只输出重复行,且只输出一次。# cat file | uniq -dc


date

date "+%Y-%m-%d %H:%M:%S" 

#显示当前时间

date -d "-1 day" +%Y%m%d 

#显示前一天的日期

date -d "+1 day" +%Y%m%d 

#显示后一天的日期 

date -d "-1 month" +%Y%m%d 

#显示上一月的日期 

date -d "+1 month" +%Y%m%d

  #显示下一月的日期 

date -d "-1 year" +%Y%m%d 

#显示前一年的日期

date -d "+1 year" +%Y%m%d

  #显示下一年的日期

date --date="-10 minute" 

#显示10分钟前的时间

date -d "10 minute ago" 

#显示10分钟前的时间



修改日期
date -s 05/10/2015 #2015年05月10日  0:00:02


例子:
echo `TZ=GMT-8 date '+%Y-%m-%d %H:%M:%S'
2015-12-26 13:34:42


date格式请参考man date
echo `TZ=GMT-8 date -d "1970-01-01 UTC 1451108183  seconds" "+%F %T"`
2015-12-26 13:36:23


useradd

-c   

comment 指定一段注释性描述。

-d    

指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录。

-u   

用户号指定用户的用户号。


userad  -c  “Test User”  -d  “/home/llj”  -m  llj


passwd

passwd 选项 用户名

passwd llj


userdel
userdel 选项 用户名

-r   删除用户登入目录以及目录中所有文件


userdel -r llj


basename获取文件名部分


文件: 带路径信息的文件

后缀: 可选参数,指定要去除的文件后缀字符串


file=/home/prm/shell/start.sh
file2=`basename $file .sh`.txt


echo $file2    #start.txt


dirname 获取文件的目录部分


echo `dirname /home/prm/shell/start.sh` #/home/prm/shell


watch 周期性执行给定的指令

-n 

指定指令执行的间隔时间(秒)

-d 

高亮显示指令输出信息不同之处

-t 

不显示标题


每隔一秒显示系统时间:watch -n 1 -d date


free

-c 

显示次数,同-s一起使用。

-m  

以MB为单位显示内存使用情况。

-s <间隔秒数>  

持续观察内存使用状况。


Total = used + free
-buffers/cache = 47992 = used - buffers - cached 实际已用的内存
+buffers/cache = 459060 = free + buffers + cached 实际可使用内存
从应用程序的角度来说 可用内存=系统free memory+buffers+cached.对操作系统来讲buffers/cached 都是属于被使用


${}  

file=/mds/app/vds/wbp/bin/start_onip.sh


1. Length
${#file} # 34
2. Substring
${file:0:16} # /mds/app/vds/wbp
${file:21} # start_onip.sh
3. Replace
${file/a/A} # /mds/App/vds/wbp/bin/start_onip.sh
${file//a/A} # /mds/App/vds/wbp/bin/stArt_onip.sh
4. Truncate
${file#*/} # mds/app/vds/wbp/bin/start_onip.sh 去掉前边1个
${file##*/} # start_onip.sh 去掉前边多个
${file%/*} # /mds/app/vds/wbp/bin
${file%%/*} # ""


利用 ${ } 还可针对不同的变量状态赋值(没设定、空值、非空值${var[:][-+=?]default}:


特殊符号
expr 等价于 $[]
let   等价于 (())
let 必须是等式,expr 必须是表达式,(())可以是等式,也可以是表达式


var=1

expr $var + 1 var2=`expr $var + 1` var3=$[var2+1]
let "var4 = var3+1" ((var5 = var4+1)) var6=$((var5 + 1))
echo "scale = 2; 1 / 3" | bc


() 成组命令,成组命令式在新的子shell内执行。分号分隔的命令组,第一个命令和左括号无需空格,最后一个命令后无需分号。
(var=12;echo "hello world")
echo ${var} #没有值    


{} 成组命令,成组命令式在benshell内执行。分号分割的命令组,第一个命令和左括号要有空格,最后一个命令后要有分号。
{ var=12;echo "hello world";}
echo ${var} #12

$() 

等价于``,$(date)等价于var=`date`

(()) 

等价于let,let命令表达式必须有等号,expr一定不能有等号,而(())可以有也可以没有let “var=var+1”(变量可以没$) expr $var + 1(变量要有$)

$(()) 

expr查看返回结果用var=$(expr ...)或`expr ...`。查看(())返回结果用$(()),并且$(())必须赋值一个变量,如果不赋值,则用(())。

var=$((var + 1)),var=$(expr 1 + 2),var=`expr 1 + 2`,var=$((var + 1))

[] 

等价于test,<、> 要转义,逻辑组合用-a、-o,各处需要空格

$[] 

exprvar =$[ $var + 1]

[[]] 

可以认为是]的扩展,支持正则,逻辑组合用&&、||,各处需要空格

{} 

当前进程,分号分隔的命令组,第一个命令和左括号要有空格。

${} 

变量引用${var}



$# 

是传给脚本的参数个数

$0 

是脚本本身的名字

$1 

是传递给该shell脚本的第一个参数

$2 

是传递给该shell脚本的第二个参数

$@ 

是传给脚本的所有参数的列表

$* 

是以一个单字符串显示所有向脚本传递的参数。

$$ 

是脚本运行的当前进程ID号

$? 

是显示最后命令的退出状态,0表示没有错误,其他表示有错误



数组
var="hello,world"


将字符串拆分成数组
按照逗号拆分
IFS=","
array=(${var})


按照空格拆分
array=(${var})


数组内容
echo ${array[@]} 
echo ${array[*]}


数组长度
echo ${#array[@]}
echo ${#array[*]}


遍历数组
for file in ${array[*]};do
    echo ${file}
done


getopt格式化命令行参数


getopt  ab:cd -a parama -b paramb -cd paramc


输出:-a -b paramb -c -d -- parama paramc


user shell
查看机器安装
cat /etc/shells


查看当前用户使用的
cat /etc/passwd | grep username
echo $SHELL


修改(重启生效)
chsh -s /bin/bash


临时修改
/bin/bash


/etc/profile: 

此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行.

.bash_profile 

用户登录时执行。.profile(由Bourne Shell和Korn Shell使用)和.login(由C Shell使用)两个文件是.bash_profile的同义词

.bashrc 

打开新shell执行,一般来说都会在.bash_profile里调用.bashrc脚本以便统一配置用户环境



环境变量设置

set 

用来显示本地变量(当前shell变量)

env 

用来显示环境变量(当前用户变量)

export 

用来显示和设置环境变量(export 显示当前导出成用户变量的shell变量)



export命令:


介绍: 设置或显示环境变量

用法: export #显示环境变量


export MY_HOME="/HOME/PRM"   #设置环境变量,把这个变量载入到内存中,而并没有写入哪个文件,没有写入到磁盘上,而注销或重启之后,将失效。


#vi /etc/profile
export  export MY_HOME="/HOME/PRM" #开机之后自动加载,对所有用户生效。


#vi /home/prm/.bashrc
export  export MY_HOME="/HOME/PRM" #开机之后自动加载,对单个用户生效。

source命令:

介绍: source命令也称为"点命令",也就是一个点符号(.),是bash的内部命令。
功能: 使Shell读入指定的Shell程序文件并依次执行文件中的所有语句。source命令通常用于重新执行刚修改的初始化文件,使之立即生效,而不必注销并重新登录。
用法: source filename 或 . filename


source(.) filename 与 sh filename 及./filename 区别
1.当shell脚本具有可执行权限时,用sh filename与./filename执行脚本是没有区别得。./filename是因为当前目录没有在PATH中,所有"."是用来表示当前目录的。
2.sh filename 重新建立一个子shell,在子shell中执行脚本里面的语句。(sh或./filename 都是子shell执行)
3.source filename:读取脚本里面的语句依次在当前shell里面执行,没有建立新的子shell。


readonly 
-f:定义只读函数
-a:定义只读数组变量
-p:显示系统中全部只读变量列表


readonly var="hello world"

unset $var 取消环境变量


declare/typeset
内建命令(这两个命令是完全一样的)允许指定变量的具体类型.declare命令是从Bash 2.0之后才被引入的命令. typeset也可以用在ksh的脚本中.


-u: 将一个变量的字符变成大写,typeset -u var="hello world"; echo ${var} # HELLO WORLD
-l: 将一个变量的字符变成小写,typeset -l var="HELLO WORLD"; echo ${var} # hello world


-r: 只读 declare -r var="read only"
-f: 在脚本中:declare -f 会列前面定义的所有函数。declare -f println 列出println函数
-a:declare -a array  变量array将被视为数组
-i: declare -i number   脚本将会把变量"number"按照整型进行处理.如果把一个变量指定为整型的话, 那么即使没有expr或者let命令, 也允许使用特定的算术运算.


vi命令
1)0: 移到行首; $:移到行尾部
2)gg:首行; nG:移到第几行;         G:移到尾行
3) :set nu   设置行号           :set nonu   取消行号 
4)x:删除字符; dw:删除当前单词; dd:删除当前行。
5)yy:复制当前行              p:粘贴到光标下一行      P:粘贴到光标前一行
6)u:撤销上一步


重定向
命令 含义 示例
cmand > ouputfile 将命令的输出发送到一个文件中 date > filename
cmand >> ouputfile 追加到一个文件中 date >> filename


cmand < ouputfile 将文件内容重定向到命令 wc > filename
cmand << ouputfile 命令行指定输入重定向的数据 wc << maker
>input every thing 
>maker

端口占用
netstat –apn | grep 8080


linux 查看网卡 ifconfig -a
或者:/var/adm/autoinstall/scripts/eth_alias.sh


调试代码,下面的代码会输出冗余脚本,方便调试
set –x
script code
set +x


shell去掉首尾空格(trim)
result=`echo ${var} | sed 's/^ //' | sed 's/ $//'` 


清空文件,/dev/null 是个"黑洞". 它非常等价于一个只写文件. 所有写入它的内容都会永远丢失. 而尝试从它那儿读取内容则什么也读不到
cat /dev/null > file


crontab log:
cat /var/log/cron | grep "/home/prm/shell/start" |  tail -8


根据Excel生成sql 


将语句贴到空白列,然后复制,在粘贴到ultraedit,把多余的双引号替换掉。


普通版:
="prompt this is row "&ROW()&CHAR(10)&"insert into cdr_inter_201510 values('"&A2&"','"&B2&"','"&C2&"','"&D2&"','"&E2&"','"&F2&"','"&G2&"','"&H2&"','"&I2&"','"&J2&"','"&K2&"','"&L2&"','"&M2&"','"&N2&"','"&O2&"','"&P2&"','"&Q2&"','"&R2&"','"&S2&"','"&T2&"','"&U2&"','"&V2&"','"&W2&"','"&X2&"','"&Y2&"','"&Z2&"');"&CHAR(10)


去首尾空格:
="prompt this is row "&ROW()&CHAR(10)&"insert into cdr_inter_201510 values('"&TRIM(A2)&"','"&TRIM(B2)&"','"&TRIM(C2)&"','"&TRIM(D2)&"','"&TRIM(E2)&"','"&TRIM(F2)&"','"&TRIM(G2)&"','"&TRIM(H2)&"','"&TRIM(I2)&"','"&TRIM(J2)&"','"&TRIM(K2)&"','"&TRIM(L2)&"','"&TRIM(M2)&"','"&TRIM(N2)&"','"&TRIM(O2)&"','"&TRIM(P2)&"','"&TRIM(Q2)&"','"&TRIM(R2)&"','"&TRIM(S2)&"','"&TRIM(T2)&"','"&TRIM(U2)&"','"&TRIM(V2)&"','"&TRIM(W2)&"','"&TRIM(X2)&"','"&TRIM(Y2)&"','"&TRIM(Z2)&"');"&CHAR(10)


含有日期列:
="prompt this is row "&ROW()&CHAR(10)&"insert into cdr_inter_201510 values('"&TRIM(A2)&"','"&TRIM(B2)&"','"&TRIM(C2)&"',to_date('"&TEXT(TRIM(D2),"yyyy/mm/dd")&"','yyyy/mm/dd'),'"&TRIM(E2)&"','"&TRIM(F2)&"','"&TRIM(G2)&"','"&TRIM(H2)&"','"&TRIM(I2)&"','"&TRIM(J2)&"','"&TRIM(K2)&"','"&TRIM(L2)&"','"&TRIM(M2)&"','"&TRIM(N2)&"','"&TRIM(O2)&"','"&TRIM(P2)&"','"&TRIM(Q2)&"','"&TRIM(R2)&"','"&TRIM(S2)&"','"&TRIM(T2)&"','"&TRIM(U2)&"','"&TRIM(V2)&"','"&TRIM(W2)&"','"&TRIM(X2)&"','"&TRIM(Y2)&"','"&TRIM(Z2)&"');"&CHAR(10)


shell 登陆 oracle
sqlplus -S "${_USERNAME}/${_PASSWORD}@${_IP}/${_SID}" 2>&1 << EOF
    ${sql} 
EOF
或者 sqlplus username/password@dbstring
    @filename.sql


 shell调用oracle
/home/prm > sqlplus prm/prm_1234@ppdmed
SQL>@sql_file


你可能感兴趣的:(shell)