由于Linux的指令非常多,不同的目的使用Linux的人所接触到的常用指令都不同。我把我经常遇到的指令写在本文章中,方查阅。
ctrl + l #清屏
ctrl + c #停止进程
ctrl + r #搜索历史记录
man #帮助命令
tab #自动补全
pwd #显示当前目录
cd #切换到当前用户目录,如root到/root,普通用户到/home/[username]
cd .. #返回上层目录
cd path #切换到path目录下,完整应该是cd ./path,因为是切换到同级目录path
cd /path #切换到指定 /path路径
ls #显示当前目录下文件
ls -l #列出文件详细属性
ls -a #列出全部文件包括隐藏文件
注意附加参数还有很多,可以man ls来查询。此外,这些参数也可以组合使用,比如说
ls -la
ll #等同于ls -l的效果
touch用于创建空文件,mkdir用于创建目录
该命令用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的,所以这个命令对我们来说就很有用了
复制文件,copy,它还可以把多个文件一次性地复制到一个目录下,它的常用参数如下:
-a :将文件的特性一起复制
-p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份
-i :若目标文件已经存在时,在覆盖时会先询问操作的进行
-r :递归持续复制,用于目录的复制行为
-u :目标文件与源文件有差异时才会复制
cp -a f1 f2 #连同文件的所有特性把文件f1复制成文件f2
cp f1 f2 f3 dir #把文件f123复制到目录dir中
该命令用于移动文件、目录或更名,move,它的常用参数如下:
-f :force强制,如果目标文件已经存在,不会询问而直接覆盖
-i :若目标文件已经存在,就会询问是否覆盖
-u :若目标文件已经存在,且比目标文件新,才会更新
mv f1 f2 f3 dir # 把文件f1、f2、f3移动到目录dir中
mv f1 f2 # 把文件file1重命名为file2
该命令用于删除文件或目录,remove,它的常用参数如下:
-f :force,忽略不存在的文件,不会出现警告消息
-i :在删除前会询问用户是否操作
-r :递归删除,最常用于目录删除,它是一个非常危险的参数
rm -i file # 删除文件file,在删除之前会询问是否进行该操作
rm -fr dir # 强制删除目录dir中的所有文件
查看文件的内容
cat filename
分页显示文本内容
head、tail查看文本中开头或结尾部分的内容
haed -n 5 a.log #查看a.log文件的前5行
tail b.log #读取后默认10行内容
在文件系统中查找指定的文件
find [PATH] [option] [action]
find /etc/ -name "aaa"
-mtime n : n为数字,意思为在n天之前的“一天内”被更改过的文件;
-mtime +n : 列出在n天之前(不含n天本身)被更改过的文件名;
-mtime -n : 列出在n天之内(含n天本身)被更改过的文件名;
-newer file : 列出比file还要新的文件名
find /root -mtime 0 # 在当前目录下查找今天之内有改动的文件
-user name : 列出文件所有者为name的文件
-group name : 列出文件所属用户组为name的文件
-uid n : 列出文件所有者为用户ID为n的文件
-gid n : 列出文件所属用户组为用户组ID为n的文件
find /home/ljianhui -user ljianhui
# 在目录/home/ljianhui中找出所有者为ljianhui的文件
-name filename :找出文件名为filename的文件
-size [+-]SIZE :找出比SIZE还要大(+)或小(-)的文件
-tpye TYPE :查找文件的类型为TYPE的文件,一般文件(f)、设备文件(b、c)、目录(d)、连接文件(l)、socket(s)、FIFO管道文件(p);
-perm mode :查找文件权限刚好等于mode的文件,mode用数字表示,如0755;
-perm -mode :查找文件权限必须要全部包括mode权限的文件,mode用数字表示
-perm +mode :查找文件权限包含任一mode的权限的文件,mode用数字表示
find / -name passwd # 查找文件名为passwd的文件
find . -perm 0755 # 查找当前目录中文件权限的0755的文件
该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等,它的简单语法为
grep [-acinv] [--color=auto] '查找字符串' filename
它的常用参数如下:
-a :将binary文件以text文件的方式查找数据
-c :计算找到‘查找字符串’的次数
-i :忽略大小写的区别,即把大小写视为相同
-v :反向选择,即显示出没有‘查找字符串’内容的那一行
# 取出文件/etc/man.config中包含MANPATH的行,并把找到的关键字加上颜色
grep --color=auto 'MANPATH' /etc/man.config
# 把ls -l的输出中包含字母file(不区分大小写)的内容输出
ls -l | grep -i file
该命令用于将某个时间点的进程运行情况选取下来并输出,process,它的常用参数如下:
-A :所有的进程均显示出来
-a :不与terminal有关的所有进程
-u :有效用户的相关进程
-x :一般与a参数一起使用,可列出较完整的信息
-l :较长,较详细地将PID的信息列出
一般使用的命令参数:
ps aux # 查看系统所有的进程数据
ps ax # 查看不与terminal有关的所有进程
ps -lA # 查看系统所有的进程数据
ps axjf # 查看连同一部分进程树状态
该命令用于向某个工作(%jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用,它的基本语法如下:
kill -signal PID
signal的常用参数如下:
注:最前面的数字为信号的代号,使用时可以用代号代替相应的信号。
1:SIGHUP,启动被终止的进程
2:SIGINT,相当于输入ctrl+c,中断一个程序的进行
9:SIGKILL,强制中断一个进程的进行
15:SIGTERM,以正常的结束进程方式来终止进程
17:SIGSTOP,相当于输入ctrl+z,暂停一个进程的进行
例如:
# 以正常的结束进程方式来终于第一个后台工作,可用jobs命令查看后台中的第一个工作进程
kill -SIGTERM %1
# 重新改动进程ID为PID的进程,PID可用ps命令通过管道命令加上grep命令进行筛选获得
kill -SIGHUP PID
该命令用于向一个命令启动的进程发送一个信号,它的一般语法如下:
killall [-iIe] [command name]
它的参数如下:
-i :交互式的意思,若需要删除时,会询问用户
-e :表示后面接的command name要一致,但command name不能超过15个字符
-I :命令名称忽略大小写
# 例如:
killall -SIGHUP syslogd # 重新启动syslogd
该命令用于对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压。它的常用参数如下:
-c :新建打包文件
-t :查看打包文件的内容含有哪些文件名
-x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中
-j :通过bzip2的支持进行压缩/解压缩
-z :通过gzip的支持进行压缩/解压缩
-v :在压缩/解压缩过程中,将正在处理的文件名显示出来
-f filename :filename为要处理的文件
-C dir :指定压缩/解压缩的目录dir
压缩:tar -jcv -f filename 要被处理的文件或目录名称
查询:tar -jtv -f filename
解压:tar -jxv -f filename -C 欲解压缩的目录
该命令用于改变文件所属用户组
chgrp [-R] dirname/filename
-R :进行递归的持续对所有文件和子目录更改
# 例如:
chgrp users -R ./dir #递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users
该命令用于改变文件的所有者,与chgrp命令的使用方法相同
该命令用于改变文件的权限
chmod [-R] xyz 文件或目录
-R:进行递归的持续更改,即连同子目录下的所有文件都会更改
u(user)、g(group)、o(other)、a(all)和+(加入)、-(删除)、=(设置)跟rwx搭配来对文件的权限进行更改。
chmod 0755 file #把file的文件权限改变为-rxwr-xr-x
#7: 111 对应rwx
#5:101 对应r-x
chmod g+w file #向file的文件权限中加入用户组g可写w权限
http://www.cnblogs.com/ggjucheng/archive/2012/01/08/2316661.html
netstat 显示网络状态信息
-a 显示所有连接和监听端口
-t (tcp)仅显示tcp相关选项
-u (udp)仅显示udp相关选项
-n 拒绝显示别名,能显示数字的全部转化成数字。
-p 显示建立相关链接的程序名
-l 列出正在监听的套接字
在Linux中curl是一个利用URL规则在命令行下工作的文件传输工具,一款很强大的http命令行工具。它支持文件的上传和下载,是综合传输工具,习惯称url为下载工具。
详细地址
语法: curl [option] [url]
Linux wget是一个下载文件的工具,它用在命令行下。对于Linux用户是必不可少的工具,尤其对于网络管理员,经常要下载一些软件或从远程服务器恢复备份到本地服务器。如果我们使用虚拟主机,处理这样的事务我们只能先从远程服务器下载到我们电脑磁盘,然后再用ftp工具上传到服务器。这样既浪费时间又浪费精力,那不没办法的事。而到了Linux VPS,它则可以直接下载到服务器而不用经过上传这一步。wget工具体积小但功能完善,它支持断点下载功能,同时支持FTP和HTTP下载方式,支持代理服务器和设置起来方便简单。
详细介绍
linux强大的编辑器,它有一般模式、插入模式、底行模式。
基本用法:
vim filename #进入一般模式
i a o等 #进入插入模式
Esc #退出插入模式返回一般模式
: #进入底行模式,命令以回车结束返回一般模式
:wq #一般模式下这样保存并退出
/ 想查找的字符, 按n查找下一个
:q! 不保存强制退出
插入命令 | 作用 |
---|---|
i | 在光标前插入 |
I | 在光标当前行开始插入 |
a | 在光标后插入 |
A | 在光标当前行末尾插入 |
o | 在光标当前行的下一行插入新行 |
O | 在光标当前行的上一行插入新行 |
定位命令 | 作用 |
---|---|
:set nu | 显示行号 |
:set nonu | 取消行号 |
gg | 到文本的第一行 |
G | 到文本的最后一行 |
:n | 到文本的第n行 |
删除命令 | 作用 |
---|---|
x | 删除光标所在处字符 |
nx | 删除光标所在处后的n个字符 |
dd | 删除光标所在行。ndd删除n行 |
dG | 删除光标所在行到末尾行的所以内容 |
D | 删除光标所在处到行尾的内容 |
:n1,n2d | 删除指定范围的行 |
其余命令 | 作用 |
---|---|
u | undo取消上一步操作 |
Ctrl + r | 返回到undo之前 |
r | 替换光标所在处的字符 |
R | 从光标所在处开始替换,按Esc键结束 |
v | 进入字符可视模式 |
V | 或 Shift + v 进入行可视模式 |