shell相关命令

shell script

#!/bin/bash

# do something

run shell script

sh script.sh

 

or

 

chmod a+x script.sh

./script.sh

# 会读取首行的解释器, 执行

cmd

cmd1; cmd2

 

or

 

cmd1

cmd2

echo

echo 的功能正如其名,就是基于标准输出打印一段文本

echo "welcome to bash"

echo welcome to bash

使用不带引号的echo时,无法显示分号

使用单引号echo时,bash不会对单引号中变量求值 '$var'

echo 中转义换行符

默认情况,echo将换行标志追加到文本尾部,可以忽略结尾换行符

echo -n 'test\n'

对字符串进行转义

echo -e '1\t2\t3'

打印彩色输出

文字颜色码

    重置0

    黑色30

    红色31

    绿色32

    黄色33

    蓝色34

    洋红35

    青色36

    白色37

 

echo -e "\e[1;31m This is red test \e[0m"

 

背景颜色码

    重置0

    黑色40

    红色41

    绿色42

    黄色43

    蓝色44

    洋红45

    青色46

    白色47

 

echo -e "\e[1;42m Green Background \e[0m"

printf

可以格式化字符串, 使用参数同cprintf一样

printf "hello world"

默认不会加换行符, 需要手动添加

printf "%-5s %-10s %-4.2f\n" 3 Jeff 77.564

 

3    Jeff      77.56

环境变量和变量

bash中,每个变量的值都是字符串,无论你给变量赋值时是否使用引号,值都会以字符串的形式存储

环境变量

查看所有与此终端进程相关的环境变量

env

查看某个进程的环境变量

cat /proc/$PID/environ

变量赋值

var=value

var='the value'

var="the $PARAM"

 

echo $var

echo ${var}

 

var = value非变量赋值是相等操作

环境变量

未在当前进程中定义,而是从父进程中继承而来的变量

export 设置环境变量,之后,从当前shell 执行的任何程序都会继承这个变量

 

export PYTHONPATH=$PYTHONPATH:/home/ken/workspace

常用的环境变量

PATH 查找可执行文件路径, 通常定义在/etc/environment or /ect/profile or ~/.bashrc

修改:        export PATH=$PATH:/new/path/

HOME

PWD

USER

UID

SHELL

获取字符串长度

length=${#var}

识别当前shell版本

echo $SHELL

    /bin/bash

echo $0

    bash

检查是否为超级用户 or 普通用户

rootUID=0

 

if [ $UID -ne 0 ]

then

    echo "not rootuser"

else

    echo"root"

fi

修改bash的提示字符

设置PS1变量

\u用户名

\h主机名

\w当前工作目录

pgrep

获取某个进程名对应进程id

pgrep gedit

shell数学运算

整数运算

let

no1=4

no2=5

let result=no1+no2

 

let no1++

let no2--

let no1+=7

let no2-=7

expr(少用)

result=`expr 3 + 4`

result=$(expr $no1 + 5)

其他方法

result=$[ no1 + no2 ]

result=$[ $no + 5 ]

 

result=$(( no1 + 5))

浮点数

echo "4 * 0.56" | bc

设定精度

echo "scale=2;3/8" | bc

进制转换

echo "obase=2;100" | bc

平方

echo "10^10" | bc

平方根

echo "sqrt(100)" | bc

命令状态

当命令成功完成, 返回0

发生错误并退回, 返回非0

可以从$?中获取 cmd; echo $?

文件描述符和重定向

文件描述符: 与文件输入/输出相关联的整数,用来跟踪已打开的文件

0 stdin  标砖输入

1 stdout 标准输出

2 stderr 标准错误

重定向到文件

清空文件写入新内容

echo "test" > temp.txt

追加

echo "test" >> temp.txt

 

>等价于1>

>>等价于 1>>

输出分离或合并

分离

cmd 2>stderr.txt 1>stdout.txt

 

合并

cmd > output.txt 2>&1

or

cmd &> output.txt

扔到垃圾桶

/dev/null 特殊设备文件, 接收到的任何数据都会被丢弃(位桶/黑洞)

 

只有标准错误

cmd 2 > /dev/null

 

标准输出和标准错误

cmd >/dev/null 2>&1

同时输出到终端和文件

cmd | tee file1

 

tee默认覆盖,可以-a选项追加

cmd | tee -a file1

stdin作为命令参数

cmd1 | cmd2 | cmd3 -

将文件重定向到命令

cmd < file

自定义文件描述符

使用文件描述符3打开并读取文件

exec 3

cat <&3

 

使用文件描述符4进行写入

exec 4>output.txt

echo newline >&4

cat

cat, concatenate(拼接)

“cat”代表了连结(Concatenation),连接两个或者更多文本文件或者以标准输出形式打印文件的内容

一般格式

cat file1 file2 file3

 

从管道中读取

OUTPUT_FROM_SOME_CMDS | cat

 

echo "test" | cat - file1

压缩空白行, 多个连续空行变成单个

cat -s  file

配合tr移除空白行

cat file | tr -s '\n' #连续多个\n -> \n

加行号

cat -n file

显示制表符等

cat -T file

 

cat f > t

注意:“>>”“>”调用了追加符号。它们用来追加到文件里,而不是显示在标准输出上。

“>”符号会删除已存在的文件,然后创建一个新的文件。

所以因为安全的原因,建议使用“>>”,它会写入到文件中,而不是覆盖或者删除。

输入多行文字(CTRL + d 退出)

cat > test.txt

数组和关联数组

普通数组,整数作为数组索引, 借助索引将多个独立的数据存储为一个集合(list)

关联数组,可以使用字符串作为索引(map)

数组

定义

array_var=(1 2 3 4 5)

 

or

array_var[0]="test1"

array_var[3]="test3"

读取

echo ${array_var[0]}

以清单形式打印

echo ${array_var[*]}

echo ${array_var[@]}

长度

echo ${#array_var[*]}

获取索引列表

echo ${!array_var[*]}

关联数组

declare -A ass_array

 

内嵌索引-

ass_array=([index1]=value1 [index2]=value2)

 

独立

ass_array[index3]=value3

 

echo ${ass_array[index1]}

alias

alias是一个系统自建的shell命令,允许你为名字比较长的或者经常使用的命令指定别名。

alias new_command='command seq'

unalias new_command

 

使用原生命令

\new_command

date

“date”命令使用标准的输出打印当前的日期和时间,也可以深入设置

读取日期

date

时间戳

date +%s

日期转换为时间戳

date --date "Thu Nov 18 08:07:21 IST 2010" +%s

日期格式化

星期  %a  Sat

      %A  Saturday

    %b Nov

      %B  November

    %d 31

固定日期格式mm/dd/yy     %D

    %y 10

      %Y  2010

小时  %I/%H   08

分钟  %M  33

    %S 10

纳秒  %N 696308515

Unix纪元时  %s

格式化

date "+%Y %B %d"

 

date +%Y-%m-%d

输出: 2011-07-28

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

设置日期和时间

date -s "格式化日期字符串"

 

date -s "21 June 2009 11:01:22"

延时

sleep number_of_seconds

两天后及两天前

date -d '2 days' +%Y%m%d

date -d '2 days ago' +%Y%m%d

某一天的几天前

TODAY=`date +%Y%m%d`

DAY_1_AGO=`date -d "$TODAY 1 daysago" +%Y%m%d`

时间戳日期转换

date-d@1193144433

date-d@1193144433"+%Y-%m-%d%T"

 

反向:

date-d"2007-10-2315:00:23""+%s"

赋值给变量

DATE=$(date +%Y%m%d)

DATE=`date +%Y%m%d`

调试脚本

打印出所执行的每一行命令

bash -x script.sh

sh -x script.sh

在脚本中设置开关

set -x 在执行时显示参数和命令

set +x 关闭调试

set -v 当命令进行读取时显示输入

set +v 禁止打印输入

直接修改脚本

#!/bin/bash -xv

函数和参数

定义函数

function fname()

{

 statements;

}

 

or

fname()

{

    statements;

}

调用

fname;

传参

fname arg1 arg2;

接收参数

$1第一个参数

$2第二个参数

$nn个参数

 

"$@"被扩展成"$1""$2""$3"

"$*"扩展成"$1c$2c$3",其中cIFS第一个字符

 

"$@"使用最多, $*将所有的参数当做单个字符串

bash支持递归

导出函数,可以作用到子进程中

export -f fname

函数及命令返回值

cmd;

echo $?

 

退出状态,成功退出,状态为0,否则,非0

 

cmd

if [ $? -eq 0 ]

then

    echo"success"

else

    echo"fail"

fi

管道

前一个命令的输出作为后一个命令的输入

$cmd1 | cmd2 |cmd3

读取命令输出

shell  subshell

cmd_output=$(COMMANDS)

or

反引用

cmd_output=`COMMANDS`

shell本身是独立进程, 不会对当前shell有任何影响

pwd;

(cd /bin; ls)

pwd #同上一个pwd

保留空格和换行符

out=$(cat text.txt)

echo $out  #丢失所有换行符

 

out="$(cat text.txt)"

echo $out  #保留

 

cat a

1

2

3

echo $(cat a)

1 2 3

echo "$(cat a)"

1

2

3

read

read, 用于从键盘或标准输入中读取文本

读取n个字符存入变量

read -n number_of_chars variable_name

不回显的方式读取密码

read -s var

显示提示信息

read -p "Enter input:" var

限时输入

read -t  timeout var

设置界定符

read -d delim_char var

read -d ":" var

hello:

字段分隔符和迭代器

内部字段分隔符,Internal Field Separator, IFS

IFS默认为空白字符(换行符,制表符,空格)

data="name,sex,rollno"

oldIFS=$IFS

IFS=,

for item in $data

do

        echo $item

done

 

IFS=$oldIFS

循环

for循环

echo {1..50}

 

for i in {a..z}; do actions; done;

 

or

 

for((i=0;i<10;i++))

{

    commands;

}

while循环

while condition

do

    commands;

done

until循环

until condition

do

    commands;

done

比较和测试

if条件

if condition;

then

    commands;

elif condition;

then

    commands;

else

    commands;

fi

逻辑运算符进行简化, 短路运算更简洁

[ condition ] && action;

[ condition ] || action;

算术比较

-gt 大于

-lt 小于

-ge 大于等于

-le 小于等于

-ne 不等于

-eq 等于

 

注意[]和操作数之间的空格

[ $var -eq 0 ]

 

and

[ $var -ne 0 -a $var2 -ge 2 ]

or

[ $var -ne 0 -o $var2 -ge 2 ]

文件测试

[ -f $file_var ] 正常文件路径或文件名

[ -x $var ] 可执行

-d 目录

-e 存在

-c 字符设备文件

-b 块设备文件

-w 可写

-r 可读

-L 符号链接

字符串比较

[[ $str1 = $str2 ]]

[[ $str1 == $str2 ]]

 

[[ $str1 !=$str2 ]] 不等

 

[[ $str1 > $str2 ]]

[[ $str1 < $str2 ]]

 

[[ -z $str1 ]] 

[[ -n $str1 ]]  非空

 

if [[ -n $str1 ]] && [[ -z $str2 ]]

then

    commands;

fi

find

搜索指定目录下的文件,从开始于父目录,然后搜索子目录

基本

find base_path

 

# 打印文件和目录列表

find . -print  #默认\n分割文件名

文件名

find path -name "*.txt" -print

          -iname  忽略大小写

 

多个条件 or

find . \( -name "*.txt" -o -name "*.py"\)

文件路径

通配符

find /home/users -path "*slynux*" -print

 

正则

find . -regex ".*\(\.py\|\.sh\)$"

       -iregex 忽略大小写

否定参数

find . ! -name "*.txt" -print

根据文件类型

find . -type d -print

f 普通文件

l 符号链接

d 目录

c 字符设备

b 块设备

s 套接字

p Fifo

设定目录深度

find . -maxdepth 1 -type f -print

find . -mindepth 2 -type f -print

根据文件时间搜索

计量单位

-atime 最近一次访问时间

-mtime 最后一次被修改时间

-ctime 文件元数据,最近一次修改时间

 

find . -type f -atime -7 -print #最近七天内被访问的

find . -type f -atime 7 -print  #恰好在七天前

                     +7 -print #超过七天

 

计量单位分钟

-amin 访问时间

-mmin 修改时间

-cmin 变化时间

 

find . -type f -amin +7 -print #访问时间超过7分钟的

 

find . -type f -newer file.txt -print  #用于比较时间戳的参考文件,比参考文件更新的文件

基于文件大小的搜索

find . -type f -size +2k

+ 大于  -小于   无符号,恰好等于

 

b

c 字节

w 字(2字节)

k 千字节

M 兆字节

G 吉字节

删除匹配的文件

find . -type f -name "*.swp" -delete

#注意:-delete位置一定是最后

文件权限及所有权

find . -type f -perm 644 -print

 

find . -type f -user slynux -print

执行命令或动作(最强大的命令)

find . -type f -user root -exec chown slynux {} \;

find . -type f -exec cp {} OLD \;

find . -iname "abc.txt" -exec md5sum {} \;

 

{} 江北替换成对应文件名

exec无法结合多个命令,可以将多个命令放入脚本,调用之

跳过指定目录

find . \( -name ".git" -prune \) -name '*.txt'

xargs

将标准输入数据转化成命令行参数

stdin接收到的数据重新格式化,再将其作为参数传给其他命令

多行输入转化成单行输出

cat  example.txt |xargs  #空格替换掉\n

切成多行,每行n个参数

cat examplet.txt | xargs -n 3

可以指定分隔符

echo "aaaXbbbXccc" | xargs -d 'X'

将参数传递给脚本(类似循环)

cat args.txt | xargs -n 1 ./cecho.sh

 

./cecho.sh -p arg1 1

需要变更

cat args.txt | xargs -I {} ./cecho.sh -p {} 1

findxargs组合

find . -type f -name "*.txt" -print | xargs rm -rf

其他

cat file | ( while read arg; do cat $arg; done )

cat file | xargs -I {} cat {}

tr

tr可以对来自标准输入的字符进行替换,删除以及压缩(translate, 可以将一组字符变成另一组字符)

tr只能通过stdin,无法通过其他命令行进行接收参数

格式

tr [options] source-char-set replace-char-set

选项

-c source-char-set补集,通常与-d/-s配合

-d 删除字source-char-set中的所列的字符

-s 浓缩重复字符,连续多个变成一个

字符替换

cat /proc/12501/environ | tr '\0' '\n'

大小写替换

echo  "HELLO"| tr 'A-Z' 'a-z'

cat text | tr '\t' ' '

删除字符

echo "hello 123 world 456"| tr -d '0-9'

hello  world

字符集补集

echo "hello 1 char 2" | tr -d -c '0-9'  #删除非0-9

12

压缩字符

连续的重复字符

echo "GNU is   not UNix" | tr -s ' '

字符类

alnum 字母和数字

alpha 字母

cntrl 控制字符

digit 数字

graph 图形字符

lower 小写字母

print 可打印字符

punct 标点符号

space 空白字符

upper 大写字母

xdigit 十六进制字符

 

tr '[:lower:]' '[:upper:]'

md5sum

32个字符的十六进制串

md5sum filename

md5sum filename1 filename2

sha1sum

40个字符十六进制串

sha1sum file

对目录进行校验

需安装md5deep软件包

md5deep/sha1deep

md5deep -rl dirname

         r递归,l相对路径

sort

语法

sort [options] [file(s)]

 

-c 检查是否已排序

-u 丢弃所有具有相同键值的记录

 

-b 忽略开头空白

-d 字典序

-g 一般数值,以浮点数类型比较字段,仅支持gnu

-i 忽略无法打印的字符

 

-k 定义排序键值字段

-n 以整数类型比较字段

-r 倒转

-o 输出到指定文件

排序

sort file1 > file1.sorted

sort -o file1.sored file1

按数字, 要明确

sort -n file1

逆序

sort -r file

测试一个文件是否已经被排过序

sort -C file

if [ $? -eq 0 ]; then

    echo ssss

fi

合并两个排过序的文件,并不需要对合并后的文件进行再排序

sort -m sorted1 sorted2

根据键或者列排序(按照哪一个列)

sort -k 1 data

限定特定范围内一组字符

key=char4-char8

sort -k 2,3 data

 

sort -k2.4,5.6 file

第二个字段的第四个字符开始比较,直到第五个字段的第六个字符

忽略前导空白及字典序排序

sort -bd unsorted.txt

去重

sort a.txt | uniq

sort -u a.txt

uniq

用法

uniq file

只显示未重复的记录

uniq -u file

找出重复的行

uniq -d file

-s 可指定跳过前N个字符

-w 指定用于比较的最大字符数

统计各行出现的次数

uniq -c file

p57

tempfile

只有在基于Debian的发布版才有(Ubuntu/Debian)

temp_file=$(tempfile)

等同

temp_file="/tmp/file-$RANDOM"

 

#$$为进程id

temp_file="/tmp/var.$$"

split

按大小分割文件, 单位k(KB), M, G, c(byte), w(word)

split -b 10k data.file

-d数字后缀,-a后缀长度

split -b 10k data.file -d -a 4

分割后指定文件名前缀

split -b 10k data.file file_prefix

 

设置后缀格式

split -b 10k data.file -d -a 4 file_prefix

根据行数分割

spilt -l 10 data

其扩展是csplit,可根据文件特性切分,关注

bash变量匹配切分

sample.jpg

file_jpg="sample.jpg"

 

从右向左匹配

${file_jpg%.*}

#sample

 

从左向右匹配

${file_jpg#.*}

#jpg

 

% # 属于非贪婪

%% ## 属于贪婪

贪婪非贪婪

var=hack.fun.book.txt

${var%.*} #hack.fun.book

${var%%.*} #hack

 

${var#.*} #fun.book.txt

${var##.*} #txt

expect

实现自动化

spawn ./ineractive.sh

expect "Enter the number"

send "1\n"

expect "Enter name:"

send "hello\n"

expect eof

 

spawn指定需要自动化的命令

expect提供需要等待的消息

send发送消息

expect eof指明命令交互结束

dd

生成任意大小的文件

# 创建一个1M大小的文件junk.data

bs=2M count=2 则文件大小4M

 

dd if=/dev/zero of=junk.data bs=1M count=1

   输入文件     输出文件     块大小   复制块数

 

块大小单位

字节(1B) c

(2B)   w

(512B)   b

千字节(1024B) k

兆字节(1024KB) M

吉字节(1024MB) G

comm

两个文件之间比较,输出三列

onleA \t onlyB \t bothAB

 

comm A B -1 -2 #删除第一第二列

-3 删除第三列

 

可以得到A^B  A-B B-A

mkdir

“mkdir”(Make directory)命令在命名路径下创建新的目录。然而如果目录已经存在了,那么它就会返回一个错误信息不能创建文件夹,文件夹已经存在了”(“cannot create folder, folderalready exists”)

mkdir dirpath     针对本身就存在的,

 

mkdir -p dirpath1/dirpath2      针对本身不存在的

 

#一次多个目录

mkdir -p /home/user/{test,test1,test2}

注意:目录只能在用户拥有写权限的目录下才能创建

ls

ls命令是列出目录内容(List Directory Contents)的意思。运行它就是列出文件夹里的内容,可能是文件也可能是文件夹

ls文件的内容关系

- 普通文件

d 目录

c 字符设备

b 块设备

l 符号链接

s 套接字

p 管道

 

文件权限序列

rwx

rwS  setuid(S),特殊权限, 出现在x的位置, 允许用户以其拥有者的权限来执行文件, 即使这个可执行文件是由其他用户运行的

 

目录

r,允许读取目录中文件和子目录列表

w,允许在目录中创建或删除文件或目录

x,指明是否可以访问目录中的文件和子目录

rwt/rwT 粘滞位,只有创建该目录的用户才能删除目录中的文件,即使用户组和其他用户也有写权限,典型例子/tmp, 写保护

查看目录

ls -d */

ls -F | grep "/$"

ls -l | grep "^d"

find . -type d -maxdepth 1 -print

其他

ls -l    命令已详情模式(longlisting fashion)列出文件夹的内容

ls -a    命令会列出文件夹里的所有内容,包括以”.”开头的隐藏文件

chmod

设置文件权限

“chmod”命令就是改变文件的模式位。chmod会根据要求的模式来改变每个所给的文件,文件夹,脚本等等的文件模式(权限)。

设置权限

user group others all

u    g     o     a

 

chmod u=rwx g=rw o=r filename

 

chmod u+x filename

chomd a+x filename #所有

 

chmod a-x filename

 

chmod 764 filename

 

#设置粘滞位

chmod a+t dirname

 

#递归改变

 

chmod 777 . –R  //给其所有权限;

注意:对于系统管理员和用户来说,这个命令是最有用的命令之一了。在多用户环境或者服务器上,对于某个用户,如果设置了文件不可访问,那么这个命令就可以解决,如果设置了错误的权限,那么也就提供了为授权的访问。

chown

每个文件都属于一个用户组和一个用户“chown”命令用来改变文件的所有权,所以仅仅用来管理和提供文件的用户和用户组授权。

改变所有权

chown user.group filename

递归

chown -R user.group .

每次都以其他用户身份执行(允许其他用户以文件所有者的身份来执行)

chomod +s executable_file

 

chown root.root executable_file

chmod +s executable_file

./executable_file

chattr

创建不可修改文件

chattr +i file

一旦被设置为不可修改, 任何用户包括超级用户都不能删除该文件, 除非其不可修改的属性被移除

chattr -i file

touch

“touch”命令代表了将文件的访问和修改时间更新为当前时间。

touch命令只会在文件不存在的时候才会创建它(空白文件)。如果文件已经存在了,它会更新时间戳,但是并不会改变文件的内容。

空白文件

touch filename

 

for name {1..100}.txt

do

    touch $name

done

修改文件访问时间

touch -a "Fri Jun 25 20:50:14 IST 1999" filename

touch -m #修改文件内容的修改时间

修改文件或目录的时间戳(YYMMDDhhmm)

touch -t 0712250000 file

注意:touch 可以用来在用户拥有写权限的目录下创建不存在的文件。

ln

建立软连接

ln -s target symbolic_link_name

如果目的路径已经存在,而没有指定 -f 标志,ln 命令不会创建新的链接,而是向标准错误写一条诊断消息并继续链接剩下的 SourceFiles

-f 促使ln 命令替换掉任何已经存在的目的路径

readlink

读取链接对应真是路径

readlink web

 

 readlink ~/.vim

 /Users/ken/github/k-vim

file

通过查看文件内容来找出特定类型的文件

打印文件类型信息

file filename

打印不包含文件名在内

file -b filename

e.g.

file /etc/passwd

/etc/passwd: ASCII English text

 

file -b /etc/passwd

ASCII English text

读文件

while read line;

do

    something

done < filename

diff

生成文件差异

非一体化

diff version1.txt version2.txt

一体化, 可读性更好

diff -u version.txt

使用patch将命令应用于任意一个文件

diff -u version1.txt version2.txt > version.patch

patch -p1 version1.txt < version.patch

递归作用于目录

diff -Naur directory1 directory2

 

-N 所有缺失的文件作为空文件

-a 所有文件视为文本文件

-u 一体化输出

-r 递归遍历

head

10行打印

head file

n

head -n 4 file

扣除最后N行之外的所有行

head -n -5 file

tail

最后10

tail file

打印最后五行

tail -n 5 file

tail -5 file

扣除前n

tail -n +(N+1)

实时动态打印

tail -f growing_file

当某个给定进程结束后, tail随之终结

tail -f file --PID $PID

pushd/popd

将当前路径压入栈

pushd

压入某个路径

pushd /home/ken

查看当前路径列表

dirs

切换到某一个

#dirs从左到右编号 0 -

pushd +3

移除最近压入栈的路径并切换到下一个目录

popd

cd

经常使用的“cd”命令代表了改变目录。它在终端中改变工作目录来执行,复制,移动,读,写等等操作

切换到上一目录

cd -

会到HOME目录

cd

cd ~

会到上一级目录

cd ..

wc

Word Count

统计行数

wc -l file

统计单词数

wc -w file

统计字符数

wc -c file

统计所有

wc file

统计最长行的长度

wc file -L

tree

以图形化的树状结构打印文件和目录的结构,需要自行安装

tree ~/unixfile

重点标记出匹配某种样式的文件

tree PATH -P "*.sh"

只标记符合样式之外的文件

tree path -I PATTERN

同时打印文件和目录大小

tree -h

grep

文本搜索工具, 支持正则表达式和通配符

‘grep‘命令搜索指定文件中包含给定字符串或者单词的行

基本用法

grep "match_pattern" file1 file2

使用颜色重点标记

grep word filename --color=auto

扩展型使用正则

grep -E "[a-z]+"

egrep "[a-z]+"

只输出匹配到的文本部分

grep -o word filename

除匹配行外的所有行

grep -v word filename

统计匹配行数

grep -c 'text' filename

打印出包含匹配字符串的行数

grep linux -n filename

打印样式匹配所位于的字符或字节的偏移

echo "gnu is not unix" | grep -b -o "not"

搜索多个文件,找出匹配文本位于哪个文件中

grep -l linux file1 file2

取反

grep -L

递归搜索目录

grep -R "text" dir

忽略大小写

grep -i "hello" filename

匹配多个样式

grep -e "pattern1" -e "pattern2" file

运行匹配脚本

grep -f pattern_file source_file

 

pattern_file:

hello

cool

在搜索中包含、排除文件

grep --include *.{c,cpp} word file

排除

grep --exclude "Readme" filename

--exclude-dir

静默输出,用于判断(不会产生任何输出)

grep -q word file

if [ $? -eq 0 ]

打印匹配行之前,之后的行

grep -A 3 之后3

grep -B 3 之前

grep -C 3 前后

使用行缓冲

在使用tail -f命令时是可以及时看到文件的变化的,但是如果再加上一个grep命令,可能看到的就不那么及时了,

因为grep命令在buffer写不满时就不输出,可以通过选项  --line-buffered 来搞定,如:

 

tail -f file.txt | grep something  --line-buffered

cut

语法

cut -c list [ file ... ]

cut -f list [ -d delim ] [ file ...]

 

-c list 以字符为主,作剪切操作

-f list 以字段为主,作剪切操作

提取字段或列

#第一列

cut -f1 filenam

 

#第二三列

cut -f2,3 filename

提取补集

cut -f1 --complement filename

指定字段分隔符

cut -d ";" -f2 filename

cut -d : -f 1,5 /etc/passwd

指定字符

-b 字节

-c 字符

-f 字段

 

cut -c1-5 filename

N-

N-M

-M

 

ls -l | cut -c 1-10

指定输出分隔符

cut -c1-3,6-9 --output-delimiter ","

join

语法

join [options] file1 file2

 

选项

-1 field1

-2 field2

-o file.field

-t separator

例子

join file1 file2

sed

sed(Stream editor)流编辑器, 可以配合正则使用,进行替换等

sed替换语法

sed 's/pattern/replace_string/' file

将结果直接运用于源文件

-i 用于, 直接修改源文件

 

替换第一个

sed -i 's/pattern/replace_string/' file

 

替换第二个

sed -i 's/pattern/replace_string/2' file

 

替换所有

sed -i 's/pattern/replace_string/g' file

 

从第N处开始替换

sed -i 's/pattern/replcae_string/2g' file

移除空白行

sed '/^$/d' file

已匹配字符串标记

引用匹配到的

sed 's/\w\+/[&]/g' filename

组合多个表达式

sed 'exp1' | sed 'exp2'

等价

sed 'exp1;exp2'

使用引用

sed "s/$text/HELLO/"

子串匹配标记(后向引用,最多9)

sed 's/\([a-z]\+\)' \([A-Z\]\+\)/\2 \1/' filename

保存到文件

sed 's/pattern/replacement/' -i outfile

使用其他分隔符

sed 's#/home/#/tmp/#'

awk

基本结构

awk -F '-' 'BEGIN{statements} {statements} END{statements}'file

表达式中单引号可以换成双引号

BEGIN -> 每一行,执行statements, 执行END

打印某一列

awk -F '-' '{print $0}' file #全部

awk -F '-' '{print $2}' file #第二列

print拼接字符

awk '{var="v1"; var1="v2"; printvar1"-"var2;}'

特殊变量

NR nuber of records, 记录数

NF number of fields, 字段数

$0 当前行文本

$1 第一字段

$2 第二字段

$NF最后一个字段

 

FILENAME 当前输入文件的名称

FNR 当前输入文件记录数

FS 字段分隔字符

OFS 输出字段分隔符,默认" "

ORS 输出记录分隔符,默认"\n"

统计行数

awk 'END{print NF}'

将外部变量值传递给awk

awk -v VARIABLE=$VAR '{ print VARIABLE }'

awk '{print v1, v2}' v1=$var1 v2=$var2

读取行

seq 5 | awk '{ getline var; print var}'

进行行过滤

awk 'NR<5' #行号小于5

awk 'NR==1,NR==4' #行号在15之间

awk '/linux/' #包含样式linux

awk '!/linux/' #不包含

awk '$1 ~/jones/' #第一个字段包含jones

 

tail file

awk 'NR <= 10' file

设定分隔符

awk -F: '{ print $NF }' file

设定输出分隔符

awk -F: -v "OFS=-" '{print $1,$2}' /etc/passwd

打印空行

awk 'NF>0 {print $0}'

or

awk 'NF>0' #未指定action默认打印

printprintf

awk -F: '{print "User", $1, "is really",$5}' /etc/passwd

awk -F: '{printf "User %s is really %s\n", $1, $5}'/etc/passwd

awk中使用循环

for(i=0;i<10;i++) { print $i; }

 

for(i in array) { print array[i] }

内建函数

length(str)

index(str,search_str)

split(str,array,delimiter) 用界定符生成一个字符串列表

substr(string, start, end) #子串

sub(regex, replacement_str, str) #正则替换首个匹配位置

gsub(regex, replacement_str, string) #最后一个匹配位置

match(string, regex) #检查是否能够匹配字符串

tolower(string) #转小写

toupper(string) #转大写

写成脚本文件

BEGIN {}

pattern1 {action1}

pattern2 {action2}

END {}

文件迭代

读文件行

while read line;

do

    echo $line;

done < file.txt

迭代每个单词

for word in $line;

do

    echo $word;

done

迭代每一个字符

for((i=0;i<${#word};i++))

do

    echo ${word:i:1} ;

done

paste

按列合并文件

paste file1 file2 file3

指定分隔符

paste file1 file2 -d ','

tac

逆序打印

tac file1 file2

rev

接收一个文件或stdin作为输入, 逆序打印每一行内容

echo "abc" | rev

wget

Wget是用于非交互式(例如后台)下载文件的免费工具.支持HTTP,HTTPS, FTP协议和 HTTP 代理(选项多, 用法灵活)

一个用于文件下载的命令行工具

wget URL1 URL2

指定保存文件名

wget URL -O local.txt

指定日志,默认达到stdout

wget URL -O local.txt -o log.txt

指定重复尝试次数

wget -t 5 URL

下载限速

wget --limit-rate 20k url

指定限额

wget -Q 100m url

断点续传

wget -c URL

 

$ wget -c -t 100 -T 120 http://www.linux.com/xxxx.data

 

当文件特别大或者网络特别慢的时候,往往一个文件还没有下载完,连接就已经被切断,此时就需要断点续传。

wget的断点续传是自动的。

-c 选项的作用为断点续传。

-t 参数表示重试次数(例如重试100次,-t 100,如果设成-t 0,表示无穷次重试,直到连接成功)

-T 参数表示超时等待时间,例如-T 120,表示等待120秒连接不上就算超时

复制或镜像整个网站

wget --mirror exampledomain.com

wget -r -N -l DEPTH URL

     递归,允许对文件使用时间戳,层级

$ wget -r -np -nd http://www.linux.com/packs/

 

-np 的作用是不遍历父目录

-nd 表示不在本机重新创建目录结构

访问需要认证的HTTP/FTP

wget --user username --password pass URL

post请求

wget url -post-data "name=value" -O output.html

批量下载

wget -i downloads.txt #将文件地址写入一个文件

wget命令执行ftp下载

wget -m ftp://username:password@hostname

curl

基本用法

curl url > index.html

不显示进度信息

curl URL --slient

将内容写入文件,而非标准输出

curl URL --slient -O

写入指定文件

curl URL --slient -o filename

显示进度条

curl url -o index.html --progress

断点续传

curl -C - URL

设置参照页字符串

curl --referer Referer_URL target_URL

跳转到target_URL,其头部refererReferer_URL

设置cookie

curl url --cookie "user=slynux;pass=hack"

另存为一个文件

 

curl URL --cookie-jar cookie_file

设置用户代理

curl URL --user-agent "Mozilla/5.0"

头部信息

curl -H "Host: www.slynux.org" -H"Accept-language: en" url

限定下载带宽

curl url --limit-rate 20k

指定最大下载量(可下载的最大文件大小)

curl url --max-filesize bytes

超出限制的话,返回非0

进行认证

curl -u user:pass url

只打印头部信息,不下载远程文件

curl -I url

curl -head url

发送post请求

curl URL -d "va1=1&va2=2"

         --data

lynx

将网页以ascii字符形式下载

lynx -dump URL > webpage_as_text.txt

打印出网站的文本板块而非html

lynx -dump url

生成信息文件

lynx -traversal url

tar

“tar”命令是磁带归档(TapeArchive),对创建一些文件的的归档和它们的解压很有用。

将多个文件和文件夹保存成单个文件, 同时还能保留所有的文件属性

对文件进行归档

-c create file,创建文件

-f specify filename,指定文件名

 

tar -cf output.tar file1 file2 file3

tar -cf output.tar *.txt

 

tar -cvf output.tar *.txt

向归档中追加文件

tar -rvf original.tar new_file

-r,追加

查看过程中更多信息

tar -tvvf archive.tar

-v/-vv, verbose

提取文件或文件夹

-x, exact

tar -xf archive.tar

 

-C,指定文件

tar -xf archive.tar -C /path/to/extraction_directory

 

 

tar -xvf archive.tar

提取指定文件

tar -xvf file.tar file1 file4

拼接两个归档文件

tar -Af file1.tar file2.tar

#file2合并到file1

只有在文件内容修改时间更新(newer),才进行添加

tar -uvvf archive.tar filea

比较归档文件与文件系统中的内容

tar -df archive.tar filename1 filename2

从归档文件中删除文件

tar -f archive.tar --delete file1 file2

提取到某个目录

 tar zxvfpackage.tar.gz -C new_dir

压缩归档文件

gzip/gunzip -> .gz

f.tar.gz   -z

tar -czvf

tar -xzvf

 

bzip/bunzip -> .bz2

f.tar.bz2  -j

 

f.tar.lzma --lzma

f.tar.lzo

从归档中排除部分文件

tar -cf arch.tar * --exclude "*.txt"

cat list

   filea

   fileb

tar -cf arch.tar * -X list

排除版本控制文件

tar --exclude-vcs -czvvf source.tar.gz files

打印总字节数

tar -cf arc.tar * --exclude "*.txt" --totals

cpio

使用频率不高

归档,保留文件属性(权限、所有权等)

echo file1 file2 | cpio -ov > archive.cpio

-o 指定输出

-v 打印归档文件列表

列出cpio中的文件内容

cpio -it < archive.cpio

-i指定输入

-t列出归档文件中的内容

gzip

压缩,会删除源文件

gzip filename

#got filename.gz

解压

gunzip filename.gz

列出文件属性信息

gzip -l text.gz

stdin读入文件并写出到stdout

cat file | gzip -c > file.gz

压缩归档文件

tar -czvvf archive.tar.gz [files]

or

tar -cvvf archive.tar.gz [files]

gzip archive.tar

指定压缩率

1-9,1最低,但速度最快

gzip -9 test.img

zcat

无需解压缩,直接从.gz中提取内容

zcat test.gz

bzip

更大的压缩率

bzip2 filename

解压缩

bunzip2 filename.bz2

stdinstdout

cat file > bzip2 -c > file.tar.bz2

压缩归档

tar -cjvvf archive.tar.bz2 [files]

or

tar -cvvf archive.tar [files]

bzip2 archive.tar

保留输入文件

bunzip2 test.bz2 -k

压缩率

bzip2 -9 test.img

lzma

gzip/bzip2更好的压缩率

压缩

lzma filename

解压

unlzma filename.lzma

stdinstdout

cat file | lzma -c > file.lzma

创建归档

tar -cavvf archive.tar.lzma [files]

    -xavf

保留输入文件

lzma test.bz2 -k

压缩率

lzma -9 test.img

zip

压缩

zip archive_name.zip [source files/dirs]

对目录和文件进行递归操作

zip -r archive.zip folder1 file2

base64

编码

base64 filename > outfile

cat file | base64 > outfile

解码

base64 -d file > outfile

md5sum

“md5sum”就是计算和检验MD5信息签名。
md5 checksum(
通常叫做哈希)使用匹配或者验证文件的文件的完整性,因为文件可能因为传输错误,磁盘错误或者无恶意的干扰等原因而发生改变。

单向散列

md5sum file

sha1sum file

rsync

可以对位于不同位置的文件和目录进行备份, 借助差异计算和压缩技术实现最小化数据传输量

要确保远端安装了 openssh

从一个目录复制到另一个目录

rsync -av source_path dest_path

-a 进行归档  -v打印细节

路径可以使本地,也可以是远端路径

 

e.g.

rsync -av /home/test /home/backups/ #复制到backups目录下

rsync -av /home/test /home/backups  #创建backups目录, 复制

备份到远程服务器

rsync -av source_path user@host:PATH

可以反向

改善传输速度

rsync -avz source destination

排除文件

rsync -avz source dest --exclude "*.txt"

                      --exclude-from FILEPATH

FILEPATH:

*.bak

更新备份时,删除不存在的文件

rsync -avz source dest --delete

git

初始化目录

git init

配置用户信息

git config --global user.name "wklken"

git config --global user.email "[email protected]"

加到远端

git remote add origin user@remotehost:/home/backup/backup.git

git push origin master

添加

git add *

删除

git rm *.py

标记一个检查点

git commit -m "Commit message"

查看日志

git log

回滚到某个版本

git checkout hashid [ filename ]

克隆

git clone url

dd

Dtat Definiton, 要注意参数顺序, 错误的参数会损毁所有数据

可以用来转换和复制文件,大多数时间是用来复制iso文件(或任何其它文件)到一个usb设备(或任何其它地方)中去,所以可以用来制作USB启动器

语法说明

dd if=SOURCE of=TARGET bs=BLOCK_SIZE count=COUNT

if/of  输入/输出文件或设备路径

bs块大小

count 限制复制到目标的字节数

 

dd if=/dev/zero of=/dev/sda1

 

#制作iso cdrom设备读取所有数据, 创建iso文件

dd if=/dev/cdrom of=cdrom.iso

备份恢复

dd if=/dev/sda1 of=x.img

 

dd if=x.img of=/dev/sda1

mount

mount 是一个很重要的命令,用来挂载不能自动挂载的文件系统。你需要root权限挂载设备。
在插入你的文件系统后,

mount --bind /source /destination

 

首先运行”lsblk”命令,识别出你的设备,然后把分配的设备名记下来。

root@tecmint:~# lsblk

创建一个任何名字的目录,但是最好和引用相关。

 

root@tecmint:~# su

Password:

root@tecmint:~# cd /dev

root@tecmint:~# mkdir usb

现在将“sdb1”文件系统挂载到“usb”目录.

root@tecmint:~# mount /dev/sdb1 /dev/usb

挂载镜像

mount -o loop file.img /mnt/mount_point

网络相关

ifconfig

显示网络接口、子网掩码等详细信息

ifconfig

/sbin/ifconfig

打印某个特定网络接口

ifconfig iface_name

 

e.g.

ifconfig en1

 

HWaddr     MAC地址

inet addr  ip地址

Bcast      广播地址

Mask       子网掩码

设置网络接口ip

ifconfig wlan0 192.168.0.80

dns

cat /etc/resolv.conf

 

host google.com #Dns查找

 

nslookup google.com #更详细信息

修改dns/host

echo nameserver IP_ADDRESS >> /etc/resolv.conf

 

echo ip domain >> /etc/hosts

ping

ping www.baidu.com

路由信息

显示路由表

route

 

以数字形式显示地址

route -n

设置默认网关

route add default gw 192.168.0.1 wlan0

trace_route, 显示分组途径的所有网关的地址

traceroute google.com

ping

基本

ping ADDRESS  #主机名,域名或ip

PING命令可以得到RTT(RoundTrip Time), 分组从源到目的主机的往返时间,单位ms

限制发送分组数

ping ADDRESS -c COUNT

 

ping

fping

同时ping一组ip, 而且响应非常快

fping -a ip1 ip2 -g

fping -a 192.160.1/24 -g

fping -a < ip.list

 

-a, 所有活动主机的ip

-g, IP/mask生成的ip地址范围

进行dns查询

fping -a -d 2 > /dev/null < ip.list

lftp

基本用法

lftp username@ftphost

cd dir

lcd改变本地主机目录

mkdir 创建目录

get/put 下载上传

quit退出

scp

scpsecure copy的缩写, scplinux系统下基于ssh登陆进行安全的远程文件拷贝命令。

linuxscp命令可以在linux服务器之间复制文件和目录.

拷贝文件

scp filename user@remotehost:/home/pat

ip或主机名均可

 

scp SOURCE DESTINATION

递归复制

scp -r dir1 user@remotehost:/home/backup

提高拷贝速度

scp  -c arcfour -r-P20755 dir/ 192.168.2.*:/**/**/data/

-c arcfour 这个算法没有加校验不保证完整性,注意慎用,内网1000M带宽,默认算法速度只能达到30M/s,用arcfour这个算法速度可以达到50-80M/s

SSH

连接远程

ssh username@remote_host

 

ssh -p port username@remote_host

执行命令

ssh username@remote_host 'cmd1; cmd2' > stdout.txt2>errors.txt

压缩功能

ssh -C user@hostname 'cmds'

打通ssh

1.创建SSH密钥

  ssh-keygen -t rsa

  公钥, ~/.ssh/id_rsa.pub

2.登陆远端服务器, 将公钥写入 ~/.ssh/authorized_keys

lsof

列出系统中开放端口及运行在端口上的服务

lsof -i

配合grep, 获取需要的信息

netstat

查看开放端口和服务

netstat -tnp

磁盘和系统

du

du = disk usage

估计文件的空间占用。逐层统计文件(例如以递归方式)并输出摘要。

查看占用磁盘空间

du FILENAME1 FILENAME2

查看目录

du -a dir

KB,MB或块为单位展示

du -h FILENAME1

显示总计情况

du -c FILENAME1

只显示合计

du -s FILENAME1

以特定单位打印

du -b/-k/-m/-B FILES

排除部分文件

du --exclude "*.txt" DIR

   --exclude-fromEXCLUDE.txt DIR

指定最深层级

du --max-depth 2 DIR

指定目录最大的10个文件

du -ak S_DIR | sort -nrk 1 | head

df

df = disk free

报告系统的磁盘使用情况。在跟踪磁盘使用情况方面对于普通用户和系统管理员都很有用。 ‘df‘ 通过检查目录大小工作,但这一数值仅当文件关闭时才得到更新。

查看磁盘可用空间

df

df -h

time

计算命令执行时间

time COMMAND

 

real 挂钟时间, 从开始执行到结束的时间

user 进程花费在用户模式中的cpu时间, 真正用于执行进程所花得时间

sys  进程花费在内核模式中的cpu时间

写入文件

time -o output.txt COMMAND

time -a output.txt COMMAND #追加

格式化输出

time -f "Time: %U" -a -o timing.log uname

real %e

user %U

sys %S

who

获取当前用户登陆信息

who / w

当前登陆主机的用户列表

users

uptime

查看系统已经通电运行多长时间了

uptime

#也可以看到负载

last

显示上次用户登录信息- 前一次启动会话信息

last

获取单个用户

last USER

watch

在终端中以固定间隔监视命令输出

#default 2s

watch ls

 

# 5s

watch -n 5 ls

颜色标示

watch -d 'COMMAND'

进程和线程

ps

ps命令给出正在运行的某个进程的状态,每个进程有特定的id成为PID

ps命令主要查看系统中进程的状态

USER             PID  %CPU %MEM      VSZ   RSS   TT  STAT STARTED      TIME COMMAND

USER表示启动进程用户

PID表示进程标志号

 

%CPU表示运行该进程占用CPU的时间与该进程总的运行时间的比例

%MEM表示该进程占用内存和总内存的比例。

 

VSZ表示占用的虚拟内存大小,以KB为单位。

RSS为进程占用的物理内存值,以KB为单位。

 

TTY表示该进程建立时所对应的终端,"?"表示该进程不占用终端。

STAT表示进程的运行状态,包括以下几种代码:

    D,不可中断的睡眠;

    R,就绪(在可运行队列中);

    S,睡眠;

    T,被跟踪或停止;

    Z,终止(僵死)的进程,Z不存在,但暂时无法消除;

    W,没有足够的内存分页可分配;<高优先序的进程;

    N,低优先序的进程;

    L,有内存分页分配并锁在内存体内(实时系统或I/O)。

 

START为进程开始时间。

TIME为执行的时间。

COMMAND是对应的命令名。

查看进程信息

#当前终端

ps

 

PID TTY TIME CMD

PID  进程ID

TTY  终端

TIME 进程启动后过去的时间

CMD  进程对应的命令

显示更多信息

#当前终端

ps -f

查看所有进程

ps aux

ps -ef

查看某个用户的所有进程

ps U ken

命令格式

ps[OTHEROPTIONS]-opar1,par2,par3

ps-eocomm,pcpu|head

pmem内存使用率,comm可执行文件名,user启动进程的用户,etime启动后度过的时间

设置升序降序

ps -eo comm,pcpu --sort -pcpu | head

+升序,-降序

找出给定命令名对应进程ID

ps -C COMMAND_NAME

ps -C bash -o pid=

进程线程相关

ps -eLf --sort -nlwp | head

查看子进程树

ps axwef

注意:当你要知道有哪些进程在运行或者需要知道想杀死的进程PIDps命令很管用。你可以把它与‘grep‘合用来查询指定的输出结果,例如:

# ps -A | grep -i ssh

pgrep

pgrep只需要命令名的一部分, ps需要准确的全名

基本用法

pgrep bash

指定进程的用户

pgrep -u root,slynux COMMAND

返回匹配进程数

pgrep -c COMANND

top

查看占用cpu最多的进程列表

top

kill

kill是用来杀死已经无关紧要或者没有响应的进程,杀死一个进程需要知道进程的PID

列出可用信号

kill -l

终止一个进程

kill PROCESS_ID_LIST

强杀进程

kill -9 PROCESS_ID

杀死一组命令

killall process_name

killall -9 process_name

 

指定用户

killall -u USERNAME process_name

pkill

杀,接受进程名

pkill process_name

pkill -s SIGNAL process_name

which

查找PATH下某个命令位置

which ls

whereis

whereis的作用是用来定位命令的二进制文件\资源\或者帮助页.举例来说,获得lskill命令的二进制文件/资源以及帮助页:

whereis ls

whereis kill

类似which,多了命令手册位置,源代码位置

注意:当需要知道二进制文件保存位置时有用.

file

确定文件类型

whatis

对命令的简短描述

hostname

当前主机名

uname

主机名

uname -n

 

#内核版本,硬件架构等

uname -a

 

#内核发行版本

uname -r

 

主机类型(32/64)

uname -m

 

cpu相关信息

cat /proc/cpuinfo

 

内存信息

cat /proc/meminfo

例子

#uname -a

Linux tecmint 3.8.0-19-generic #30-Ubuntu SMP Wed May 116:36:13 UTC 2013 i686 i686 i686 GNU/Linux

 

1. “Linux“: 机器的内核名

2. “tecmint“: 机器的分支名

3. “3.8.0-19-generic“: 内核发布版本

4. “#30-Ubuntu SMP“: 内核版本

5. “i686“: 处理器架构

6. “GNU/Linux“: 操作系统名

crontab

格式

* * * * * cmd

分钟(0-59),小时(0-23),天(1-31),月份(1-12),工作日(0-6)

 

A,B  A and B

*/C  every C

查看

crontab -l

crontab -l -u slynux

编辑

crontab -e

移除

crontab -r

crontab -u slynux -r

可以在crontab 中加入环境变量

getopts

命令行参数处理

while getopts :f:vql opt

do

    case $opt in

    f)  file=$OPTARG

        ;;

    v)  verbose=true

        ;;

    ....

history

“history”命令就是历史记录。它显示了在终端中所执行过的所有命令的历史

history

注意:按住“CTRL + R”就可以搜索已经执行过的命令,它可以你写命令时自动补全

sudo

“sudo”(super user do)命令允许授权用户执行超级用户或者其它用户的命令。通过在sudoers列表的安全策略来指定。

注意:sudo 允许用户借用超级用户的权限,然而”su”命令实际上是允许用户以超级用户登录。所以sudosu更安全。
并不建议使用sudo或者su来处理日常用途,因为它可能导致严重的错误如果你意外的做错了事,这就是为什么在linux社区流行一句话:

“To err is human, but to really foul up everything, you needroot password.”
人非圣贤孰能无过,但是拥有root密码就真的万劫不复了。

cal

“cal”Calender),它用来显示当前月份或者未来或者过去任何年份中的月份

cal

cal 02 1835

cp

“copy”就是复制。它会从一个地方复制一个文件到另外一个地方

cp file1 file2

cp -r dir1 dir2

快速备份一个文件:

cp some_file_name{,.bkp}

注意: cp,在shell脚本中是最常用的一个命令,而且它可以使用通配符(在前面一块中有所描述),来定制所需的文件的复制。

mv

“mv”命令将一个地方的文件移动到另外一个地方去。

“mv”命令将一个地方的文件移动到另外一个地方去。

pwd

“pwd”printworking directory),在终端中显示当前工作目录的全路径。

注意:这个命令并不会在脚本中经常使用,但是对于新手,当从连接到nux很久后在终端中迷失了路径,这绝对是救命稻草。

free

free -m

             total       used       free    shared    buffers     cached

Mem:          7982       6811       1171          0        350       5114

-/+ buffers/cache:      1346       6636

Swap:        16935         11     16924

显示剩余内存

free -m | grep cache | awk '/[0-9]/{ print $4" MB"}'

在这里例子中,应用程序只使用了1346MB内存,还有6636MB空闲内存可以使用.

一些简单的计算方法:

物理已用内存 = 实际已用内存 - 缓冲 - 缓存 = 6811M - 350M - 5114M

物理空闲内存 = 总物理内存 - 实际已用内存 + 缓冲 + 缓存

应用程序可用空闲内存 = 总物理内存 - 实际已用内存

应用程序已用内存 = 实际已用内存 - 缓冲 - 缓存

原始解释:转至互联网:
Linux
的基本原则是没有资源应该被浪费.因此核心会使用尽可能多的RAM,来缓存来自本地和远程的文件系统的信息.系统做读写操作的时候,会将与当前运行的进程相关的数据尽量存储在RAM.系统报告的缓存是缓冲和页缓存两者之和.缓存并不是在进程结束的时候被回收(你可能很快会启动另外一个进程,需要同样的数据),而是随需回收比如,当你启动一个需要大量内存的进程时,Linux核心会从内存中回收缓存,将得到的内存分配给新的进程.

有些区域,比如匿名内存映射(mmps)和共享内存区域,它们被报告为缓存,但不是被核心直接释放.一般的缓存不映射到进程的地址空间,仅仅是简单的核心映射,而这些特别的缓存映射到所有挂接到它们上面的进程.

eval

eval "ls -l"

basename

获取路径中文件部分

basename resolv.conf #resolv.conf

basename /etc/resolv.conf # resolv.conf

cmp

比较两个任意类型的文件并将结果输出至标准输出。如果两个文件相同, ‘cmp‘默认返回0;如果不同,将显示不同的字节数和第一处不同的位置。

cmp file1 file2

diff file1 file2

rm

‘rm’ 标准移除命令。rm 可以用来删除文件和目录

rm file1

rm -r dir1  #递归删除空目录

强删

rm -rf fileordir

警告: ”rm -rf” 命令是一个破坏性的命令,假如你不小心删除一个错误的目录。
一旦你使用’rm -rf’ 删除一个目录,在目录中所有的文件包括目录本身会被永久的删除,所以使用这个命令要非常小心。

service

‘service‘命令控制服务的启动、停止和重启,它让你能够不重启整个系统就可以让配置生效以开启、停止或者重启某个服务。

注意:要想使用service命令,进程的脚本必须放在‘/etc/init.d‘,并且路径必须在指定的位置。
如果要运行“service apache2 start”实际上实在执行“service /etc/init.d/apache2 start”.

man

‘man‘是系统帮助页。Man提供命令所有选项及用法的在线文档。几乎所有的命令都有它们的帮助页

man thecommand

注意:系统帮助页是为了命令的使用和学习而设计的。

passwd

这是一个很重要的命令,在终端中用来改变自己密码很有用。显然的,因为安全的原因,你需要知道当前的密码。

gcc

gcc Linux环境下C语言的内建编译器。下面是一个简单的C程序,在桌面上保存为Hello.c (记住必须要有‘.c‘扩展名

gcc Hello.c

./a.out

gcc -o Hello Hello.c

./Hello

注意: 编译C程序时,输出会自动保存到一个名为“a.out”的新文件,因此每次编译C程序 “a.out”都会被修改。
因此编译期间最好定义输出文件名.,这样就不会有覆盖输出文件的风险了。

g++

g++C++的内建编译器

g++ Add.cpp

./a.out

g++ -o Add Add.cpp

./Add

java

Java 是世界上使用最广泛的编程语言之一. 它也被认为是高效,安全和可靠的编程语言. 现在大多数基于网络的服务都使用Java实现.

javac tecmint.java

java tecmint

注意: 几乎所有的Linux发行版都带有gcc编译器, 大多数发行版都内建了g++ java 编译器, 有些也可能没有. 你可以用apt yum 安装需要的包.

关于/dev/null

特别有用的特殊文件,位桶,传送到此文件的数据都会被系统丢弃。

语言及乱码

查看变量值

echo $LANG   未设置任何LC_XXX时使用的默认值

echo $LC_ALL覆盖所有LC_XXX变量,总控开关

好的做法是,避免为任何LC_XXX变量赋值,使用LC_ALLLANG来控制

避免乱码:从编辑器到语言,再到系统,统一编码为UTF-8

shell的版本

bash --version

 

你可能感兴趣的:(liunx相关)