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

Linux基础命令详解和命令大全

2015-07-21 14:10 465 查看


一.20个常用命令


1.ls命令

ls命令是列出目录内容(ListDirectoryContents)的意思。运行它就是列出文件夹里的内容,可能是文件也可能是文件夹。

?
“ls-l”命令以详情模式(longlistingfashion)列出文件夹的内容。

?
"ls-a"命令会列出文件夹里的所有内容,包括以"."开头的隐藏文件。

?
注意:在Linux中,文件以“.”开头的就是隐藏文件,并且每个文件,文件夹,设备或者命令都是以文件对待。ls
-l命令输出:

d(代表了是目录).
rwxr-xr-x是文件或者目录对所属用户,同一组用户和其它用户的权限。
上面例子中第一个ravisaive代表了文件文件属于用户ravisaive
上面例子中的第二个ravisaive代表了文件文件属于用户组ravisaive
4096代表了文件大小为4096字节.
May801:06代表了文件最后一次修改的日期和时间.
最后面的就是文件/文件夹的名字

更多"ls"例子请查看15linux中ls命令实例






66号公路

翻译于2年前


8人顶

顶翻译的不错哦!
其它翻译版本(1)


2.lsblk命令

"lsblk"就是列出块设备。除了RAM外,以标准的树状输出格式,整齐地显示块设备。

?
“lsblk-l”命令以列表格式显示块设备(而不是树状格式)。

?
注意:lsblk是最有用和最简单的方式来了解新插入的USB设备的名字,特别是当你在终端上处理磁盘/块设备时。


3.md5sum命令

“md5sum”就是计算和检验MD5信息签名。md5checksum(通常叫做哈希)使用匹配或者验证文件的文件的完整性,因为文件可能因为传输错误,磁盘错误或者无恶意的干扰等原因而发生改变。

?
注意:用户可以使用官方提供的和md5sum生成签名信息匹对以此检测文件是否改变。Md5sum没有sha1sum安全,这点我们稍后讨论。






66号公路

翻译于2年前


9人顶

顶翻译的不错哦!


4.dd命令

“dd”命令代表了转换和复制文件。可以用来转换和复制文件,大多数时间是用来复制iso文件(或任何其它文件)到一个usb设备(或任何其它地方)中去,所以可以用来制作USB启动器。

?
注意:在上面的例子中,usb设备就是sdb1(你应该使用lsblk命令验证它,否则你会重写你的磁盘或者系统),请慎重使用磁盘的名,切忌。

dd命令在执行中会根据文件的大小和类型以及usb设备的读写速度,消耗几秒到几分钟不等。






66号公路

翻译于2年前


7人顶

顶翻译的不错哦!


5.uname命令

"uname"命令就是UnixName的简写。显示机器名,操作系统和内核的详细信息。

?
注意:uname显示内核类别,uname
-a显示详细信息。上面的输出详细说明了uname
-a

“Linux“:机器的内核名
“tecmint“:机器的节点名
“3.8.0-19-generic“:内核发布版本
“#30-UbuntuSMP“:内核版本
“i686“:处理器架构
“GNU/Linux“:操作系统名


6.history命令

“history”命令就是历史记录。它显示了在终端中所执行过的所有命令的历史。

?
注意:按住“CTRL+R”就可以搜索已经执行过的命令,它可以在你写命令时自动补全。

?





66号公路

翻译于2年前


4人顶

顶翻译的不错哦!


7.sudo命令

“sudo”(superuserdo)命令允许授权用户执行超级用户或者其它用户的命令。通过在sudoers列表的安全策略来指定。

?
注意:sudo允许用户借用超级用户的权限,然而"su"命令实际上是允许用户以超级用户登录。所以sudo比su更安全。

并不建议使用sudo或者su来处理日常用途,因为它可能导致严重的错误如果你意外的做错了事,这就是为什么在linux社区流行一句话:

“Toerrishuman,buttoreallyfoulupeverything,youneedrootpassword.”



“人非圣贤孰能无过,但是拥有root密码就真的万劫不复了。”#译
8.mkdir命令

“mkdir”(Makedirectory)命令在命名路径下创建新的目录。然而如果目录已经存在了,那么它就会返回一个错误信息"不能创建文件夹,文件夹已经存在了"("cannot
createfolder,folderalreadyexists")

?
注意:目录只能在用户拥有写权限的目录下才能创建。mkdir:不能创建目录`tecmint`,因为文件已经存在了。(上面的输出中不要被文件迷惑了,你应该记住我开头所说的-在linux中,文件,文件夹,驱动,命令,脚本都视为文件)






66号公路

翻译于2年前


8人顶

顶翻译的不错哦!


9.touch命令

“touch”命令代表了将文件的访问和修改时间更新为当前时间。touch命令只会在文件不存在的时候才会创建它。如果文件已经存在了,它会更新时间戳,但是并不会改变文件的内容。

?
注意:touch可以用来在用户拥有写权限的目录下创建不存在的文件。


10.chmod命令

“chmod”命令就是改变文件的模式位。chmod会根据要求的模式来改变每个所给的文件,文件夹,脚本等等的文件模式(权限)。

在文件(文件夹或者其它,为了简单起见,我们就使用文件)中存在3中类型的权限

?
所以如果你想给文件只读权限,就设置为'4';只写权限,设置权限为'2';只执行权限,设置为1;读写权限,就是4+2=6,以此类推。

现在需要设置3种用户和用户组权限。第一个是拥有者,然后是用户所在的组,最后是其它用户。

?
这里root的权限是rwx(读写和执行权限),

所属用户组权限是r-x(只有读和执行权限,没有写权限),

对于其它用户权限是-x(只有只执行权限)

为了改变它的权限,为拥有者,用户所在组和其它用户提供读,写,执行权限。

?
三种都只有读写权限

?
拥有者用户有读写和执行权限,用户所在的组和其它用户只有可执行权限

?
注意:对于系统管理员和用户来说,这个命令是最有用的命令之一了。在多用户环境或者服务器上,对于某个用户,如果设置了文件不可访问,那么这个命令就可以解决,如果设置了错误的权限,那么也就提供了为授权的访问。






66号公路

翻译于2年前


9人顶

顶翻译的不错哦!


11.chown命令

“chown”命令就是改变文件拥有者和所在用户组。每个文件都属于一个用户组和一个用户。在你的目录下,使用"ls
-l",你就会看到像这样的东西。

?
在这里,目录Binary属于用户"server",和用户组"root",而目录"Desktop"属于用户“server”和用户组"server"

“chown”命令用来改变文件的所有权,所以仅仅用来管理和提供文件的用户和用户组授权。

?
注意:“chown”所给的文件改变用户和组的所有权到新的拥有者或者已经存在的用户或者用户组。






66号公路

翻译于2年前


5人顶

顶翻译的不错哦!


12.apt命令

Debian系列以“apt”命令为基础,“apt”代表了Advanced
PackageTool。APT是一个为Debian系列系统(Ubuntu,Kubuntu等等)开发的高级包管理器,在Gnu/Linux系统上,它会为包自动地,智能地搜索,安装,升级以及解决依赖。

?
?
注意:上面的命令会导致系统整体的改变,所以需要root密码(查看提示符为"#",而不是“$”).和yum命令相比,Apt更高级和智能。

见名知义,apt-cache用来搜索包中是否包含子包mplayer,apt-get用来安装,升级所有的已安装的包到最新版。

关于apt-get和apt-cache命令更多信息,请查看25
APT-GET和APT-CACHE命令






66号公路

翻译于2年前


6人顶

顶翻译的不错哦!


13.tar命令

“tar”命令是磁带归档(TapeArchive),对创建一些文件的的归档和它们的解压很有用。

?
?
?
注意:"tar.gz"代表了使用gzip归档,“bar.bz2”使用bzip压缩的,它压缩的更好但是也更慢。

了解更多"tar命令"的例子,请查看18Tar命名例子


14.cal命令

“cal”(Calender),它用来显示当前月份或者未来或者过去任何年份中的月份。

?
显示已经过去的月份,1835年2月

?
显示未来的月份,2145年7月。

?
注意:你不需要往回调整日历50年,既不用复杂的数据计算你出生那天,也不用计算你的生日在哪天到来,[因为它的最小单位是月,而不是日]。






66号公路

翻译于2年前


4人顶

顶翻译的不错哦!


15.date命令

“date”命令使用标准的输出打印当前的日期和时间,也可以深入设置。

?
?
注意:这个命令在脚本中十分有用,以及基于时间和日期的脚本更完美。而且在终端中改变日期和时间,让你更专业!!!(当然你需要root权限才能操作这个,因为它是系统整体改变)


16.cat命令

“cat”代表了连结(Concatenation),连接两个或者更多文本文件或者以标准输出形式打印文件的内容。

?
?
注意:“>>”和“>”调用了追加符号。它们用来追加到文件里,而不是显示在标准输出上。“>”符号会删除已存在的文件,然后创建一个新的文件。所以因为安全的原因,建议使用“>>”,它会写入到文件中,而不是覆盖或者删除。






66号公路

翻译于2年前


4人顶

顶翻译的不错哦!
在深入探究之前,我必须让你知道通配符(你应该知道通配符,它出现在大多数电视选秀中)。通配符是shell的特色,和任何GUI文件管理器相比,它使命令行更强大有力!如你所看到那样,在一个图形文件管理器中,你想选择一大组文件,你通常不得不使用你的鼠标来选择它们。这可能觉得很简单,但是事实上,这种情形很让人沮丧!

例如,假如你有一个有很多很多各种类型的文件和子目录的目录,然后你决定移动所有文件名中包含“Linux”字样的HTML文件到另外一个目录。如何简单的完成这个?如果目录中包含了大量的不同名的HTML文件,你的任务很巨大,而不是简单了。

在LInuxCLI中,这个任务就很简单,就好像只移动一个HTML文件,因为有shell的通配符,才会如此简单。这些是特殊的字符,允许你选择匹配某种字符模式的文件名。它帮助你来选择,即使是大量文件名中只有几个字符,而且在大多数情形中,它比使用鼠标选择文件更简单。

这里就是常用通配符列表:

?
!叫做非,带'!'的反向字符串为真

更多请阅读Linuxcat命令的实例13Linux中cat命令实例






66号公路

翻译于2年前


6人顶

顶翻译的不错哦!


17.cp命令

“copy”就是复制。它会从一个地方复制一个文件到另外一个地方。

?
注意:cp,在shell脚本中是最常用的一个命令,而且它可以使用通配符(在前面一块中有所描述),来定制所需的文件的复制。


18.mv命令

“mv”命令将一个地方的文件移动到另外一个地方去。

?
注意:mv命令可以使用通配符。mv需谨慎使用,因为移动系统的或者未授权的文件不但会导致安全性问题,而且可能系统崩溃。


19.pwd命令

“pwd”(printworkingdirectory),在终端中显示当前工作目录的全路径。

?
注意:这个命令并不会在脚本中经常使用,但是对于新手,当从连接到nux很久后在终端中迷失了路径,这绝对是救命稻草。






66号公路

翻译于2年前


5人顶

顶翻译的不错哦!


20.cd命令

最后,经常使用的“cd”命令代表了改变目录。它在终端中改变工作目录来执行,复制,移动,读,写等等操作。

?
?
注意:在终端中切换目录时,cd就大显身手了。“cd~”会改变工作目录为用户的家目录,而且当用户发现自己在终端中迷失了路径时,非常有用。“cd..”从当前工作目录切换到(当前工作目录的)父目录。

二.命令大全

系统信息

arch显示机器的处理器架构(1)

uname-m显示机器的处理器架构(2)

uname-r显示正在使用的内核版本

dmidecode-q显示硬件系统部件-(SMBIOS/DMI)

hdparm-i/dev/hda罗列一个磁盘的架构特性

hdparm-tT/dev/sda在磁盘上执行测试性读取操作

cat/proc/cpuinfo显示CPUinfo的信息

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显示系统日期

cal2007显示2007年的日历表

date041217002007.00设置日期和时间-月日时分年.秒

clock-w将时间修改保存到BIOS

关机(系统的关机、重启以及登出)

shutdown-hnow关闭系统(1)

init0关闭系统(2)

telinit0关闭系统(3)

shutdown-hhours:minutes&按预定时间关闭系统

shutdown-c取消按预定时间关闭系统

shutdown-rnow重启(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)

mkdirdir1创建一个叫做'dir1'的目录'

mkdirdir1dir2同时创建两个目录

mkdir-p/tmp/dir1/dir2创建一个目录树

rm-ffile1删除一个叫做'file1'的文件'

rmdirdir1删除一个叫做'dir1'的目录'

rm-rfdir1删除一个叫做'dir1'的目录并同时删除其内容

rm-rfdir1dir2同时删除两个目录及它们的内容

mvdir1new_dir重命名/移动一个目录

cpfile1file2复制一个文件

cpdir/*.复制一个目录下的所有文件到当前工作目录

cp-a/tmp/dir1.复制一个目录到当前工作目录

cp-adir1dir2复制一个目录

ln-sfile1lnk1创建一个指向文件或目录的软链接

lnfile1lnk1创建一个指向文件或目录的物理链接

touch-t0712250000file1修改一个文件或目录的时间戳-(YYMMDDhhmm)

filefile1outputsthemimetypeofthefileastext

iconv-l列出已知的编码

iconv-ffromEncoding-ttoEncodinginputFile>outputFilecreatesanewfromthegiveninputfilebyassumingitisencodedinfromEncodingandconvertingittotoEncoding.

find.-maxdepth1-name*.jpg-print-execconvert"{}"-resize80x60"thumbs/{}"\;batchresizefilesinthecurrentdirectoryandsendthemtoathumbnailsdirectory(requiresconvertfromImagemagick)

文件搜索

find/-namefile1从'/'开始进入根文件系统搜索文件和目录

find/-useruser1搜索属于用户'user1'的文件和目录

find/home/user1-name\*.bin在目录'/home/user1'中搜索带有'.bin'结尾的文件

find/usr/bin-typef-atime+100搜索在过去100天内未被使用过的执行文件

find/usr/bin-typef-mtime-10搜索在10天内被创建或者修改过的文件

find/-name\*.rpm-execchmod755'{}'\;搜索以'.rpm'结尾的文件并定义其权限

find/-xdev-name\*.rpm搜索以'.rpm'结尾的文件,忽略光驱、捷盘等可移动设备

locate\*.ps寻找以'.ps'结尾的文件-先运行'updatedb'命令

whereishalt显示一个二进制文件、源码或man的位置

whichhalt显示一个二进制文件或可执行文件的完整路径

挂载一个文件系统

mount/dev/hda2/mnt/hda2挂载一个叫做hda2的盘-确定目录'/mnt/hda2'已经存在

umount/dev/hda2卸载一个叫做hda2的盘-先从挂载点'/mnt/hda2'退出

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

umount-n/mnt/hda2运行卸载操作而不写入/etc/mtab文件-当文件为只读或当磁盘写满时非常有用

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-oloopfile.iso/mnt/cdrom挂载一个文件或ISO镜像文件

mount-tvfat/dev/hda5/mnt/hda5挂载一个WindowsFAT32文件系统

mount/dev/sda1/mnt/usbdisk挂载一个usb捷盘或闪存设备

mount-tsmbfs-ousername=user,password=pass//WinClient/share/mnt/share挂载一个windows网络共享

磁盘空间

df-h显示已经挂载的分区列表

ls-lSr|more以尺寸大小排列文件和目录

du-shdir1估算目录'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类系统)

返回顶部索引^

用户和群组

groupaddgroup_name创建一个新用户组

groupdelgroup_name删除一个用户组

groupmod-nnew_group_nameold_group_name重命名一个用户组

useradd-c"NameSurname"-gadmin-d/home/user1-s/bin/bashuser1创建一个属于"admin"用户组的用户

useradduser1创建一个新用户

userdel-ruser1删除一个用户('-r'排除主目录)

usermod-c"UserFTP"-gsystem-d/ftp/user1-s/bin/nologinuser1修改用户属性

passwd修改口令

passwduser1修改一个用户的口令(只允许root执行)

chage-E2005-12-31user1设置用户口令的失效期限

pwck检查'/etc/passwd'的文件格式和语法修正以及存在的用户

grpck检查'/etc/passwd'的文件格式和语法修正以及存在的群组

newgrpgroup_name登陆进一个新的群组以改变新创建文件的预设群组

返回顶部索引^

文件的权限-使用"+"设置权限,使用"-"用于取消

ls-lh显示权限

ls/tmp|pr-T5-W$COLUMNS将终端划分成5栏显示

chmodugo+rwxdirectory1设置目录的所有人(u)、群组(g)以及其他人(o)以读(r)、写(w)和执行(x)的权限

chmodgo-rwxdirectory1删除群组(g)与其他人(o)对目录的读写执行权限

chownuser1file1改变一个文件的所有人属性

chown-Ruser1directory1改变一个目录的所有人属性并同时改变改目录下所有文件的属性

chgrpgroup1file1改变文件的群组

chownuser1:group1file1改变一个文件的所有人和群组属性

find/-perm-u+s罗列一个系统中所有使用了SUID控制的文件

chmodu+s/bin/file1设置一个二进制文件的SUID位-运行该文件的用户也被赋予和所有者同样的权限

chmodu-s/bin/file1禁用一个二进制文件的SUID位

chmodg+s/home/public设置一个目录的SGID位-类似SUID,不过这是针对目录的

chmodg-s/home/public禁用一个目录的SGID位

chmodo+t/home/public设置一个文件的STIKY位-只允许合法所有人删除文件

chmodo-t/home/public禁用一个目录的STIKY位

返回顶部索引^

文件的特殊属性-使用"+"设置权限,使用"-"用于取消

chattr+afile1只允许以追加方式读写文件

chattr+cfile1允许这个文件能被内核自动压缩/解压

chattr+dfile1在进行文件系统备份时,dump程序将忽略这个文件

chattr+ifile1设置成不可变的文件,不能被删除、修改、重命名或者链接

chattr+sfile1允许一个文件被安全地删除

chattr+Sfile1一旦应用程序对这个文件执行了写操作,使系统立刻把修改的结果写到磁盘

chattr+ufile1若文件被删除,系统会允许你在以后恢复这个被删除的文件

lsattr显示特殊的属性

返回顶部索引^

打包和压缩文件

bunzip2file1.bz2解压一个叫做'file1.bz2'的文件

bzip2file1压缩一个叫做'file1'的文件

gunzipfile1.gz解压一个叫做'file1.gz'的文件

gzipfile1压缩一个叫做'file1'的文件

gzip-9file1最大程度压缩

rarafile1.rartest_file创建一个叫做'file1.rar'的包

rarafile1.rarfile1file2dir1同时压缩'file1','file2'以及目录'dir1'

rarxfile1.rar解压rar包

unrarxfile1.rar解压rar包

tar-cvfarchive.tarfile1创建一个非压缩的tarball

tar-cvfarchive.tarfile1file2dir1创建一个包含了'file1','file2'以及'dir1'的档案文件

tar-tfarchive.tar显示一个包中的内容

tar-xvfarchive.tar释放一个包

tar-xvfarchive.tar-C/tmp将压缩包释放到/tmp目录下

tar-cvfjarchive.tar.bz2dir1创建一个bzip2格式的压缩包

tar-xvfjarchive.tar.bz2解压一个bzip2格式的压缩包

tar-cvfzarchive.tar.gzdir1创建一个gzip格式的压缩包

tar-xvfzarchive.tar.gz解压一个gzip格式的压缩包

zipfile1.zipfile1创建一个zip格式的压缩包

zip-rfile1.zipfile1file2dir1将几个文件和目录同时压缩成一个zip格式的压缩包

unzipfile1.zip解压一个zip格式压缩包

返回顶部索引^

RPM包-(Fedora,Redhat及类似系统)

rpm-ivhpackage.rpm安装一个rpm包

rpm-ivh--nodeepspackage.rpm安装一个rpm包而忽略依赖关系警告

rpm-Upackage.rpm更新一个rpm包但不改变其配置文件

rpm-Fpackage.rpm更新一个确定已经安装的rpm包

rpm-epackage_name.rpm删除一个rpm包

rpm-qa显示系统中所有已经安装的rpm包

rpm-qa|grephttpd显示所有名称中包含"httpd"字样的rpm包

rpm-qipackage_name获取一个已安装包的特殊信息

rpm-qg"SystemEnvironment/Daemons"显示一个组件的rpm包

rpm-qlpackage_name显示一个已经安装的rpm包提供的文件列表

rpm-qcpackage_name显示一个已经安装的rpm包提供的配置文件列表

rpm-qpackage_name--whatrequires显示与一个rpm包存在依赖关系的列表

rpm-qpackage_name--whatprovides显示一个rpm包所占的体积

rpm-qpackage_name--scripts显示在安装/删除期间所执行的脚本l

rpm-qpackage_name--changelog显示一个rpm包的修改历史

rpm-qf/etc/httpd/conf/httpd.conf确认所给的文件由哪个rpm包所提供

rpm-qppackage.rpm-l显示由一个尚未安装的rpm包提供的文件列表

rpm--import/media/cdrom/RPM-GPG-KEY导入公钥数字证书

rpm--checksigpackage.rpm确认一个rpm包的完整性

rpm-qagpg-pubkey确认已安装的所有rpm包的完整性

rpm-Vpackage_name检查文件尺寸、许可、类型、所有者、群组、MD5检查以及最后修改时间

rpm-Va检查系统中所有已安装的rpm包-小心使用

rpm-Vppackage.rpm确认一个rpm包还未安装

rpm2cpiopackage.rpm|cpio--extract--make-directories*bin*从一个rpm包运行可执行文件

rpm-ivh/usr/src/redhat/RPMS/`arch`/package.rpm从一个rpm源码安装一个构建好的包

rpmbuild--rebuildpackage_name.src.rpm从一个rpm源码构建一个rpm包

返回顶部索引^

YUM软件包升级器-(Fedora,RedHat及类似系统)

yuminstallpackage_name下载并安装一个rpm包

yumlocalinstallpackage_name.rpm将安装一个rpm包,使用你自己的软件仓库为你解决所有依赖关系

yumupdatepackage_name.rpm更新当前系统中所有安装的rpm包

yumupdatepackage_name更新一个rpm包

yumremovepackage_name删除一个rpm包

yumlist列出当前系统中安装的所有包

yumsearchpackage_name在rpm仓库中搜寻软件包

yumcleanpackages清理rpm缓存删除下载的包

yumcleanheaders删除所有头文件

yumcleanall删除所有缓存的包和头文件

返回顶部索引^

DEB包(Debian,Ubuntu以及类似系统)

dpkg-ipackage.deb安装/更新一个deb包

dpkg-rpackage_name从系统删除一个deb包

dpkg-l显示系统中所有已经安装的deb包

dpkg-l|grephttpd显示所有名称中包含"httpd"字样的deb包

dpkg-spackage_name获得已经安装在系统中一个特殊包的信息

dpkg-Lpackage_name显示系统中已经安装的一个deb包所提供的文件列表

dpkg--contentspackage.deb显示尚未安装的一个包所提供的文件列表

dpkg-S/bin/ping确认所给的文件由哪个deb包提供

返回顶部索引^

APT软件工具(Debian,Ubuntu以及类似系统)

apt-getinstallpackage_name安装/更新一个deb包

apt-cdrominstallpackage_name从光盘安装/更新一个deb包

apt-getupdate升级列表中的软件包

apt-getupgrade升级所有已安装的软件

apt-getremovepackage_name从系统删除一个deb包

apt-getcheck确认依赖的软件仓库正确

apt-getclean从下载的软件包中清理缓存

apt-cachesearchsearched-package返回包含所要搜索字符串的软件包名称

返回顶部索引^

查看文件内容

catfile1从第一个字节开始正向查看文件的内容

tacfile1从最后一行开始反向查看一个文件的内容

morefile1查看一个长文件的内容

lessfile1类似于'more'命令,但是它允许在文件中和正向操作一样的反向操作

head-2file1查看一个文件的前两行

tail-2file1查看一个文件的最后两行

tail-f/var/log/messages实时查看被添加到一个文件中的内容

返回顶部索引^

文本处理

catfile1file2...|command<>file1_in.txt_or_file1_out.txtgeneralsyntaxfortextmanipulationusingPIPE,STDINandSTDOUT

catfile1|command(sed,grep,awk,grep,etc...)>result.txt合并一个文件的详细说明文本,并将简介写入一个新文件中

catfile1|command(sed,grep,awk,grep,etc...)>>result.txt合并一个文件的详细说明文本,并将简介写入一个已有的文件中

grepAug/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'文件中所有包含数字的行

grepAug-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-nfile1标示文件的行数

catexample.txt|awk'NR%2==1'删除example.txt文件中的所有偶数行

echoabc|awk'{print$1}'查看一行第一栏

echoabc|awk'{print$1,$3}'查看一行的第一和第三栏

pastefile1file2合并两个文件或两栏的内容

paste-d'+'file1file2合并两个文件或两栏的内容,中间用"+"区分

sortfile1file2排序两个文件的内容

sortfile1file2|uniq取出两个文件的并集(重复的行只保留一份)

sortfile1file2|uniq-u删除交集,留下其他的行

sortfile1file2|uniq-d取出两个文件的交集(只留下同时存在于两个文件中的文件)

comm-1file1file2比较两个文件的内容只删除'file1'所包含的内容

comm-2file1file2比较两个文件的内容只删除'file2'所包含的内容

comm-3file1file2比较两个文件的内容只删除两个文件共有的部分

返回顶部索引^

字符设置和文件格式转换

dos2unixfiledos.txtfileunix.txt将一个文本文件的格式从MSDOS转换成UNIX

unix2dosfileunix.txtfiledos.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分区创建一个linuxext2的文件系统

mke2fs-j/dev/hda1在hda1分区创建一个linuxext3(日志型)的文件系统

mkfs-tvfat32-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-essh--delete/homeip_address:/tmp通过SSH通道rsync

rsync-az-essh--deleteip_addr:/home/public/home/local通过ssh和压缩将一个远程目录同步到本地目录

rsync-az-essh--delete/home/localip_addr:/home/public通过ssh和压缩将本地目录同步到远程目录

ddbs=1Mif=/dev/hda|gzip|sshuser@ip_addr'ddof=hda.gz'通过ssh在远程主机上执行一次备份本地磁盘的操作

ddif=/dev/sdaof=/tmp/file1备份磁盘内容到一个文件

tar-Pufbackup.tar/home/user执行一次对'/home/user'目录的交互式备份操作

(cd/tmp/local/&&tarc.)|ssh-Cuser@ip_addr'cd/home/share/&&tarx-p'通过ssh在远程目录中复制一个目录内容

(tarc/home)|ssh-Cuser@ip_addr'cd/home/backup-home&&tarx-p'通过ssh在远程目录中复制一个本地目录

tarcf-.|(cd/tmp/backup;tarxf-)本地将一个目录复制到另一个地方,保留原有权限及链接

find/home/user1-name'*.txt'|xargscp-av--target-directory=/home/backup/--parents从一个目录查找并复制所有以'.txt'结尾的文件到另一个目录

find/var/log-name'*.log'|tarcv--files-from=-|bzip2>log.tar.bz2查找所有以'.log'结尾的文件并做成一个bzip包

ddif=/dev/hdaof=/dev/fd0bs=512count=1做一个将MBR(MasterBootRecord)内容复制到软盘的动作

ddif=/dev/fd0of=/dev/hdabs=512count=1从已经保存到软盘的备份中恢复MBR内容

返回顶部索引^

光盘

cdrecord-vgracetime=2dev=/dev/cdrom-ejectblank=fast-force清空一个可复写的光盘内容

mkisofs/dev/cdrom>cd.iso在磁盘上创建一个光盘的iso镜像文件

mkisofs/dev/cdrom|gzip>cd_iso.gz在磁盘上创建一个压缩了的光盘iso镜像文件

mkisofs-J-allow-leading-dots-R-V"LabelCD"-iso-level4-o./cd.isodata_cd创建一个目录的iso镜像文件

cdrecord-vdev=/dev/cdromcd.iso刻录一个ISO镜像文件

gzip-dccd_iso.gz|cdrecorddev=/dev/cdrom-刻录一个压缩了的ISO镜像文件

mount-oloopcd.iso/mnt/iso挂载一个ISO镜像文件

cd-paranoia-B从一个CD光盘转录音轨到wav文件中

cd-paranoia--"-3"从一个CD光盘转录音轨到wav文件中(参数-3)

cdrecord--scanbus扫描总线以识别scsi通道

ddif=/dev/hdc|md5sum校验一个设备的md5sum编码,例如一张CD

返回顶部索引^

网络-(以太网和WIFI无线)

ifconfigeth0显示一个以太网卡的配置

ifupeth0启用一个'eth0'网络设备

ifdowneth0禁用一个'eth0'网络设备

ifconfigeth0192.168.1.1netmask255.255.255.0控制IP地址

ifconfigeth0promisc设置'eth0'成混杂模式以嗅探数据包(sniffing)

dhclienteth0以dhcp模式启用'eth0'

route-nshowroutingtable

routeadd-net0/0gwIP_Gatewayconfiguradefaultgateway

routeadd-net192.168.0.0netmask255.255.0.0gw192.168.1.1configurestaticroutetoreachnetwork'192.168.0.0/16'

routedel0/0gwIP_gatewayremovestaticroute

echo"1">/proc/sys/net/ipv4/ip_forwardactivateiprouting

hostnameshowhostnameofsystem

hostwww.example.comlookuphostnametoresolvenametoipaddressandviceversa(1)

nslookupwww.example.comlookuphostnametoresolvenametoipaddressandviceversa(2)

iplinkshowshowlinkstatusofallinterfaces

mii-tooleth0showlinkstatusof'eth0'

ethtooleth0showstatisticsofnetworkcard'eth0'

netstat-tupshowallactivenetworkconnectionsandtheirPID

netstat-tuplshowallnetworkserviceslisteningonthesystemandtheirPID

tcpdumptcpport80showallHTTPtraffic

iwlistscanshowwirelessnetworks

iwconfigeth1showconfigurationofawirelessnetworkcard

hostnameshowhostname

hostwww.example.comlookuphostnametoresolvenametoipaddressandviceversa

nslookupwww.example.comlookuphostnametoresolvenametoipaddressandviceversa

whoiswww.example.comlookuponWhoisdatabase

GOTOPINDEX^

MicrosoftWindowsnetworks(SAMBA)

nbtscanip_addrnetbiosnameresolution

nmblookup-Aip_addrnetbiosnameresolution

smbclient-Lip_addr/hostnameshowremotesharesofawindowshost

smbget-Rrsmb://ip_addr/sharelikewgetcandownloadfilesfromahostwindowsviasmb

mount-tsmbfs-ousername=user,password=pass//WinClient/share/mnt/sharemountawindowsnetworkshare


(责任编辑:网络)

本文关键字:

大全命令常用文件一个目录

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  linux