linux 常用命令2

ls
 
常用参数
 
-l :列出长数据串,包含文件的属性与权限数据等
 
-a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)
 
-d :仅列出目录本身,而不是列出目录的文件数据
 
-h :将文件容量以较易读的方式(GB,kB等)列出来
 
-R :连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来
 
注:这些参数也可以组合使用,下面举两个例子:
 
ls -l #以长数据串的形式列出当前目录下的数据文件和目录
 
ls -lR #以长数据串的形式列出当前目录下的所有文件
 
grep
 
该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等
 
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
 
wc
 
wc(word count)功能为统计指定的文件中字节数、字数、行数,并将统计结果输出
 
命令格式:
 
wc [option] file..
 
命令参数:
 
-c 统计字节数
 
-l 统计行数
 
-m 统计字符数
 
-w 统计词数,一个字被定义为由空白、跳格或换行字符分隔的字符串
 
实例:
 
(1)查找文件的 行数 单词数 字节数 文件名
 
wc text.txt
 
结果:7 8 70 test.txt
 
(2)统计输出结果的行数
 
cat test.txt | wc -l
 
find
 
find是一个基于查找的功能非常强大的命令:
 
find [PATH] [option] [action]
 
与时间有关的参数:
 
-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/test -user tom # 在目录/home/test中找出所有者为tom的文件
 
与文件权限及名称有关的参数:
 
-name filename :找出文件名为filename的文件
 
-size [+-]SIZE :找出比SIZE还要大(+)或小(-)的文件
 
-tpye TYPE :查找文件的类型为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
 
find . -perm 0755 # 查找当前目录中文件权限的0755的文件
 
find . -size +12k # 查找当前目录中大于12KB的文件,注意c表示byte
 
cp
 
该命令用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下,常用参数:
 
-a :将文件的特性一起复制
 
-p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份
 
-i :若目标文件已经存在时,在覆盖时会先询问操作的进行
 
-r :递归持续复制,用于目录的复制行为
 
-u :目标文件与源文件有差异时才会复制
 
例如
 
cp -a file1 file2 #连同文件的所有特性把文件file1复制成文件file2
 
cp file1 file2 file3 dir #把文件file1、file2、file3复制到目录dir中
 
scp
 
常用于不同机器之间传文件和目录
 
scp [可选参数] file_source file_target
 
从 本地 复制到 远程
 
命令格式:
 
scp local_file remote_username@remote_ip:remote_folder
 
scp local_file remote_ip:remote_folder
 
第1,2个指定了用户名,命令执行后需要再输入密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名;
 
第3,4个没有指定用户名,命令执行后需要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名;
 
例子:
 
scp /home/space/music/1.mp3 root@www.test.com:/home/root/others/music
 
scp /home/space/music/1.mp3 www.test.com:/home/root/others/music
 
复制目录:
 
scp -r local_folder remote_username@remote_ip:remote_folder
 
scp -r local_folder remote_ip:remote_folder
 
scp -r /home/space/music/ root@www.test.com:/home/root/others/
 
scp -r /home/space/music/ www.test.com:/home/root/others/
 
从 远程 复制到 本地,只要将 从 本地 复制到 远程 的命令 的 后2个参数 调换顺序 即可;
 
例如:
 
scp root@www.test.com:/home/root/others/music /home/space/music/1.mp3
 
scp -r www.test.com:/home/root/others/ /home/space/music/
 
参数 :
 
-v 用来显示进度 . 可以用来查看连接 , 认证 , 或是配置错误 .
 
-C 使能压缩选项 .
 
-P 选择端口 . 注意 -p 已经被 rcp 使用 .
 
-4 强行使用 IPV4 地址 .
 
-6 强行使用 IPV6 地址 .
 
注意两点:
 
1.如果远程服务器防火墙有特殊限制,scp便要走特殊端口:
 
scp -p 9997 remote@www.test.com:/usr/local/sin.sh /home/tom
 
2.使用scp要注意所使用的用户是否具有可读取远程服务器相应文件的权限。
 
mv
 
该命令用于移动文件、目录或更名,move之意,它的常用参数如下:
 
-f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖
 
-i :若目标文件已经存在,就会询问是否覆盖
 
-u :若目标文件已经存在,且比目标文件新,才会更新
 
注:该命令可以把一个文件或多个文件一次移动一个文件夹中,但是最后一个目标文件一定要是“目录”。
 
例如:
 
mv file1 file2 file3 dir # 把文件file1、file2、file3移动到目录dir中
 
mv file1 file2 # 把文件file1重命名为file2
 
rm
 
该命令用于删除文件或目录,remove之间,常用参数如下:
 
-f :就是force的意思,忽略不存在的文件,不会出现警告消息
 
-i :互动模式,在删除前会询问用户是否操作
 
-r :递归删除,最常用于目录删除,它是一个非常危险的参数
 
例如:
 
rm -i file # 删除文件file,在删除之前会询问是否进行该操作
 
rm -fr dir # 强制删除目录dir中的所有文件
 
ps
 
该命令用于将某个时间点的进程运行情况选取下来并输出,process之意,它的常用参数如下:
 
-A :所有的进程均显示出来
 
-a :不与terminal有关的所有进程
 
-u :有效用户的相关进程
 
-x :一般与a参数一起使用,可列出较完整的信息
 
-l :较长,较详细地将PID的信息列出
 
其实我们只要记住ps一般使用的命令参数搭配即可,它们并不多,如下:
 
ps aux # 查看系统所有的进程数据
 
ps ax # 查看不与terminal有关的所有进程
 
ps -lA # 查看系统所有的进程数据
 
ps axjf # 查看连同一部分进程树状态
 
kill
 
该命令用于向某个工作(%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
 
该命令用于向一个命令启动的进程发送一个信号,它的一般语法如下:
 
killall [-iIe] [command name]
 
它的参数如下:
 
-i :交互式的意思,若需要删除时,会询问用户
 
-e :表示后面接的command name要一致,但command name不能超过15个字符
 
-I :命令名称忽略大小写
 
例如:
 
killall -SIGHUP syslogd # 重新启动syslogd
 
tar
 
该命令用于对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压。它的常用参数如下:
 
-c :新建打包文件
 
-t :查看打包文件的内容含有哪些文件名
 
-x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中
 
-j :通过bzip2的支持进行压缩/解压缩
 
-z :通过gzip的支持进行压缩/解压缩
 
-v :在压缩/解压缩过程中,将正在处理的文件名显示出来
 
-f filename :filename为要处理的文件
 
-C dir :指定压缩/解压缩的目录dir
 
常用命令前两条
 
压缩:tar -zcvf /tmp/etc.tar.gz /etc  <==打包后,以 gzip 压缩
 
解压:tar -zxvf /tmp/etc.tar.gz 欲解压缩的目录
 
查询:tar -ztvf /tmp/etc.tar.gz
 
打包:tar -cvf /tmp/etc.tar /etc    <==仅打包,不压缩!
 
cat
 
该命令用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用,从而可以一页页地查看数据。例如:
 
cat text | less # 查看text文件中的内容
 
注:这条命令也可以使用less text来代替
 
chgrp
 
该命令用于改变文件所属用户组,它的使用非常简单,它的基本用法如下:
 
chgrp [-R] dirname/filename
 
-R :进行递归的持续对所有文件和子目录更改
 
例如:
 
chgrp users -R ./dir # 递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users
 
chown
 
该命令用于改变文件的所有者
 
chown [选项]… [所有者][:[组]] 文件…
 
必要参数:
 
-c 显示更改的部分的信息
 
-f 忽略错误信息
 
-h 修复符号链接
 
-R 处理指定目录以及其子目录下的所有文件
 
-v 显示详细的处理信息
 
chown mail:mail log2016.log
 
groups
 
查看当前登录用户的组内成员
 
groups
 
groups root 查看root组的用户
 
whoami 查看当前用户名
 
/etc/group文件包含所有组
 
/etc/shadow和/etc/passwd系统存在的所有用户名
 
chmod
 
该命令用于改变文件的权限,一般的用法如下:
 
chmod [-R] xyz 文件或目录
 
-R:进行递归的持续更改,即连同子目录下的所有文件都会更改
 
同时,chmod还可以使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(删除)、=(设置)跟rwx搭配来对文件的权限进行更改
 
例如:
 
chmod 0755 file # 把file的文件权限改变为-rxwr-xr-x
 
chmod g+w file # 向file的文件权限中加入用户组可写权限
 
df
 
显示磁盘空间使用情况。获取硬盘被占用了多少空间,目前还剩下多少空间等信息
 
-a 全部文件系统列表
 
-h 以方便阅读的方式显示信息
 
-i 显示inode信息
 
-k 区块为1024字节
 
-l 只显示本地磁盘
 
-T 列出文件系统类型
 
df -haT
 
du
 
-a 显示目录中所有文件大小
 
-k 以KB为单位显示文件大小
 
-m 以MB为单位显示文件大小
 
-g 以GB为单位显示文件大小
 
-h 以易读方式显示文件大小
 
-s 仅显示总计
 
-c或--total 除了显示个别目录或文件的大小外,同时也显示所有目录或文件的总和
 
du -ah filedir/
 
ln
 
功能是为文件在另外一个位置建立一个同步的链接,当在不同目录需要该问题时,就不需要为每一个目录创建同样的文件,通过ln创建的链接(link)减少磁盘占用量。
 
链接分类:软件链接及硬链接
 
软链接:
 
1.软链接,以路径的形式存在。类似于Windows操作系统中的快捷方式
 
2.软链接可以 跨文件系统 ,硬链接不可以
 
3.软链接可以对一个不存在的文件名进行链接
 
4.软链接可以对目录进行链接
 
硬链接:
 
1.硬链接,以文件副本的形式存在。但不占用实际空间。
 
2.不允许给目录创建硬链接
 
3.硬链接只有在同一个文件系统中才能创建
 
需要注意:
 
第一:ln命令会保持每一处链接文件的同步性,也就是说,不论你改动了哪一处,其它的文件都会发生相同的变化;
 
第二:ln的链接又分软链接和硬链接两种,软链接就是ln –s 源文件 目标文件,它只会在你选定的位置上生成一个文件的镜像,不会占用磁盘空间,硬链接 ln 源文件 目标文件,没有参数-s, 它会在你选定的位置上生成一个和源文件大小相同的文件,无论是软链接还是硬链接,文件都保持同步变化。
 
第三:ln指令用在链接文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则会把前面指定的所有文件或目录复制到该目录中。若同时指定多个文件或目录,且最后的目的地并非是一个已存在的目录,则会出现错误信息。
 
常用参数:
 
-b 删除,覆盖以前建立的链接
 
-s 软链接(符号链接)
 
-v 显示详细处理过程
 
实例:
 
(1)给文件创建软链接,并显示操作信息
 
ln -sv source.log link.log
 
(2)给文件创建硬链接,并显示操作信息
 
ln -v source.log link1.log
 
(3)给目录创建软链接
 
ln -sv /opt/soft/test/test3 /opt/soft/test/test5
 
lsof
 
查找哪些程序使用了那些文件
 
lsof -i :port_number |grep “(LISTEN)”
 
-i是用来查找和网络相关的文件,”:”号是必须的,它是标志你查找的是一个端口 port_number就是你要查找的端口号,譬如你要查找是否 有程序占用了oracle的监听端口1521,就可以使用lsof -i :1521 |grep “(LISTEN)”。如果有程序已经占用了,那么下面打印的第二个字段就是该程序的进程id,第一个字段是进程的名字。
 
如果只有losf -i :port_number可能会查到很多应用程序,但这些程序实际并没有占用你指定的端口,这些端口只是连接到本机器或者别的机器的该端口。所以要grep “(LISTEN)“,因为一个端口只可能被一个程序占用的,所以这种方法是可靠的
 
netstat
 
查看端口是否已经打开:
 
netstat -ann|grep 80
 
查看 某个端口是被什么程序占用了
 
使用netstat -anp|grep 80
 
netstat -lnp|awk ‘BEGIN{prt=”:1521$”}{if ($4 ~ prt) print $0}’
 
Netstat后面的意思
 
·Proto显示连接使用的协议。
 
·RefCnt表示连接到本套接口上的进程号。
 
·Types显示套接口的类型。
 
·State显示套接口当前的状态。
 
·Path表示连接到套接口的其它进程使用的路径名
 
Netstat -tln 命令是用来查看linux的端口使用情况,
 
netstat -a 查看所有的服务端口
 
netstat -an | grep 端口号 来检验下是不是已经打开了某某端口
 
service xxx start 或者 /etc/init.d/xxx start是开启xxx某端口
 
iptables -A INPUT –dport xxx -j DROP
 
iptables -A OUTPUT –dport xxx -j DROP是关闭xxx端口
posted @ 2020-06-27 21:32  山的那一边  阅读(207)  评论(0编辑  收藏  举报