Linux学习以及常用命令汇总大全



Linux文件系统和文本编辑器
1用户管理常用命令:
在Linux系统中,由于角色不同,权限和所完成的任务也不同,用户的角色是通过UID来识别的,用户的UID是全局唯一的,Linux用户可以为一下三类:
A:root用户(超级用户):系统唯一,是真实的。该用户可以登录系统,可以操作系统任何文件或命令,拥有最高权限。
B:虚拟用户:这类用户被称之为伪用户或假用户,与真实用户区分开来,这类用户不具有登录系统的能力,但却是系统运行不可缺少的用,如:bin daemon adm ftp  mail等,这类用户是系统自身拥有的,而非后来添加的,当然我们也可以添加虚拟用户。
C:普通真实用户:这类用户能登录系统,但只能操作其根目录的内容,权限受到限制,这类用户都是系统管理员自行添加的用户。
Linux用户管理的常用命令主要有:
                              用户账号添加命令useradd 或 adduser ;
      修改用户命令usermod;
      删除用户命令:userdel
                          及用户口令管理:password.

useradd和adduser是完全等价的两条命令。都是用于创建新的用户名。指向该命令后,将在系统中做如下事情:
1》在/etc/password文件中增添了一行记录。
2》在/home目录下创建新用户的主目录,并将/etc/skel目录中的文件复制到该目录中。
使用了该命令后,新建的用户暂时无法登录,因为还没有为该用户设置口令。需要再用password命令为其设置口令后,才能登陆。用户的UID和GID是useradd自动选取的,它是将/etc/password文件中的UID加1,将/etc/group文件中的GID加1.

AA:useradd和adduser命令的选项及其意义:
1:-g [inital_grp] 用于添加用户账号时指定该用户的私有组,如不指定-g参数,useradd命令将自动建立与用户账号同名的组作为该账号的私有组。
2:-G [grp...]     用户添加附属组。
3:-D              用于显示或设置useradd命令所使用的默认值。
4:-d [directory]  指定用户目录,如果此目录不存在,则同时使用-m选项来创建主目录。
5:-m              使用者若目录不存在,则自动建立。
6:-u UID          指定用户的用户号,如果同时有-o选项,则可以重复使用其他用户的标识号。注意,ID值不能为负值,预设为 最小不得小于99而逐次增加。0-99传统上保留给系统账号使用。

BB:修改用户账号----usermod
usermod命令可用来修改用户账户的各种属性,包括用户主目录,私有组,登录shell等内容,usermod的命令格式如下:
usermod [option] [username]
usermod的命令选项及其意义:
1》-d [directory] 修改用户登入时的目录
2》-e [days]      修改账号的有效期限,days标识天数
3》-g [group]     修改用户所属的群组。
4》-l [login_name]变更用户登录时的名称为login_name
5》-p [password]  修改用户密码
6》-s [shell]     指定用户登录的Shell,如果不设置,则选用系统预设的shell

需要注意的是:最好不要使用usermod命令修改用户密码,因为如果使用usermod命令,则显示在文件"/etc/shadow"中的密码是明码,应该用password命令修改密码
eg:使用usermod修改密码:usermod -p 123456 wang
   查看用户wang的密码:tail -l /etc/shadow
usermod不允许改变已登录用户的用户账号名称,当用户修改时,也必须确认这个用户没有在电脑上面执行任何程序。


CC:删除用户账号命令----userdel
userdel的命令非常简单,只有一个可选项-r ,如果在userdel后加上-r选项,则在删除用户的同时 也一并删除存储在/home目录下的该用户目录和软件。

DD:用户口令管理命令---password
用户管理一个重要的内容就是用户口令管理。用户账号刚建立的时候是没有口令的,但是会被系统锁定,必须为其制定口令才能使用,这时需要password命令,下面是password命令的语法格式:password [option] [username] 其中[option]为password的命令选项,[username]为用户名。
password的命令选项及其意义:
1》-l          锁定用户指令,即禁止使用该用户账号
2》-u          口令解锁
3》-d          关闭使用者的密码确认功能,使用者在登录时可以不用输入密码,只有具备root权限者才可以使用
4》-f          强迫用户下次登录时修改密码
5》-l [login_name] 变更用户登录时的名称为login_name
6》-s          显示指定使用者的密码认证种类,同样只有具备root权限的用户才可以使用
当用户作为普通用户修改自己密码时,首先会提示用户的原密码,然后要求用户重新输入两次来验证用户新口令,如果口令一致,则新口令设置成功,而超级用户root为用户设定密码时不需要原密码。

2:用户组管理常用命令
AA:用户组添加命令---groupadd
groupadd可指定用户组名称来简历新的用户组,需要时可从系统中取得新的用户组值,其语法格式为:groupadd [option] [groupname]
groupadd命令的选项及其意义:
1》-g GID     除非使用-o参数,否则GID的值必须是唯一切数值不可为负,预设值以/etc/login.defs为准
2》-o GID     运行GID不唯一
3》-r   加入组GID号,切其GID号低于499系统账号
4》-f   新增一个已经存在的用户组账号,系统会出现错误信息,然后结束
BB:用户组修改命令---groupmod
groupmod可指定用户组名称来修改新的用户组号或用户组名称,其语法格式为:groupmod [option] [groupname],其中[option]为groupmod命令选项,[groupname]为用户组名
1》-g GID     用户指定新的GID
2》-o GID 重复使用GID
3》-n         为群组改名
CC:用户组删除命令---groupdel
groupdel可指定用户组名称来删除已有的用户组,其语法格式为:groupdel [groupname]
该命令非常简单,但需要注意的是,如果该用户组包含某些用户,则必须删除这些用户,然后才能删除该用户组。



文件操作常用命令:
1:文件清单命令----ls
ls命令的选项及其意义
1》-a      显示指定目录下所有的子目录与文件,包括隐藏文件
2》-A      显示指定目录下所有的子目录与文件,包括隐藏文件,且不列出“.”和“..”
3》-b      对文件名的不可显示字符用八进制逃逸字符显示
4》-c      按文件的修改时间排序
5》-C      分成多列显示各项
6》-d      如果参数是目录,只显示其名称,而不是显示其下的各文件。往往与1选项一起使用,以得到目录的详细信息
7》-f      不排序,该选项将使Its选项失效,使用aU选项有效。
8》-i      在输出的第一列显示文件的i节点号
9》-l      以长格式来显示文件的详细信息,每行列出的信息依次是:文件类型与权限,连接数,文件属主,文件属组,文件大小,最近修改的时间,名字
10》-L     若指定的名称为一个符号链接文件,则显示链接所指向的文件
11》-m     输出按字符流格式,文件跨页显示,以逗号隔开。
12》-n     输出格式与l选项相同,只不过在输出文件属主和属组是用相应的UID号和GID号来表示,而不是实际的名称。
13》-o     与l选项相同,只是不显示拥有者信息
14》-p     在目录后面添加一个“/”
15》-q     将文件名中不可显示字符用“?”代替
16》-r     按字母逆序或最早优先的顺序显示输出结果
17》-R     递归式地显示指定目录的各个子目录的文件
18》-s     给出每个目录项所用的块数,包括间接块
19》-t     显示时按修改时间(最近优先)而不是按名字排序,若文件修改时间相同,则按字典顺序,修改时间取决于是否使用了c或u项,默认的时间标记是最后一次修改时间。
20》-u     显示时按文件上次存取的时间(最近优先)而不是按名字排序,即将-t的时间标记修改为最后一次访问的时间。
21》-x     按行显示出各排序项的信息

2:文件复制命令----cp
cp命令可以将给出的文件或目录复制到另一文件或目录中,就如同DOS下的copy命令一样,功能非常强大。
cp命令的一般格式为:cp [opton] [source] [destination]
该命令把指定的源文件复制到目标文件或把多个源文件复制到目标文件中,其中[option]为cp命令选项,[source]为源文件,而[destination]为目标目录或目标文件。
cp命令的选项及其意义:
1》-a      该选项通常在复制目录时使用,它保留链接,文件属性,并递归的复制目录
2》-d      复制时暴露连接
3》-f      删除已经存在的目标文件而不提示
4》-i      在覆盖目标文件之前将给出提示要求用户确认。回答y时,目标文件将被覆盖,是交互式复制。
5》-p      此时cp除复制文件的内容外,还将把其修改时间和访问时间和访问权限也复制到新文件中
6》-r      若给出的源文件是目录文件,此时cp将递归复制该目录下所有的子目录和文件,此时目标文件必须为一个目录名。
7》-l      不进行复制操作只是链接文件。


3:文件移动命令----mv
mv命令可用于将文件或目录从一个位置移动到另一个位置,同时可移动多个文件。mv命令还可以用于重命名,其一般格式为:mv [option] [source] [destination]
mv命令将所给的源文件或目录重命名为给定的目标文件名,此时源文件只能有一个(也可以是源目录),如果[desyination]是已存在的目录名称,源文件或目录参数可以有多个,mv命令将各参数指定的源文件全部移至目标目录中,在跨文件系统移动时,mv先复制再将原有文件删除,从而导致该文件的连接丢失。
mv命令选项及其意义:
1》-i      交互方式操作,如果mv操作将导致对已存在的目标文件的覆盖,此时系统询问是否重写,要求用户回答y或n,这样可以避免误覆盖文件
2》-f      禁止交互操作,在mv操作覆盖某已有的目标文件时不给任何提示,指定此选项后,i选项将不再起作用。
3》-p      移动时保持权限。


4:删除文件命令----rm
rm命令提供删除文件功能,该命令可以删除目录中的一个或者多个文件或子目录,他也可以将某个目录及其下的所有文件及其子目录均删除,删除单个文件不用带任何参数;如果是删除整个目录及目录下的所有文件,需要带-rf参数。其一般格式为:rm [option] [filename or directoryname]
其中[option]为rm命令选项,[filename or directoryname]为文件名或者子目录名
rm命令的选项及其意义:
1》-f       忽略不存在的文件,从不给出提示
2》-r       指示rm将参数中列出的全部目录和子目录均递归删除
3》-i       进行交互式删除
删除文件:rm -filename;     删除目录:rm -rf  directioryname


目录操作常用命令
1创建目录命令---mkdir
mkdir命令用于创建目录。其格式为:mkdir [option] [directoryName]其中[option]为mkdir命令选项,[directoryName]是需要创建的目录名称,需要说明的是该命令创建由[directoryName]命名的目录,要求创建目录的用户在当前目录中[directoryname的父目录中]具有写权限,并且[directoryName]
不能是已有的目录或者文件名称
mkdir命令的选项及其意义:
1》-m       对新建目录设置存取权限
2》-p       可以是一个路径名称,此时若路径中的某些目录尚不存在,加上选项之后,系统将自动建立好哪些尚不存在的目录,即一次可以建立多个目录。
3》-v       每次创建目录都显示信息
在进行目录创建的时候,可以使用-m选项设置目录的权限
eg:创建一个目录名称为tsk,让所有用户都有rwx(即读、写、执行的权限)
mkdir -m 777 tsk
用-m 777 指定目录的读、写、执行权限。
如果在创建目录的过程中父目录不存在,即可使用-p选项一起创建父目录和需要创建的子目录。
eg:mkdir -p testdir/test

2目录删除命令---rmdir
rmdir命令可以删除一个或者多个目录,再删除目录时,目录必须为空。rm命令可以同时删除多个目录,再删除某一目录时,必须拥有该目录的父目录的写和执行的权限。
语法格式为:rmdir [option] [directoryname]
rmdir命令选项及其意义:
1》-p       递归删除,当子目录删除后,其父目录为空时,也将会一同被删除,如果整个路径被删除或者由于某种原因保留部分路径,则系统会在标准输出上显示相应的信息
2》-ignore-fail-on-non-empty      忽略非空目录的错误信息
由于rmdir仅仅能删除父目录中包含子目录的情况,如果目录中存在文件,则使用rmdir和rmdir -p命令是无法删除该目录的,所以,需使用“rm -rf [directoryname]”命令代替rmdir,删除某目录时,同样要求该用户对父目录的读写权限。

3目录切换命令---cd
shell中提供了一个目录切换字符---cd,利用该字符可以轻松的在不同的目录之间进行切换。
语法格式:cd [directoryname]
想要访问目录或文件的相对路径之前,要确保知道当前工作目录的位置,如果标明的是到另一个目录或文件的绝对路径,则不必担心文件系统的所在位置,如果不能肯定,可输入pwd命令,就会显示当前的工作目录。
cd命令的具体使用说明:
1》cd        返回登录目录
2》cd ~      同样是返回登录目录
3》cd/       返回系统根目录
4》cd/root   返回到根用户或超级用户(在安装时创建的账号)的主目录,但必须是根用户才能访问的目录
5》cd/home   返回到home目录,home目录通常为用户登录目录的上级目录。
6》cd ..     返回上一级目录
7》cd -      返回上次访问的目录


文件和目录权限管理:
文件或目录的访问权限分为只读、只写、可执行三种。以文件为例,只读权限表示只允许读其内容,而禁止对其做任何的更改操作;可执行权限表示允许将该文件作为一个程序执行,文件被创建时,文件所有者自动拥有对该文件的读、写、和可执行权限,以便于对文件的阅读和修改,用户也可根据需要把访问权限设置为任何组合。
1更改文件(目录)权限命令---chmod
chmod命令用于更改文件或目录的访问权限,它有两种用法:一种是包含字母和操作符表达式的文字设定方法;另一种是包含数字的数字设定法
chmod命令的三种参数类型:
1》u表示用户(user),即文件或目录的所有者。               +添加某个权限                         r可读
2》g表示同组(group),即与文件属主同组的用户              -取消某个权限                         r可写
3》o表示其他(other)用户                                  =赋予给定权限并取消其他所有权限       x可执行
4》a表示所有(all)用户,它是系统默认值





子shell与进程处理
内建命令
内建命令就是包含在bash shell工具包中的命令,内建命令是bash shell的骨干部分,除此之外,保留字(reserved  words)也是bash shell的骨干部分,保留字对于bash shell具有特殊的含义,用来构建shell语法结构,for if then while until等都是保留字,保留字本身不是一个命令,而是命令结构的一部分
bash shell的内建命令和保留字:
1》!         保留字,逻辑非
2》:         不做任何事制作参数展开
3》.         读取文件,并在当前的shell中执行它
4》alias     设置命令或命令行的别名
5》bg        将作业置于后台执行
6》bind      将关键字序列与readline函数或宏绑定
7》break     保留字,跳出for   while   until  select 循环
8》builtin   调用命令的内建命令格式,而禁用同名的函数,或者同名的扩展命令
9》case      保留字,多重选择
10》cd       切换当前工作目录
11》command  找出内建和外部命令,寻找内建命令而非同名函数
12》contine  保留字,到达下一次for while until select 循环
13》declare  声明变量,定义变量属性
14》dirs     显示当前存储目录列表
15》disown   将作业从表中删除
16》do       保留字,for while until select 循环的一部分
17》done     保留字,for while until select 循环的一部分
18》echo     打印参数
19》elif     保留字if结构的一部分
20》else     保留字if结构的一部分
21》enable   开启和关闭内部命令
22》esac     保留字,case的一部分
23》eval     将参数作为命令在处理一遍
24》exec     以特定程序取代shell或为shell改变I/O
25》exit     退出shell
26》export   将变量声明为环境变量
27》fc       与命令历史一起执行
28》fg       将作业置于前台执行
29》fi       保留字,if结构的一部分
30》for      保留字,for循环的一部分
31》function 定义一个函数
32》getops   处理命令行选项
33》hash     记录并指定命令的路径名
34》help     显示内建命令的帮助信息
35》history  显示历史命令信息
36》if       保留字,if结构的一部分
37》in       保留字,case的一部分
38》jobs     显示在后台运行的作业
39》kill     向进程传送信号
40》let      使变量执行算术运算
41》local    定义局部变量
42》logout   从shell中注销
43》popd     从目录栈中弹出目录
44》pushd    将目录压入目录栈
45》pwd      显示当前工作目录
46》read     从标准输入中读入一行
47》readonly 将变量定义为只读
48》return   从函数脚本中返回
49》select   保留字,生成选择菜单
50》set      设置shell选项
51》shift    变换命令行参数
52》suspend  终止shell的执行
53》test     评估条件表达式
54》then     保留字,if结构的一部分
55》time     保留字,输出统计出来的命令执行时间,其输出格式由TIMEFORNAT变量来执行
56》times    针对shell及其子shell,显示用户和系统CPU的时间之和
57》trap     设置信号捕捉程序
58》type     确认命令的源
59》typeset  声明变量,定义变量属性,与declare等价
60》ulimit   设置和显示进程占用资源的限制
61》umask    设置和显示文件的权限码
62》unalias  取消别名定义
63》unset    取消变量或函数定义
64》until    保留字,一种循环结构
65》wait     等待后台作业完成
66》while    保留字,一种循环结构

●安装和登录命令:login、 shutdown、 halt、 reboot 、mount、umount 、chsh
●文件处理命令:file、 mkdir、 grep、dd、 find、 mv 、ls 、diff、 cat、 ln
●系统管理相关命令: df、 top、 free、 quota 、at、 lp、 adduser、 groupadd kill、 crontab、 tar、 unzip、 gunzip 、last
●网络操作命令:ifconfig、 ip 、ping 、 netstat 、telnet、 ftp、 route、 rlogin rcp 、finger 、mail 、nslookup
●系统安全相关命令: passwd 、su、 umask 、chgrp、 chmod、chown、chattr、sudo、 pswho

查看所有网络链接端口为20881:【netstat -an|grep 20881】
查看指定端口被哪个进程占用的情况
lsof -i:端口号
netstat -tunlp|grep 端口号
netstat -anp|grep 80


   pwd:查看“当前工作目录”的完整路径

arch 显示机器的处理器架构(1)
uname -m 显示机器的处理器架构(2)
uname -r 显示正在使用的内核版本
dmidecode -q 显示硬件系统部件 - (SMBIOS / DMI)
hdparm -i /dev/hda 罗列一个磁盘的架构特性
hdparm -tT /dev/sda 在磁盘上执行测试性读取操作
cat /proc/cpuinfo 显示CPU info的信息
cat /proc/interrupts 显示中断
cat /proc/meminfo 校验内存使用
cat /proc/swaps 显示哪些swap被使用
cat /proc/version 显示内核的版本
cat /proc/net/dev 显示网络适配器及统计
cat /proc/mounts 显示已加载的文件系统
lspci -tv 罗列 PCI 设备
lsusb -tv 显示 USB 设备
date 显示系统日期
cal 2007 显示2007年的日历表
date 041217002007.00 设置日期和时间 - 月日时分年.秒
clock -w 将时间修改保存到 BIOS


关机 (系统的关机、重启以及登出 )
shutdown -h now 关闭系统(1)
init 0 关闭系统(2)
telinit 0 关闭系统(3)
shutdown -h hours:minutes & 按预定时间关闭系统
shutdown -c 取消按预定时间关闭系统
shutdown -r now 重启(1)
reboot 重启(2)
logout 注销


文件和目录
cd /home     进入 '/ home' 目录'
cd ..     返回上一级目录
cd ../..    返回上两级目录
cd     进入个人的主目录
cd ~user1    进入个人的主目录
cd -     返回上次所在的目录
pwd     显示工作路径,查看用户当前所在目录
ls     查看目录中的文件
ls -F     查看目录中的文件
ls -l     显示文件和目录的详细资料
ls -a     显示隐藏文件
ls *[0-9]*    显示包含数字的文件名和目录名
tree     显示文件和目录由根目录开始的树形结构(1)
lstree     显示文件和目录由根目录开始的树形结构(2)


mkdir dir1    创建一个叫做 'dir1' 的目录'
mkdir dir1 dir2    同时创建两个目录
mkdir -p /tmp/dir1/dir2  创建一个目录树


rm -f file1    删除一个叫做 'file1' 的文件'
rmdir dir1    删除一个叫做 'dir1' 的目录'
rm -rf dir1    删除一个叫做 'dir1' 的目录并同时删除其内容
rm -rf dir1 dir2   同时删除两个目录及它们的内容


mv dir1 new_dir    重命名/移动 一个目录

cp file1 file2    复制一个文件
cp dir/* .    复制一个目录下的所有文件到当前工作目录
cp -a /tmp/dir1 .   复制一个目录到当前工作目录
cp -a dir1 dir2    复制一个目录

ln -s file1 lnk1   创建一个指向文件或目录的软链接
ln file1 lnk1    创建一个指向文件或目录的物理链接
touch -t 0712250000 file1  修改一个文件或目录的时间戳 - (YYMMDDhhmm)


file file1 outputs the mime type of the file as text
iconv -l 列出已知的编码
iconv -f fromEncoding -t toEncoding inputFile > outputFile creates a new from the given input file by assuming it is encoded in fromEncoding and converting it to toEncoding.
find . -maxdepth 1 -name *.jpg -print -exec convert "{}" -resize 80x60 "thumbs/{}" \; batch resize files in the current directory and send them to a thumbnails directory (requires convert from Imagemagick)


文件搜索
find / -name file1      从 '/' 开始进入根文件系统搜索文件和目录
find / -user user1      搜索属于用户 'user1' 的文件和目录
find /home/user1 -name \*.bin     在目录 '/ home/user1' 中搜索带有'.bin' 结尾的文件
find /usr/bin -type f -atime +100    搜索在过去100天内未被使用过的执行文件
find /usr/bin -type f -mtime -10    搜索在10天内被创建或者修改过的文件
find / -name \*.rpm -exec chmod 755 '{}' \;  搜索以 '.rpm' 结尾的文件并定义其权限
find / -xdev -name \*.rpm     搜索以 '.rpm' 结尾的文件,忽略光驱、捷盘等可移动设备
locate \*.ps       寻找以 '.ps' 结尾的文件 - 先运行 'updatedb' 命令
whereis halt       显示一个二进制文件、源码或man的位置
which halt       显示一个二进制文件或可执行文件的完整路径


挂载一个文件系统
mount /dev/hda2 /mnt/hda2     挂载一个叫做hda2的盘 - 确定目录 '/ mnt/hda2' 已经存在
umount /dev/hda2      卸载一个叫做hda2的盘 - 先从挂载点 '/ mnt/hda2' 退出
umount -n /mnt/hda2     运行卸载操作而不写入 /etc/mtab 文件- 当文件为只读或当磁盘写满时非常有用

fuser -km /mnt/hda2      当设备繁忙时强制卸载

mount /dev/fd0 /mnt/floppy     挂载一个软盘
mount /dev/cdrom /mnt/cdrom     挂载一个cdrom或dvdrom
mount /dev/hdc /mnt/cdrecorder    挂载一个cdrw或dvdrom
mount /dev/hdb /mnt/cdrecorder    挂载一个cdrw或dvdrom
mount -o loop file.iso /mnt/cdrom    挂载一个文件或ISO镜像文件
mount -t vfat /dev/hda5 /mnt/hda5    挂载一个Windows FAT32文件系统
mount /dev/sda1 /mnt/usbdisk     挂载一个usb 捷盘或闪存设备
mount -t smbfs -o username=user,password=pass //WinClient/share /mnt/share 挂载一个windows网络共享


磁盘空间
df -h    显示已经挂载的分区列表
ls -lSr |more   以尺寸大小排列文件和目录
du -sh dir1   估算目录 'dir1' 已经使用的磁盘空间'
du -sk * | sort -rn  以容量大小为依据依次显示文件和目录的大小
rpm -q -a --qf '%10{SIZE}t%{NAME}n' | sort -k1,1n  以大小为依据依次显示已安装的rpm包所使用的空间 (fedora, redhat类系统)
dpkg-query -W -f='${Installed-Size;10}t${Package}n' | sort -k1,1n 以大小为依据显示已安装的deb包所使用的空间 (ubuntu, debian类系统)

返回顶部索引 ^

用户和群组
groupadd group_name       创建一个新用户组
groupdel group_name       删除一个用户组
groupmod -n new_group_name old_group_name    重命名一个用户组
useradd -c "Name Surname " -g admin -d /home/user1 -s /bin/bash user1 创建一个属于 "admin" 用户组的用户
useradd user1        创建一个新用户
userdel -r user1       删除一个用户 ( '-r' 排除主目录)
usermod -c "User FTP" -g system -d /ftp/user1 -s /bin/nologin user1 修改用户属性
passwd         修改口令
passwd user1        修改一个用户的口令 (只允许root执行)
chage -E 2005-12-31 user1      设置用户口令的失效期限
pwck 检查 '/etc/passwd'      的文件格式和语法修正以及存在的用户
grpck 检查 '/etc/passwd'      的文件格式和语法修正以及存在的群组
newgrp group_name       登陆进一个新的群组以改变新创建文件的预设群组

返回顶部索引 ^

文件的权限 - 使用 "+" 设置权限,使用 "-" 用于取消
ls -lh 显示权限
ls /tmp | pr -T5 -W$COLUMNS 将终端划分成5栏显示
chmod ugo+rwx directory1                                 设置目录的所有人(u)、群组(g)以及其他人(o)以读(r )、写(w)和执行(x)的权限
chmod go-rwx directory1                                        删除群组(g)与其他人(o)对目录的读写执行权限
chown user1 file1                                              改变一个文件的所有人属性
chown -R user1 directory1                                      改变一个目录的所有人属性并同时改变改目录下所有文件的属性
chgrp group1 file1                                             改变文件的群组
chown user1:group1 file1                                       改变一个文件的所有人和群组属性
find / -perm -u+s                                              罗列一个系统中所有使用了SUID控制的文件
chmod u+s /bin/file1                                     设置一个二进制文件的 SUID 位 - 运行该文件的用户也被赋予和所有者同样的权限
chmod u-s /bin/file1                                           禁用一个二进制文件的 SUID位
chmod g+s /home/public                                         设置一个目录的SGID 位 - 类似SUID ,不过这是针对目录的
chmod g-s /home/public                                         禁用一个目录的 SGID 位
chmod o+t /home/public                                         设置一个文件的 STIKY 位 - 只允许合法所有人删除文件
chmod o-t /home/public                                         禁用一个目录的 STIKY 位

返回顶部索引 ^

文件的特殊属性 - 使用 "+" 设置权限,使用 "-" 用于取消
chattr +a file1                                                 只允许以追加方式读写文件
chattr +c file1                                                 允许这个文件能被内核自动压缩/解压
chattr +d file1                                                 在进行文件系统备份时,dump程序将忽略这个文件
chattr +i file1                                                 设置成不可变的文件,不能被删除、修改、重命名或者链接
chattr +s file1                                                 允许一个文件被安全地删除
chattr +S file1                                                 一旦应用程序对这个文件执行了写操作,使系统立刻把修改的结果写到磁盘
chattr +u file1                                                 若文件被删除,系统会允许你在以后恢复这个被删除的文件
lsattr                                                          显示特殊的属性

返回顶部索引 ^

打包和压缩文件
bunzip2 file1.bz2                                                 解压一个叫做 'file1.bz2'的文件
bzip2 file1                                                       压缩一个叫做 'file1' 的文件
gunzip file1.gz                                                   解压一个叫做 'file1.gz'的文件
gzip file1                                                        压缩一个叫做 'file1'的文件
gzip -9 file1                                                     最大程度压缩
rar a file1.rar test_file                                         创建一个叫做 'file1.rar' 的包
rar a file1.rar file1 file2 dir1                                  同时压缩 'file1', 'file2' 以及目录 'dir1'
rar x file1.rar                                                   解压rar包
unrar x file1.rar                                                 解压rar包
tar -cvf archive.tar file1                                        创建一个非压缩的 tarball
tar -cvf archive.tar file1 file2 dir1                             创建一个包含了 'file1', 'file2' 以及 'dir1'的档案文件
tar -tf archive.tar                                               显示一个包中的内容
tar -xvf archive.tar                                              释放一个包
tar -xvf archive.tar -C /tmp                                      将压缩包释放到 /tmp目录下
tar -cvfj archive.tar.bz2 dir1                                    创建一个bzip2格式的压缩包
tar -xvfj archive.tar.bz2                                         解压一个bzip2格式的压缩包
tar -cvfz archive.tar.gz dir1                                     创建一个gzip格式的压缩包
tar -xvfz archive.tar.gz                                          解压一个gzip格式的压缩包
zip file1.zip file1                                               创建一个zip格式的压缩包
zip -r file1.zip file1 file2 dir1                                 将几个文件和目录同时压缩成一个zip格式的压缩包
unzip file1.zip                                                   解压一个zip格式压缩包

返回顶部索引 ^

RPM 包 - (Fedora, Redhat及类似系统)
rpm -ivh package.rpm                                              安装一个rpm包
rpm -ivh --nodeeps package.rpm                                    安装一个rpm包而忽略依赖关系警告
rpm -U package.rpm                                                更新一个rpm包但不改变其配置文件
rpm -F package.rpm                                                更新一个确定已经安装的rpm包
rpm -e package_name.rpm                                           删除一个rpm包
rpm -qa                                                           显示系统中所有已经安装的rpm包
rpm -qa | grep httpd                                              显示所有名称中包含 "httpd" 字样的rpm包
rpm -qi package_name                                              获取一个已安装包的特殊信息
rpm -qg "System Environment/Daemons"                              显示一个组件的rpm包
rpm -ql package_name                                              显示一个已经安装的rpm包提供的文件列表
rpm -qc package_name                                              显示一个已经安装的rpm包提供的配置文件列表
rpm -q package_name --whatrequires                                显示与一个rpm包存在依赖关系的列表
rpm -q package_name --whatprovides                                显示一个rpm包所占的体积
rpm -q package_name --scripts                                     显示在安装/删除期间所执行的脚本l
rpm -q package_name --changelog                                   显示一个rpm包的修改历史
rpm -qf /etc/httpd/conf/httpd.conf                                确认所给的文件由哪个rpm包所提供
rpm -qp package.rpm -l                                            显示由一个尚未安装的rpm包提供的文件列表
rpm --import /media/cdrom/RPM-GPG-KEY                             导入公钥数字证书
rpm --checksig package.rpm                                        确认一个rpm包的完整性
rpm -qa gpg-pubkey                                                确认已安装的所有rpm包的完整性
rpm -V package_name                                               检查文件尺寸、 许可、类型、所有者、群组、MD5检查以及最后修改时间
rpm -Va                                                           检查系统中所有已安装的rpm包- 小心使用
rpm -Vp package.rpm                                               确认一个rpm包还未安装
rpm2cpio package.rpm | cpio --extract --make-directories *bin*    从一个rpm包运行可执行文件
rpm -ivh /usr/src/redhat/RPMS/`arch`/package.rpm                  从一个rpm源码安装一个构建好的包
rpmbuild --rebuild package_name.src.rpm                           从一个rpm源码构建一个 rpm 包

返回顶部索引 ^

YUM 软件包升级器 - (Fedora, RedHat及类似系统)
yum install package_name                                          下载并安装一个rpm包
yum localinstall package_name.rpm                                 将安装一个rpm包,使用你自己的软件仓库为你解决所有依赖关系
yum update package_name.rpm                                       更新当前系统中所有安装的rpm包
yum update package_name                                           更新一个rpm包
yum remove package_name                                           删除一个rpm包
yum list                                                          列出当前系统中安装的所有包
yum search package_name                                           在rpm仓库中搜寻软件包
yum clean packages                                                清理rpm缓存删除下载的包
yum clean headers                                                 删除所有头文件
yum clean all                                                     删除所有缓存的包和头文件

返回顶部索引 ^

DEB 包 (Debian, Ubuntu 以及类似系统)
dpkg -i package.deb                                               安装/更新一个 deb 包
dpkg -r package_name                                              从系统删除一个 deb 包
dpkg -l                                                           显示系统中所有已经安装的 deb 包
dpkg -l | grep httpd                                              显示所有名称中包含 "httpd" 字样的deb包
dpkg -s package_name                                              获得已经安装在系统中一个特殊包的信息
dpkg -L package_name                                              显示系统中已经安装的一个deb包所提供的文件列表
dpkg --contents package.deb                                       显示尚未安装的一个包所提供的文件列表
dpkg -S /bin/ping                                                 确认所给的文件由哪个deb包提供

返回顶部索引 ^

APT 软件工具 (Debian, Ubuntu 以及类似系统)
apt-get install package_name                                      安装/更新一个 deb 包
apt-cdrom install package_name                                    从光盘安装/更新一个 deb 包
apt-get update                                                    升级列表中的软件包
apt-get upgrade                                                   升级所有已安装的软件
apt-get remove package_name                                       从系统删除一个deb包
apt-get check                                                     确认依赖的软件仓库正确
apt-get clean                                                     从下载的软件包中清理缓存
apt-cache search searched-package                                 返回包含所要搜索字符串的软件包名称

返回顶部索引 ^

查看文件内容
cat file1                                              从第一个字节开始正向查看文件的内容
tac file1                                              从最后一行开始反向查看一个文件的内容
more file1                                             查看一个长文件的内容
less file1                                             类似于 'more' 命令,但是它允许在文件中和正向操作一样的反向操作
head -2 file1                                          查看一个文件的前两行
tail -2 file1                                          查看一个文件的最后两行
tail -f /var/log/messages                              实时查看被添加到一个文件中的内容

返回顶部索引 ^

文本处理
cat file1 file2 ... | command <> file1_in.txt_or_file1_out.txt general syntax for text manipulation using PIPE, STDIN and STDOUT
cat file1 | command( sed, grep, awk, grep, etc...) > result.txt    合并一个文件的详细说明文本,并将简介写入一个新文件中
cat file1 | command( sed, grep, awk, grep, etc...) >> result.txt   合并一个文件的详细说明文本,并将简介写入一个已有的文件中
grep Aug /var/log/messages 在文件 '/var/log/messages'              中查找关键词"Aug"
grep ^Aug /var/log/messages 在文件 '/var/log/messages'             中查找以"Aug"开始的词汇
grep [0-9] /var/log/messages 选择 '/var/log/messages'              文件中所有包含数字的行
grep Aug -R /var/log/* 在目录 '/var/log'                           及随后的目录中搜索字符串"Aug"
sed 's/stringa1/stringa2/g' example.txt                            将example.txt文件中的 "string1" 替换成 "string2"
sed '/^$/d' example.txt 从example.txt                              文件中删除所有空白行
sed '/ *#/d; /^$/d' example.txt 从example.txt                      文件中删除所有注释和空白行
echo 'esempio' | tr '[:lower:]' '[:upper:]'                        合并上下单元格内容
sed -e '1d' result.txt                                             从文件example.txt 中排除第一行
sed -n '/stringa1/p'                                               查看只包含词汇 "string1"的行
sed -e 's/ *$//' example.txt                                       删除每一行最后的空白字符
sed -e 's/stringa1//g' example.txt                                 从文档中只删除词汇 "string1" 并保留剩余全部
sed -n '1,5p;5q' example.txt                                       查看从第一行到第5行内容
sed -n '5p;5q' example.txt                                         查看第5行
sed -e 's/00*/0/g' example.txt                                     用单个零替换多个零
cat -n file1                                                       标示文件的行数
cat example.txt | awk 'NR%2==1'         删除example.txt文件中的所有偶数行
echo a b c | awk '{print $1}'                                       查看一行第一栏
echo a b c | awk '{print $1,$3}'                                    查看一行的第一和第三栏
paste file1 file2                                                   合并两个文件或两栏的内容
paste -d '+' file1 file2                                            合并两个文件或两栏的内容,中间用"+"区分
sort file1 file2                                                    排序两个文件的内容
sort file1 file2 | uniq                                             取出两个文件的并集(重复的行只保留一份)
sort file1 file2 | uniq -u                                          删除交集,留下其他的行
sort file1 file2 | uniq -d                                          取出两个文件的交集(只留下同时存在于两个文件中的文件)
comm -1 file1 file2                                                 比较两个文件的内容只删除 'file1' 所包含的内容
comm -2 file1 file2                                                 比较两个文件的内容只删除 'file2' 所包含的内容
comm -3 file1 file2                                                 比较两个文件的内容只删除两个文件共有的部分

返回顶部索引 ^


字符设置和文件格式转换
dos2unix filedos.txt fileunix.txt                                  将一个文本文件的格式从MSDOS转换成UNIX
unix2dos fileunix.txt filedos.txt                                  将一个文本文件的格式从UNIX转换成MSDOS
recode ..HTML < page.txt > page.html                               将一个文本文件转换成html
recode -l | more                                                   显示所有允许的转换格式

返回顶部索引 ^

文件系统分析
badblocks -v /dev/hda1                                             检查磁盘hda1上的坏磁块
fsck /dev/hda1                                                     修复/检查hda1磁盘上linux文件系统的完整性
fsck.ext2 /dev/hda1                                                修复/检查hda1磁盘上ext2文件系统的完整性
e2fsck /dev/hda1                                                   修复/检查hda1磁盘上ext2文件系统的完整性
e2fsck -j /dev/hda1                                                修复/检查hda1磁盘上ext3文件系统的完整性
fsck.ext3 /dev/hda1                                                修复/检查hda1磁盘上ext3文件系统的完整性
fsck.vfat /dev/hda1                                                修复/检查hda1磁盘上fat文件系统的完整性
fsck.msdos /dev/hda1                                               修复/检查hda1磁盘上dos文件系统的完整性
dosfsck /dev/hda1                                                  修复/检查hda1磁盘上dos文件系统的完整性

返回顶部索引 ^

初始化一个文件系统
mkfs /dev/hda1                                                     在hda1分区创建一个文件系统
mke2fs /dev/hda1                                                   在hda1分区创建一个linux ext2的文件系统
mke2fs -j /dev/hda1                                                在hda1分区创建一个linux ext3(日志型)的文件系统
mkfs -t vfat 32 -F /dev/hda1                                       创建一个 FAT32 文件系统
fdformat -n /dev/fd0                                               格式化一个软盘
mkswap /dev/hda3                                                   创建一个swap文件系统

返回顶部索引 ^

SWAP文件系统
mkswap /dev/hda3                                                   创建一个swap文件系统
swapon /dev/hda3                                                   启用一个新的swap文件系统
swapon /dev/hda2 /dev/hdb3                                         启用两个swap分区

返回顶部索引 ^

备份
dump -0aj -f /tmp/home0.bak /home                                   制作一个 '/home' 目录的完整备份
dump -1aj -f /tmp/home0.bak /home                                   制作一个 '/home' 目录的交互式备份
restore -if /tmp/home0.bak                                          还原一个交互式备份
rsync -rogpav --delete /home /tmp                                   同步两边的目录
rsync -rogpav -e ssh --delete /home ip_address:/tmp                 通过SSH通道rsync
rsync -az -e ssh --delete ip_addr:/home/public /home/local          通过ssh和压缩将一个远程目录同步到本地目录
rsync -az -e ssh --delete /home/local ip_addr:/home/public          通过ssh和压缩将本地目录同步到远程目录
dd bs=1M if=/dev/hda | gzip | ssh user@ip_addr 'dd of=hda.gz'       通过ssh在远程主机上执行一次备份本地磁盘的操作
dd if=/dev/sda of=/tmp/file1                                        备份磁盘内容到一个文件
tar -Puf backup.tar /home/user 执行一次对 '/home/user'              目录的交互式备份操作
( cd /tmp/local/ && tar c . ) | ssh -C user@ip_addr 'cd /home/share/ && tar x -p'       通过ssh在远程目录中复制一个目录内容
( tar c /home ) | ssh -C user@ip_addr 'cd /home/backup-home && tar x -p'                通过ssh在远程目录中复制一个本地目录
tar cf - . | (cd /tmp/backup ; tar xf - )                                       本地将一个目录复制到另一个地方,保留原有权限及链接
find /home/user1 -name '*.txt' | xargs cp -av --target-directory=/home/backup/ --parents 从一个目录查找并复制所有以 '.txt' 结尾的文件到另一个目录
find /var/log -name '*.log' | tar cv --files-from=- | bzip2 > log.tar.bz2             查找所有以 '.log' 结尾的文件并做成一个bzip包
dd if=/dev/hda of=/dev/fd0 bs=512 count=1                                    做一个将 MBR (Master Boot Record)内容复制到软盘的动作
dd if=/dev/fd0 of=/dev/hda bs=512 count=1                                    从已经保存到软盘的备份中恢复MBR内容

返回顶部索引 ^

光盘
cdrecord -v gracetime=2 dev=/dev/cdrom -eject blank=fast -force               清空一个可复写的光盘内容
mkisofs /dev/cdrom > cd.iso                                                   在磁盘上创建一个光盘的iso镜像文件
mkisofs /dev/cdrom | gzip > cd_iso.gz                                         在磁盘上创建一个压缩了的光盘iso镜像文件
mkisofs -J -allow-leading-dots -R -V "Label CD" -iso-level 4 -o ./cd.iso data_cd 创建一个目录的iso镜像文件
cdrecord -v dev=/dev/cdrom cd.iso                                              刻录一个ISO镜像文件
gzip -dc cd_iso.gz | cdrecord dev=/dev/cdrom -                                 刻录一个压缩了的ISO镜像文件
mount -o loop cd.iso /mnt/iso                                                  挂载一个ISO镜像文件
cd-paranoia -B                                                                 从一个CD光盘转录音轨到 wav 文件中
cd-paranoia -- "-3"                                                            从一个CD光盘转录音轨到 wav 文件中(参数-3)
cdrecord --scanbus                                                             扫描总线以识别scsi通道
dd if=/dev/hdc | md5sum                                                        校验一个设备的md5sum编码,例如一张 CD










  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值