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

Linux下常见的系统命令小结(转)

2016-08-08 19:06 155 查看
grep命令
该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等,它的简单语法为

[plain] view
plain copy

 print?

grep [-acinv] [--color=auto] '查找字符串' filename  

它的常用参数如下:

[plain] view
plain copy

 print?

-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  

find命令
find是一个基于查找的功能非常强大的命令,相对而言,它的使用也相对较为复杂,参数也比较多,所以在这里将给把它们分类列出,它的基本语法如下:

[plain] view
plain copy

 print?

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/ljianhui -user ljianhui # 在目录/home/ljianhui中找出所有者为ljianhui的文件  

  

# 与文件权限及名称有关的参数:  

-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 . -perm 0755 # 查找当前目录中文件权限的0755的文件  

find . -size +12k # 查找当前目录中大于12KB的文件,注意c表示byte  

5、cp命令
该命令用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下,它的常用参数如下:

[plain] view
plain copy

 print?

-a :将文件的特性一起复制  

-p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份  

-i :若目标文件已经存在时,在覆盖时会先询问操作的进行  

-r :递归持续复制,用于目录的复制行为  

-u :目标文件与源文件有差异时才会复制  

例如 :

[plain] view
plain copy

 print?

cp -a file1 file2 #连同文件的所有特性把文件file1复制成文件file2  

cp file1 file2 file3 dir #把文件file1、file2、file3复制到目录dir中  

6、mv命令
该命令用于移动文件、目录或更名,move之意,它的常用参数如下:

[plain] view
plain copy

 print?

-f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖  

-i :若目标文件已经存在,就会询问是否覆盖  

-u :若目标文件已经存在,且比目标文件新,才会更新  

注:该命令可以把一个文件或多个文件一次移动一个文件夹中,但是最后一个目标文件一定要是“目录”。

例如:

[plain] view
plain copy

 print?

mv file1 file2 file3 dir # 把文件file1、file2、file3移动到目录dir中  

mv file1 file2 # 把文件file1重命名为file2  

7、rm命令
该命令用于删除文件或目录,remove之间,它的常用参数如下:

[plain] view
plain copy

 print?

-f :就是force的意思,忽略不存在的文件,不会出现警告消息  

-i :互动模式,在删除前会询问用户是否操作  

-r :递归删除,最常用于目录删除,它是一个非常危险的参数  

例如:

[plain] view
plain copy

 print?

rm -i file # 删除文件file,在删除之前会询问是否进行该操作  

rm -fr dir # 强制删除目录dir中的所有文件  

8、ps命令
该命令用于将某个时间点的进程运行情况选取下来并输出,process之意,它的常用参数如下:

[plain] view
plain copy

 print?

-A :所有的进程均显示出来  

-a :不与terminal有关的所有进程  

-u :有效用户的相关进程  

-x :一般与a参数一起使用,可列出较完整的信息  

-l :较长,较详细地将PID的信息列出  

其实我们只要记住ps一般使用的命令参数搭配即可,它们并不多,如下:

[plain] view
plain copy

 print?

ps aux # 查看系统所有的进程数据  

ps ax # 查看不与terminal有关的所有进程  

ps -lA # 查看系统所有的进程数据  

ps axjf # 查看连同一部分进程树状态  

9、kill命令
该命令用于向某个工作(%jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用,它的基本语法如下:

[plain] view
plain copy

 print?

kill -signal PID  

signal的常用参数如下:
注:最前面的数字为信号的代号,使用时可以用代号代替相应的信号。

[plain] view
plain copy

 print?

1:SIGHUP,启动被终止的进程  

2:SIGINT,相当于输入ctrl+c,中断一个程序的进行  

9:SIGKILL,强制中断一个进程的进行  

15:SIGTERM,以正常的结束进程方式来终止进程  

17:SIGSTOP,相当于输入ctrl+z,暂停一个进程的进行  

例如:

[plain] view
plain copy

 print?

# 以正常的结束进程方式来终于第一个后台工作,可用jobs命令查看后台中的第一个工作进程  

kill -SIGTERM %1   

# 重新改动进程ID为PID的进程,PID可用ps命令通过管道命令加上grep命令进行筛选获得  

kill -SIGHUP PID  

10、killall命令
该命令用于向一个命令启动的进程发送一个信号,它的一般语法如下:

[plain] view
plain copy

 print?

killall [-iIe] [command name]  

它的参数如下:

[plain] view
plain copy

 print?

-i :交互式的意思,若需要删除时,会询问用户  

-e :表示后面接的command name要一致,但command name不能超过15个字符  

-I :命令名称忽略大小写  

# 例如:  

killall -SIGHUP syslogd # 重新启动syslogd  

11、file命令
该命令用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的,所以这个命令对我们来说就很有用了,它的用法非常简单,基本语法如下:

[plain] view
plain copy

 print?

file filename  

#例如:  

file ./test  

12、tar命令
该命令用于对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压。它的常用参数如下:

[plain] view
plain copy

 print?

-c :新建打包文件  

-t :查看打包文件的内容含有哪些文件名  

-x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中  

-j :通过bzip2的支持进行压缩/解压缩  

-z :通过gzip的支持进行压缩/解压缩  

-v :在压缩/解压缩过程中,将正在处理的文件名显示出来  

-f filename :filename为要处理的文件  

-C dir :指定压缩/解压缩的目录dir  

上面的解说可以已经让你晕过去了,但是通常我们只需要记住下面三条命令即可:

[plain] view
plain copy

 print?

压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称  

查询:tar -jtv -f filename.tar.bz2  

解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录  

注:文件名并不定要以后缀tar.bz2结尾,这里主要是为了说明使用的压缩程序为bzip2

13、cat命令
该命令用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用,从而可以一页页地查看数据。例如:

[plain] view
plain copy

 print?

cat text | less # 查看text文件中的内容  

# 注:这条命令也可以使用less text来代替  

14、chgrp命令
该命令用于改变文件所属用户组,它的使用非常简单,它的基本用法如下:

[plain] view
plain copy

 print?

chgrp [-R] dirname/filename  

-R :进行递归的持续对所有文件和子目录更改  

# 例如:  

chgrp users -R ./dir # 递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users  

15、chown命令
该命令用于改变文件的所有者,与chgrp命令的使用方法相同,只是修改的文件属性不同,不再详述。

16、chmod命令
该命令用于改变文件的权限,一般的用法如下:

[plain] view
plain copy

 print?

chmod [-R] xyz 文件或目录  

-R:进行递归的持续更改,即连同子目录下的所有文件都会更改  

同时,chmod还可以使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(删除)、=(设置)跟rwx搭配来对文件的权限进行更改。

[plain] view
plain copy

 print?

# 例如:  

chmod 0755 file # 把file的文件权限改变为-rxwr-xr-x  

chmod g+w file # 向file的文件权限中加入用户组可写权限  

18、vim命令
该命令主要用于文本编辑,它接一个或多个文件名作为参数,如果文件存在就打开,如果文件不存在就以该文件名创建一个文件。vim是一个非常好用的文本编辑器,它里面有很多非常好用的命令,在这里不再多说。你可以从这里下载vim常用操作的详细说明。

19、gcc命令
对于一个用Linux开发C程序的人来说,这个命令就非常重要了,它用于把C语言的源程序文件,编译成可执行程序,由于g++的很多参数跟它非常相似,所以这里只介绍gcc的参数,它的常用参数如下:

[plain] view
plain copy

 print?

-o :output之意,用于指定生成一个可执行文件的文件名  

-c :用于把源文件生成目标文件(.o),并阻止编译器创建一个完整的程序  

-I :增加编译时搜索头文件的路径  

-L :增加编译时搜索静态连接库的路径  

-S :把源文件生成汇编代码文件  

-lm:表示标准库的目录中名为libm.a的函数库  

-lpthread :连接NPTL实现的线程库  

-std= :用于指定把使用的C语言的版本  

  

# 例如:  

# 把源文件test.c按照c99标准编译成可执行程序test  

gcc -o test test.c -lm -std=c99  

#把源文件test.c转换为相应的汇编程序源文件test.s  

gcc -S test.c  

20、time命令

该命令用于测算一个命令(即程序)的执行时间。它的使用非常简单,就像平时输入命令一样,不过在命令的前面加入一个time即可,例如:

[plain] view
plain copy

 print?

time ./process  

time ps aux  

在程序或命令运行结束后,在最后输出了三个时间,它们分别是:
user:用户CPU时间,命令执行完成花费的用户CPU时间,即命令在用户态中执行时间总和;
system:系统CPU时间,命令执行完成花费的系统CPU时间,即命令在核心态中执行时间总和;
real:实际时间,从command命令行开始执行到运行终止的消逝时间;

注:用户CPU时间和系统CPU时间之和为CPU时间,即命令占用CPU执行的时间总和。实际时间要大于CPU时间,因为Linux是多任务操作系统,往往在执行一条命令时,系统还要处理其它任务。另一个需要注意的问题是即使每次执行相同命令,但所花费的时间也是不一样,其花费时间是与系统运行相关的。

=============安装和登陆命令========================================
Mount:挂载命令。把存储介质指定成系统中的某个目录,比如挂载光驱mount /dev/cdrom把CDROM挂载,可在目录/mnt/cdrom下查看内容。
umount:卸载命令,比如umount /dev/cdrom

exit:退出终端命令。
shutdown:关闭linux系统,后面可加参数,比如shut down now。
reboot:重新启动linux。
halt:挂起系统,但没有关机。
chsh:改变登入系统的shell。
tty:显示终端机连接标准输入设备的文件名称。
=============系统管理命令========================================
Pwd:显示完整的当前工作目录。
Source:通常用于重新执行刚修改的初始化文件,使之立即生效,而不必注销并重新登录,比如修改玩环境变量配置后,运行source ~/.bashrc。
ls dev:显示系统设备。
df:显示当前系统磁盘使用状况。
top:显示资源状况,类似于XP的资源管理器。
free:显示系统内存使用状况。
at:在某个约定的时间执行特定操作。
adduser:在home目录下添加一个用户。
useradd:跟adduser是一个东西。
groupadd:建立一个新群组。
unzip:解压缩zip文件。
gzip:将文件压缩成.gz文件。
gunzip:解压缩.gz文件。
last:列出过去与目前登入系统的用户相关信息。
lspci :用lspci -v查看硬件芯片组。
lsusb:显示系统USB总线设备信息。
lsmod:显示系统已经加载的模块信息。
uname:查看系统软硬件信息。用uname -r -m -p -i得到内核版本和处理器架构等信息。
insmod:加载模块,Linux有许多功能是通过模块的方式,在需要时才载入kernel。
rmmod:卸载模块。
rpm:它的功能类似于Windows里面的“添加/删除程序”,被广泛应用于在Linux下安装、删除软件。如:rpm -q modutils,查询系统中有没有modutils软件包。
df:硬盘空间使用状况,及挂载信息。
mplayer:利用该工具包调试和使用声音。mplayer xxx.wav,会播放音频文件,显示当前音频所用设备。当然,也可以指定用OSS或者ALSA来播放,如:mplayer -ao alsa xxx.wav,用alsa音频组件来播放。
fdisk:是显示磁盘挂载和分配信息,比如sudo fdisk -l,显示挂载点、用途。如果是IDE硬盘,设备名依次为:/dev/hda,/dev/hdb,/dev/hdc,/dev/hdd等;如果是SCSI 硬盘,则设备名依次为/dev/sda,/dev/sdb。
dmesg:打印内核信息,有些打印语句是输出到内核而非终端。
lsof:显示打开文件的所有进程等。比如lsof abc.txt 显示开启文件abc.txt的进程
=============网络操作命令========================================
service network restart:配置好网络服务后,重启。
ip:就是整合了 ifconfig 与 route 这两个指令。
ping:功能与XP一样。如果要其停下来,用ctrl+c。
netstat:netstat命令的功能是显示网络连接、路由表和网络接口信息,可以让用户得知目前都有哪些网络连接正在运作。
telnet:开启终端机阶段作业,并登入远端主机。
rlogin:remote login,开启终端机阶段作业,并登入远端主机。
ftp:登录ftp服务器。
route:显示当前系统路由表信息。
finger:显示系统中某个用户的用户名、主目录、停滞时间、登录时间、登录shell等信息。
mail:邮件信息。
w3m:终端登入文字版浏览器。
=============系统安全命令========================================
passwd:修改密码。
su:作用是变更为其它使用者的身份,超级用户除外,需要键入该使用者的密码。
umask:确定了你创建文件的缺省模式。这一命令实际上和chmod命令正好相反。如:umask 777。
sudo:是允许系统管理员让普通用户执行一些或者全部的root命令的一个工具,如halt,reboot,su等等。这样不仅减少了root用户的登陆和管理时间,同样也提高了安全性。
chmod:改变文件权限。比如chmod 777 cc,设置cc权限为777。第一位是文件所有者权限,第二位是群组权限,第三位是其它人权限。每位的权限值是读权限(4)与写权限(2)与执行权限(1)之和。
chown:改变与文件关联的所有者和组。如chown jim program.c,即program.c的用户访问权限现在应用到jim;chown -R john:build /tmp/src,将src目录下面所有文件关联到用户john,组build。
=============压缩与解压缩命令========================================
tar:解压命令。
    .tar.gz 

        解压:tar zxvf FileName.tar.gz
        压缩:tar zcvf FileName.tar.gz DirName 把DirName的内容压缩成以FileName命名的压缩文档。
    .tar.bz2

        解压:tar jxvf FileName.tar.bz2
        压缩:tar jcvf FileName.tar.bz2 DirName
    .tar
        解压:tar xvf FileName.tar
        打包:tar cvf FileName.tar DirName 该命令起不了压缩作用


LINUX 下chmod|chown|chgrp和用法和区别

 (2011-03-27 23:48:08)


转载▼

标签: 


杂谈

分类: Linux笔记
1、chgrp(转变文件所属用户组)

chgrp 用户组 文件名 ###便是这个格了。若是整个目次下的都改,则加-R参数用于递归。

如:chgrp -R user smb.conf

2、chown(转变文件拥有者)

格局: A:chown 用户名 文件/目次

B:chown 用户名:用户组:文件/目次

若是整个目次下的都改,则加-R参数用于递归。

例:chown -R root /etc/config.cfg

chown -R root:root /home

3、chmod(变动文件属性)

文件属性的设置方式有两种,,别离是数字和标记。

mode : 权限设定字串,格局如下 : [ugoa...][[+-=][rwxX]...][,...],此中u 暗示该档案的拥有者,g 暗示与该档案的拥有者属于统一个群体(group)者,o 暗示其他以外的人,a 暗示这三者皆是。

  + 暗示增添权限、- 暗示打消权限、= 暗示独一设定权限。

  r 暗示可读取,w 暗示可写入,x 暗示可实行,X 暗示只有当该档案是个子目次大概该档案已经被设定过为可实行。

  -s :在文件实行时把历程的属主或组ID置为该文件的文件属主。

  -c : 若该档案权限确实已经变动,才表现其变动行动

  -f : 若该档案权限无法被变动也不要表现错误讯息

  -v : 表现权限变动的具体资料

  -R : 对今朝目次下的全部档案与子目次举行不异的权限变动(即以递回的体例逐个变动)

  --help : 表现帮助申明

  --version : 表现版本

  典范 :将档案 file1.txt 设为全部人皆可读取 :

  chmod ugo+r file1.txt

  将档案 file1.txt 设为全部人皆可读取 :

  chmod a+r file1.txt

  将档案 file1.txt 与 file2.txt 设为该档案拥有者,与其所属统一个群体者可写入,但其他以外的人则不成写入 :

  chmod ug+w,o-w file1.txt file2.txt

  将 ex1.py 设定为只有该档案拥有者可以实行 :

  chmod u+x ex1.py

  将今朝目次下的全部档案与子目次皆设为任何人可读取 :

  chmod -R a+r *

  当其他用户实行oracle的sqlplus这个法式时,他的身份因这个法式临时酿成oracle

  chmod u+s sqlplus

  别的,chmod也可以用数字来暗示权限如 chmod 777 file

  语法为:chmod abc file

  此中a,b,c各为一个数字,别离暗示User、Group、及Other的权限。

  r=4,w=2,x=1

  若要rwx属性则4+2+1=7;

  若要rw-属性则4+2=6;

  若要r-x属性则4+1=5。

  典范

  chmod a=rwx file

  和

  chmod 777 file

  结果不异

  chmod ug=rwx,o=x file

  和

  chmod 771 file

  结果不异

  若用chmod 4755 filename可使此程式具有root的权限

  若是是办理员也便是常说的ROOT用户的话,根基上有可以检察全部文件的权利.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  linux