您的位置:首页 > 运维架构 > Linux

Linux命令

2016-06-20 15:17 459 查看
ps -ef | grep:列出相关进程。

-u name:列出某个用户的进程。

top:查看某个或者某些进程信息。

-p +pid 某个进程

du -sh:当前文件夹的大小。

df -l:磁盘使用情况。

du -h:当前文件夹及以下的文件夹的使用情况。

quota:列出磁盘使用量

mkdir -p /root/test/test 这样可以现在root下新建/test目录,然后再在test下新建test目录。

tee:从标准输入设备读入数据,输出到标准输出设备,并保存为文件。

-append 不覆盖既有文件,添加到既有文件之后。

pwd | tee -append who.out

more:与cat命令类似,输出文件内容到屏幕,支持分页显示,空格显示下一个命令,q停止。

ls -l | more

more 2016.log

\cmd:临时取消alias,调用原始路径与命令。

cat:命令可以完整的显示整个文件,当文件较大时,会不方便。cat可以将两个文件合并为一个 car file1 file2 > file3

less:与more命令类似,支持上下键滚动屏幕。

sleep:延时命令的执行时间,sleep 1:延时1s

sleep 1s:延时1s

sleep 1m:延时1分钟

sleep 1h:延时一小时

wait
:等待进程号为n的进程结束,并报告它的结束状态,如果默认参数n,等待shell上的所以活动的后台进程结束

ctrl alt k表示linux和window下的程序切换锁定

alt tab切换应用程序

sort   -n按数值大小排序,小的排前边,

    -r按相反的顺序来排序,

统计当前文件夹下的文件个数:ls -l | grep "^-" | wc -l

统计当前文件夹下的目录个数:ls -l | grep "^d" | wc -l

sh命令是shell命令语言解释器,执行命令从标准输入读取或者从一个文件读取,然后执行。

  sh -c 表示从之后的字符串读取内容。 sh -c "echo $1"

xterm是图形界面下的一个virtual terminal的实现。

date +%s,显示当前时间,以秒为单位;

   +%N,显示当前ns;

cut -c num1-num2,以byte为单位,取其中的几个。

rename(原字符串,目标字符串,文件列表),只能对文件名进行替换,改变。

  rename main1.c main.c main1.c 将main1.c改名为main.c

  支持通配符,?随机一个字符,*随机很多字符。     

  假设有文件foo0,,,,,,,foo278;

    rename foo foo0 foo?,首先文件list是foo0-9,之后将这些文件的文件名中的foo改为foo0;

    rename foo foo0 foo??,首先文件list是foo0-278,之后将这些文件名中的foo改为foo0;

对正则表达式的使用,rename "s/AA/aa/" *,将当前文件里的所以文件名中的AA,改为aa

          rename "s/.html/.php/" *,将当前所有文件里的所有文件名中的,以.html结尾的文件名,改为以.php结尾。

chmod,设置权限,用户分为u:该user,g:该group,o:other

         操作有:r,w,x

    chmod ugo +r file 所有人都可读

    chmod u-w file 同组没有写操作

  chmod 777 表示所有用户都有读写执行权;

      755 表示只有该用户有读写权,同组有执行,读权利,其他只有执行权利。

xclip命令,在linux中,从一个窗口复制数据到另一个窗口,有两套机制,Selections和cut buffers,

  常用的copy&paste是利用的cut buffers的机制,

  鼠标选中文件中文字,在另一个窗口按鼠标中键实现复制,利用的是Selection机制,分为Master Selection,Slave Selection

xclip命令,可以不需要鼠标选中,来将数据搬运到Master Selection中,

  xclip -i /etc/passwd 之后鼠标中键,粘贴就可以

ENV显示当前terminal中的环境变量,

环境变量USER,GROUP,HOST,REMOTEHOST,DISPLAY,TERM,OSTYPE,MACHTYPE,

wget是一个从网络上自动下载文件的自由工具,支持http,https,ftp协议。可以使用http代理。

wget支持用户退出系统之后的后台执行,常见用法:wget -P download url 下载文件放在download文件夹中。

ls命令使用:

ls -a:列出文件夹下所有的文件

ls -l:列出文件的详细信息

ls -t:按时间进行文件的排序

ls -s:在文件后加上文件的大小

ls -L:列出文件的连接名

ls -S:以文件的大小进行排序

ls | less:实现文件列表的分页

  ls -i:在文件前加入inode编号

  ls -1:只在一列中显示文件

  ls --color=always:颜色显示

也可以组合显示:ls -atrl,表示按逆序显示目录下的文件显示格式

linux终端显示颜色的控制,与具体的语言没有关系,只要加相应的颜色转义字符打印在终端上,就可以改变终端默认的黑色显示。

转义字符以‘ESC’和[ 开始,'ESC',一般由八进制或16进制,通过asiic来表示,十进制 27,十六进制0x1B,八进制033,

  所以可以写成 \033[ 开始和 结束, %c[ 开始和结束, 之后的参数化打印选择1bH,033O,或者27D。

  控制颜色显示的数字,Param1;Param2 m。m表示该参数结束。

  Param1,显示方式,0--默认,1--粗体,高亮,4--单条下划线,5--闪烁,

  Param2,前景色,数字30+颜色值 表示,0--黑,1--红,2--绿,3--黄,4--蓝,6--青,7--白

  Param3,背景色。数字40+颜色值 表示。

命令 \033[显示方式 Param1;前景色 Param2; 背景色 Param3 m

     “输出字符串”

   \033[显示方式 Param1;前景色 Param2; 背景色 Param3 m

一般的结束都是改为默认色,\033[0m

linux打开pdf,evince/acroread

寻找help信息,

1):cmd --help

2):man cmd

3):whatis cmd等同于man -f

4):info cmd 详细显示cmd信息

xargs命令:给命令传递参数的一个过滤器。用在很多不支持管道传递参数的命令中。

能够捕获一个命令的输出,然后传递给另外一个命令。

     xargs的默认命令是echo,空格是默认定界符

-I 将xargs的每一项,一行一行的赋值给{},

find ./* -name "*abc*" -type -d | xargs -I {} rm -rf {}

-a file 从文件中读入数据。

     -t 先打印命令,在执行

捕获的是标准输入的数据,管道捕获的是程序输出的结果

echo "--help" | cat

echo "--help" | xargs cat, 输出的是help的信息

-exec命令,与xargs命令类似,但是-exec的参数是一个一个传递的,传递一次就执行一次命令

    find ./ -iname "*.txt" -exec rm {} \; 之后的\;必须添加,rm命令会被执行很多次。

xargs命令,可以通过-n +num的形式来控制,每次传递的参数的个数。

ln命令:link功能,将同一个文件在不同的目录中建立link关系

ln [命令参数] [源文件目录] [目标文件目录]

-f force执行, -s 软链接

软链接类似win中的快捷操作;

硬链接类似文件副本的形式保存,但是并不占内存

echo -n 输出不加换行符。 echo -n "123"; echo "456" 最终输出123456。

echo -e 可以识别特殊字符。 echo -e "\n1234" 输出换行1234。

hostname:服务器名字;

whoami:用户名;

last -n +number:最后登录的几个用户名;

head -n <行数> 文件,输出文件的开头至标准输出中;

tail -n <行数> 文件,输出文件的结尾至标准输出中;

linux快捷键操作:

F11最大化当前terminal;

ctrl 0正常化大小的terminal;

ctrl+page up/down,在一个terminal中切换tab;

ctrl+shift+t,在一个terminal中新建tab;

ctrl+alt+t,新建一个terminal;

sed:Stream Editor,流式编辑器,一次处理一行内容,把当前处理行的内容放在临时缓冲区,称为"模式空间"(pattern space)

接着用sed命令处理缓冲区的内容,处理完成后,将缓冲区的内容送到屏幕,如此重复,直到文件结束。

sed主要用来自动编辑一个或多个文件,简化对文件的反复操作,编写转换程序。本身就是一个管道命令,可以将数据进行替换,删除,

新增,选取等工作,

sed定址,通过定址来定位希望编辑的行,用数字($/正则表达式)构成,以逗号分隔的两个行数,表示行的起始范围。

sed命令的两种方式: sed [options] 'command' files

sed [options] -f scriptfile files

常用选项:-n silent模式,本来所有来自STDIN的资料都会列出到屏幕上,加上-n之后,只有经过sed处理的那一行才输出到STDOUT。

-f filename,直接执行filename中的sed命令。

-i 直接修改缓冲区内的内容,不由屏幕输出。

-e 进行多行编辑时,使用

# sed -e '1,10d' -e 's/My/Your/g' datafile 使用-e第一个执行结束,更新缓冲区内的行,之后第二个命令执行,所以顺序影响之后的结果。

常用命令:a+string 新增,这些string加在新的一行中。

c+string 取代,string直接取代n1,n2之间的行。

d 删除,删除执行地址内的内容。

i+string 插入,这些string插在指定行之前。

p 输出,将选中的内容输出,通常与-n选项一同运行。

s 取代,搭配正在表达式来使用。

# sed '1d' ab 删除第一行。

# sed '$d' ab 删除最后一行。

# sed '1,2d' ab 删除第一行到第二行。

# sed '2,$d' ab 删除第二行到最后一行。

# sed -n '1p' ab 显示第一行。

# sed -n '$p' ab 显示最后一行。

# sed -n '1,2p' ab 显示第一行到第二行。

# sed -n '/ruby/p' ab 查询ruby所在行,并显示出来。

# sed -n '/\$/p' ab 查询$所在行,并显示出来。

append操作只会增加新行,要在行尾增加字符,只能用s/$/string/

# sed '1a drink tea' ab 第一行后,增加字符串"drink tea"

# sed '1a drink tea \n or coffeee' ab 第一行之后,新增两行。

# sed '$a bye' ab 新增最后一行。

# sed '1c Hi' ab 第一行替代为Hi

# sed '1,2c Hi' ab 第一行到第二行替代为Hi

# sed -n '/ruby/p' ab | sed 's/ruby/bird/g' 替换ruby为bird

# sed -n '/ruby/p' ab | sed 's/ruby//g' 删除所有ruby

awk:一种编程语言,对文本和数据进行处理,可以在命令行中使用,也可以在script中使用。

以文件中的一行为处理单元,awk每次接收文件中的一行,执行相应操作,再处理下一行。

语法形式:awk [options] 'script' var=value file

awk [options] -f scriptfile var=value file

常用命令选项:-F 指定输入分隔符,

-f scriptfile 从脚本文件中读取awk命令,

基本结构:awk 'BEGIN {} pattern {command} END {}' file,BEGIN语句块,模式匹配的通用语句块,END语句块

首先执行BEGIN语句块,逐行扫描文件,执行pattern {command},直到文件结束,最后执行END {command}操作。

cat /etc/passwd | awk -F ':' '{print $1"\t"$7}' 读入有\n换行符的一条记录,按指定的域分隔符划分域,$0表示所有域,$n表示第n个域,

awk默认的分割符是空格,print是awk内的命令

正则表达式:grep/sed/awk/gvim中都会遇到的匹配模式。

1:字符集,[]表示,[\d]表示所有数字,[\s]表示任意空白符,\h\v水平和垂直空白符,[\w]匹配word,[\R]断行符

反义简写,[^]或者大写,[\D],[\W]等。

2:锚,^行首,$行尾,\A字符串首,\z字符串尾,字符串可以分为多行,所以行首比字符串首更多。

再匹配后加/m可以将^/$变为串首/串尾。

3:修饰符: *匹配零次或多次前一字符。

+匹配一次或多次前一字符。

?匹配零次或一次前边的字符,一般用在匹配单个字符。

.匹配任意字符,除了换行符。

\<\>匹配单词边界。

\n 第n个捕获变量的值。

\{\} 前边正则表达式匹配的次数。

| 择一匹配。

gvim中的查找命令的匹配: 1:字符集,[]表示,

2:锚,^行首,$行尾,\A字符串首,\z字符串尾,字符串可以分为多行,所以行首比字符串首更多。

再匹配后加/m可以将^/$变为串首/串尾。

3:修饰符: *匹配零次或多次前一字符。

+匹配一次或多次前一字符。

?匹配零次或一次前边的字符,一般用在匹配单个字符。(需要反义字符\)

. 匹配任意字符,除了换行符。

\<\>匹配单词边界。

\n 第n个捕获变量的值。

\{} 前边正则表达式匹配的次数。

| 择一匹配。

grep命令中的匹配,与正则表达式中的查找相同。

*表示匹配任意个前一字符;

. 表示匹配一个非换行的任意字符;

\<表示匹配一个单词的首字符;

\>表示匹配一个单词的末尾字符;

[]表示匹配一个指定范围内的字符;

nl:将文件中的内容输出,并自动加上行号。

nl log2012.log

输出:1 2012-1

2 2012 -2

shell中的一些快捷键:

ctrl + a,跳转到命令行首

ctrl + e,跳转到命令行尾

ctrl + f,向前跳转一个字符

ctrl + b,向后跳转一个字符

alt + f,向前跳转到一个字的第一个字符

alt + b,向后跳转到一个字的第一个字符

ctrl+w,删除当前光标之前的字符

ctrl+k,删除当前光标之后的字符

ctrl+u,删除shell中的命令字符

ctrl+d,删除当前位置字符

alt+d,删除光标所在字

ctrl+y,粘帖最后一个被删除的字

  !?string?:p,向前搜索命令中包含的字符,加p只打印,不支持

  通过history打开命令之后,可以通过!+num的形式,再次执行

  !$可以将上一次命令的输入参数传递给这次的命令

  !*表示上一次命令的所有输入参数,!cmd:num表示上一次命令的第几个参数, !cp:2 上一次cp命令的第二个参数

  !!表示最近一次执行的命令

!(file),表示不对文件做接下来的访问,rm !(*.pdf) 删除除了pdf之外的文件

terminal提示符的设置:

alias setprmp "set prompt = "%B%m%3c%b""

alias cd cd ; setprmp; ls

%B开始粗体模式,%b结束粗体模式

%nc,显示当前目录的后n个组成部分,%m机器名称,%t12进制表示时间,%n用户名

其他还可以设置颜色等

linux中path的设置:

1)通过IBM的module load工具,自动加载tools,自动更新相应的bin到PATH变量中。

2)手动添加bin到PATH变量中,以":"为间隔

module load/add 添加tools,module unload/rm 移除tools

module list显示目前加载的tools,module av显示目前系统中加载的tools

在 gnome-terminal 的菜单栏中选 "Edit" -] "Keyboard Shortcuts ..."打开 "Keyboard Shortcuts" 对话框,并勾选下面两个复选项

"Disable all menu access keys (such as Alt+f to open File menu)"

"Disable menu shortcut key (F10 by default)"
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: