shell常用命令

常用的命令

 1、stat 可以详细显示文件的信息

 [root@server~]#stat test

 File:‘test’  Size:2 Blocks:8  IOBlock:4096  regularfile

 Device:fd00h/64768d Inode:67223147    Links:1

Access:(0644/-rw-r--r--)    Uid:( 0/ root)    Gid:( 0/ root) 

Access:2017-06-0915:30:51.797642579+0800 

Modify:2017-06-0915:30:47.955971908+0800 

Change:2017-06-0915:30:47.955971908+0800 Birth:

2、mktemp 

Linuxmktemp 命令用于建立暂存文件。 

mktemp 建立的一个暂存文件,供 shellscript 使用。 

语法

 mktemp[-qu][文件名参数] 

参数: 

        -q 执行时若发生错误,不会显示任何信息。

       -u 暂存文件会在 mktemp 结束前先行删除。

 [文件名参数] 文件名参数必须是以"自订名称.XXXXXX"的格式。

实例

使用 mktemp 命令生成临时文件时,文件名参数应当以"文件名.XXXX"的形式给出, mktemp 会根据文件名参数建立一个临时文件。在命令行提示符输入如下命令:

 [root@server~]#mktemptmp.XXXXXX tmp.dDMkkq

3、split 

split 命令可以将一个大文件分割成很多个小文件,有时需要将文件分割成更小的片段,比 如为提高可读性,生成日志等。 

选项      -b:值为每一输出档案的大小,单位为 byte。 

            -C:每一输出档中,单行的最大 byte 数。

           -d:使用数字作为后缀。 

    -l:值为每一输出档的列数大小。 

实例: 

生成一个大小为 100KB 的测试文件:

[root@server~]#ddif=/dev/zerobs=100kcount=1of=date.file 

1+0recordsin 

1+0recordsout 

102400bytes(102kB)copied,0.000643191s,159MB/s

使用 split 命令将上面创建的 date.file 文件分割成大小为 10KB 的小文件:

 [root@server~]#split-b10kdate.file

[root@server~]#ls 

anaconda-ks.cfg date.file xaa xab xac xad xae xaf xag xah xai xaj

文件被分割成多个带有字母的后缀文件,如果想用数字后缀可使用-d 参数,同时可以使用alength 来指定后缀的长度: [root@server~]#rm-rfxa* 

[root@server~]#split-b10kdate.file-d-a3 

[root@server~]#ls 

anaconda-ks.cfg x000 x002 x004 x006 x008 

date.file x001 x003 x005 x007 x009

为分割后的文件指定文件名的前缀:

 [root@server~]#rm-rfx* 

[root@server~]#ls anaconda-ks.cfg date.file 

[root@server~]#split-b10kdate.file-d-a3split_file 

[root@server~]#ls 

anaconda-ks.cfg split_file001 split_file004 split_file007 

date.file split_file002 split_file005 split_file008 

split_file000 split_file003 split_file006 split_file009

4、shuf 

随机排序命令 主要用来生成一个随机数 

生成一个随机数 

[root@server~]#shuf-i1-6-n1 5

5、tr 

tr 命令可以对来自标准输入的字符进行替换、压缩和删除。它可以将一组字符变成另 一组字符,经常用来编写优美的单行命令,作用很强大。

语法 tr(选项)(参数)

选项 

-c 或——complerment:取代所有不属于第一字符集的字符; 

-d 或——delete:删除所有属于第一字符集的字符; 

-s 或--squeeze-repeats:把连续重复的字符以单独一个字符表示; 

-t 或--truncate-set1:先删除第一字符集较第二字符集多出的字符。

参数 

字符集 1:指定要转换或删除的原字符集。当执行转换操作时,必须使用参数“字符集 2”指 定转换的目标字符集。但执行删除操作时,不需要参数“字符集 2”; 

字符集 2:指定要转换成的目标字符集。

实例 

将输入字符由大写转换为小写:

[root@server~]#echo"HELLOWORLD"|tr'A-Z''a-z' 

helloworld 'A-Z' 和 'a-z'都是集合,集合是可以自己制定的,例如:'ABD-}'、'bB.,'、'a-de-h'、'a-c0-9'都 属于集合,集合里可以使用'\n'、'\t',可以可以使用其他 ASCII 字符。

使用 tr 删除字符: 

[root@server~]#echo"hello123world456"|tr-d'0-9' 

hello world

6、basename 

返回一个字符串参数的基本文件名称。 

语法 

basenameString[Suffix] 描述 basename 命令读取 String 参数,删除以 /(斜杠) 结尾的前缀以及任何指定的 Suffix 参 数,并将剩余的基本文件名称写至标准输出。basename 命令应用以下创建基本文件名称 的规则: 

工作步骤: 如果 String 参数是 //(双斜杠) 或如果 String 参数包含的都是斜杠字符,则将字符串 更改为单个 /(斜杠)。跳过步骤 2 到 4。 

从指定字符串除去任何拖尾的 / 字符。 

如果在 String 参数中剩余任何 / 字符,则除去字符串的前缀直到(包含)最后一个 / 字符。 

如果指定 Suffix 参数,且它和字符串中的剩余的字符相同,则不修改此字符串。

例 如,输入: 

示例: 

[root@server~]#basename/etc/sysconfig/ 

sysconfig 

[root@server~]#basename$PATH 

bin

7、dirname 

dirname 命令去除文件名中的非目录部分,仅显示与目录有关的内容。 

dirname 命令读取指定路径名保留最后一个/及其后面的字符,删除其他部分,并写结 果到标准输出。如果最后一个/后无字符,dirname 命令使用倒数第二个/,并忽略其后的 所有字符。 dirname 和 basename 通常在 shell 内部命令替换使用,以指定一个与指定输入文件 名略有差异的输出文件名。

语法 dirname(选项)(参数)

 选项 -help:显示帮助;

--version:显示版本号。

实例 

[root@server~]#dirname/etc/sysconfig/network-scripts/ifcfg-eth0 /etc/sysconfig/network-scripts

8、factor:

可以算出某个数字可以由哪些素数组成:

 [root@server~]#factor100

100:2255

9、常用命令整理


a、系统信息 

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

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

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

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

cat/proc/cpuinfo 显示 CPUinfo 的信息 

cat/proc/interrupts 显示中断 

cat/proc/meminfo 校验内存使用 

cat/proc/swaps 显示哪些 swap 被使用 

cat/proc/version 显示内核的版本

 cat/proc/net/dev 显示网络适配器及统计 

cat/proc/mounts 显示已加载的文件系统 

date 显示系统日期 

cal2007 显示 2007 年的日历表 

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

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

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

shutdown-hnow 关闭系统(1) 

init0 关闭系统(2)

telinit0 关闭系统(3) 

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

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

shutdown-rnow 重启(1)

 reboot 重启(2)

 logout 注销

c、文件和目录 

cd/home 进入 '/home' 目录'

cd.. 返回上一级目录 

cd../.. 返回上两级目录 

cd 进入个人的主目录 

cd~user1 进入个人的主目录

cd- 返回上次所在的目录 

pwd 显示工作路径 

ls 查看目录中的文件 

ls-F 查看目录中的文件 

ls-l 显示文件和目录的详细资料 

ls-a 显示隐藏文件 

ls*[0-9]* 显示包含数字的文件名和目录名 

tree 显示文件和目录由根目录开始的树形结构(1) 

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

d、文件搜索 

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 显示一个二进制文件或可执行文件的完整路径

e、挂载一个文件系统 

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

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

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

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

mount/dev/fd0/mnt/floppy 挂载一个软盘

mount/dev/cdrom/mnt/cdrom 挂载一个 cdrom 或 dvdrom

mount/dev/sdc/mnt/cdrecorder 挂载一个 cdrw 或 dvdrom

mount/dev/sdb/mnt/cdrecorder 挂载一个 cdrw 或 dvdrom

mount-oloopfile.iso/mnt/cdrom 挂载一个文件或 ISO 镜像文件

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

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

mount -t smbfs -o username=user,password=pass //WinClient/share /mnt/share 挂 载 一 个 windows 网络共享

f、磁盘空间

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 类系统)

g、用户和群组

groupaddgroup_name 创建一个新用户组

groupdelgroup_name 删除一个用户组

groupmod-nnew_group_nameold_group_name 重命名一个用户组

useradd -c "Name Surname " -g admin -d /home/user1 -s /bin/bash user1 创 建一 个属 于 "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 登陆进一个新的群组以改变新创建文件的预设群组

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

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

chmod ugo+rwx directory1 设置目录的所有人(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 位

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

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

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

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

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

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

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

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

lsattr 显示特殊的属性

j、打包和压缩文件

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 格式压缩包


k、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 包还未安装

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

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

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


l、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 删除所有缓存的包和头文件

m、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 包提供

n、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 返回包含所要搜索字符串的软件包名称


o、查看文件内容

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

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

morefile1 查看一个长文件的内容 lessfile1 类似于 'more' 命令,但是它允许在文件中和正向操作一样的反向操作

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

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

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


p、文本处理

cat file1 file2 ... | command <> file1_in.txt_or_file1_out.txt general syntax for text manipulation usingPIPE,STDINandSTDOUT

cat file1 | 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 比较两个文件的内容只删除两个文件共有的部分


q、字符设置和文件格式转换

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

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

recode..HTML<page.txt>page.html 将一个文本文件转换成 html

recode-l|more 显示所有允许的转换格式


r、文件系统分析

badblocks-v/dev/sda1 检查磁盘 sda1 上的坏磁块

fsck/dev/sda1 修复/检查 sda1 磁盘上 linux 文件系统的完整性

fsck.ext2/dev/sda1 修复/检查 sda1 磁盘上 ext2 文件系统的完整性

e2fsck/dev/sda1 修复/检查 sda1 磁盘上 ext2 文件系统的完整性

e2fsck-j/dev/sda1 修复/检查 sda1 磁盘上 ext3 文件系统的完整性

fsck.ext3/dev/sda1 修复/检查 sda1 磁盘上 ext3 文件系统的完整性

fsck.vfat/dev/sda1 修复/检查 sda1 磁盘上 fat 文件系统的完整性

fsck.msdos/dev/sda1 修复/检查 sda1 磁盘上 dos 文件系统的完整性

dosfsck/dev/sda1 修复/检查 sda1 磁盘上 dos 文件系统的完整性


s、初始化一个文件系统

mkfs/dev/sda1 在 sda1 分区创建一个文件系统

mke2fs/dev/sda1 在 sda1 分区创建一个 linuxext2 的文件系统

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

mkfs-tvfat32-F/dev/sda1 创建一个 FAT32 文件系统

fdformat-n/dev/fd0 格式化一个软盘

mkswap/dev/sda3 创建一个 swap 文件系统


t、SWAP 文件系统

mkswap/dev/sda3 创建一个 swap 文件系统

swapon/dev/sda3 启用一个新的 swap 文件系统

swapon/dev/sda2/dev/hdb3 启用两个 swap 分区


u、备份

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 和压缩将本地目录同步到 远程目录

dd bs=1M if=/dev/sda | gzip | ssh user@ip_addr 'dd of=sda.gz' 通过 ssh 在远程主机上执行一 次备份本地磁盘的操作

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

tar-Pufbackup.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;tarxf-) 本地将一个目录复制到另一个地方,保留原有权限及链接

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/sda of=/dev/fd0 bs=512 count=1 做一个将 MBR (Master Boot Record)内容复制到 软盘的动作

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


v、光盘

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 "Label CD" -iso-level 4 -o ./cd.iso data_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



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值