Loading... <p>1.linux上的文件管理类命令都用哪些,其常用的使用方法及其相关示例演示。</p> <p>常用命令有:cp, mv, rm</p> <p></p> <p><span class="Apple-tab-span"> </span>复制命令:cp</p> <p><span class="Apple-tab-span"> </span>cp [OPTION]… [-T] SOURCE DEST</p> <p> cp [OPTION]… SOURCE… DIRECTORY</p> <p> cp [OPTION]… -t DIRECTORY SOURCE…</p> <p></p> <p> cp SRC DEST</p> <p> <span class="Apple-tab-span"> </span>SRC是文件:</p> <p> <span class="Apple-tab-span"> </span>如果目标不存在:新建DEST,并将SRC中内容填充至DEST中;</p> <p> [root@ocp etc]# more nano1</p> <p> nano1: No such file or directory</p> <p> [root@ocp etc]# cp issue nano1</p> <p> [root@ocp etc]# more issue</p> <p> Red Hat Enterprise Linux Server release 5.4 (Tikanga)</p> <p> Kernel \r on an \m</p> <p> <span class="Apple-tab-span"> </span>如果目标存在:</p> <p> <span class="Apple-tab-span"> </span>如果DEST是文件:将SRC中的内容覆盖至DEST中;此时建议为cp命令使用-i选项;</p> <p> [root@ocp etc]# cp -i issue nano1</p> <p> cp: overwrite `nano1'? y</p> <p> [root@ocp etc]# </p> <p> <span class="Apple-tab-span"> </span></p> <p> <span class="Apple-tab-span"> </span>如果DEST是目录:在DEST下新建与原文件同名的文件,并将SRC中内容填充至新文件中;</p> <p> 将etc目录下的issue文件复制到etc/ntp目录下:</p> <p> [root@ocp etc]# cp -i issue ntp/issue</p> <p> [root@ocp etc]# more ntp/issue</p> <p> Red Hat Enterprise Linux Server release 5.4 (Tikanga)</p> <p> Kernel \r on an \m</p> <p></p> <p></p> <p> cp SRC… DEST</p> <p> <span class="Apple-tab-span"> </span>SRC…:多个文件</p> <p> <span class="Apple-tab-span"> </span>DEST必须存在,且为目录,其它情形均会出错;</p> <p> 将etc下的文件passwd和issue复制到/tmp目录下 </p> <p> [root@ocp etc]# cp -i passwd issue /tmp</p> <p> [root@ocp etc]# ls /tmp</p> <p> issue keyring-WqJMI0 mapping-oracle mapping-root passwd vmware-root</p> <p> 复制etc下的文件passwd和issue,目标为tmp目录下的issue文件:</p> <p> [root@ocp etc]# cp -i passwd issue /tmp/issue</p> <p> cp: target `/tmp/issue' is not a directory</p> <p> [root@ocp etc]# </p> <p> </p> <p></p> <p> cp SRC DEST</p> <p> <span class="Apple-tab-span"> </span>SRC是目录:</p> <p> <span class="Apple-tab-span"> </span>此时使用选项:-r</p> <p> 常用选项:</p> <p> <span class="Apple-tab-span"> </span>-i:交互式</p> <p> <span class="Apple-tab-span"> </span>-r, -R: 递归复制目录及内部的所有内容;</p> <p> <span class="Apple-tab-span"> </span>-a: 归档,相当于-dR –preserv=all</p> <p> <span class="Apple-tab-span"> </span>-d:–no-dereference –preserv=links</p> <p> <span class="Apple-tab-span"> </span>–preserv[=ATTR_LIST]</p> <p> <span class="Apple-tab-span"> </span>mode: 权限</p> <p> <span class="Apple-tab-span"> </span>ownership: 属主属组</p> <p> <span class="Apple-tab-span"> </span>timestamp: </p> <p> <span class="Apple-tab-span"> </span>links</p> <p> <span class="Apple-tab-span"> </span>xattr</p> <p> <span class="Apple-tab-span"> </span>context</p> <p> <span class="Apple-tab-span"> </span>all</p> <p> <span class="Apple-tab-span"> </span>-p: –preserv=mode,ownership,timestamp</p> <p> <span class="Apple-tab-span"> </span>-v: –verbose</p> <p> <span class="Apple-tab-span"> </span>-f: –force</p> <p></p> <p></p> <p> <span class="Apple-tab-span"> </span>如果DEST不存在:则创建指定目录,复制SRC目录中所有文件至DEST中;</p> <p> <span class="Apple-tab-span"> </span>如果DEST存在:</p> <p> <span class="Apple-tab-span"> </span></p> <p>如果DEST是目录:</p> <p>[root@ocp etc]# ls ntp</p> <p>issue keys nano1 ntpservers step-tickers</p> <p>[root@ocp etc]# ls yum</p> <p>pluginconf.d yum-updatesd.conf</p> <p>[root@ocp etc]# cp -i -r ntp yum</p> <p>[root@ocp etc]# ls yum</p> <p>ntp pluginconf.d yum-updatesd.conf</p> <p>[root@ocp etc]# ls yum/ntp</p> <p>issue keys nano1 ntpservers step-tickers</p> <p>[root@ocp etc]# </p> <p></p> <p>如果DEST是文件:报错</p> <p></p> <p>[root@ocp etc]# cp -i -r ntp yum/yum-updatesd.conf </p> <p>cp: cannot overwrite non-directory `yum/yum-updatesd.conf' with directory `ntp'</p> <p>[root@ocp etc]# </p> <p> </p> <p> mv: move,移动文件</p> <p> mv [OPTION]… [-T] SOURCE DEST</p> <p> mv [OPTION]… SOURCE… DIRECTORY</p> <p> mv [OPTION]… -t DIRECTORY SOURCE…</p> <p> </p> <p> 常用选项:</p> <p> <span class="Apple-tab-span"> </span>-i: 交互式</p> <p>[root@ocp etc]# mv -i issue ntp/issue</p> <p>mv: overwrite `ntp/issue'? y</p> <p></p> <p> <span class="Apple-tab-span"> </span>-f: 强制</p> <p>[root@ocp etc]# mv -f ntp/issue issue</p> <p>[root@ocp etc]# more issue</p> <p>Red Hat Enterprise Linux Server release 5.4 (Tikanga)</p> <p>Kernel \r on an \m</p> <p></p> <p>[root@ocp etc]# </p> <p></p> <p> rm: remove,删除</p> <p> <span class="Apple-tab-span"> </span>rm [OPTION]… FILE…</p> <p></p> <p> <span class="Apple-tab-span"> </span>常用选项:</p> <p> <span class="Apple-tab-span"> </span>-i: 交互式</p> <p>交互式删除/tmp下的passwd文件,并选择不删除</p> <p>[root@ocp etc]# rm -i /tmp/passwd </p> <p>rm: remove regular file `/tmp/passwd'? n </p> <p>[root@ocp etc]# ls /tmp</p> <p>issue keyring-WqJMI0 mapping-oracle mapping-root passwd vmware-root</p> <p> <span class="Apple-tab-span"> </span>-f: 强制删除</p> <p> <span class="Apple-tab-span"> </span>-r: 递归</p> <p></p> <p> <span class="Apple-tab-span"> </span>rm -rf </p> <p></p> <p>[root@ocp etc]# rm -rf /tmp/passwd </p> <p>[root@ocp etc]# ls /tmp</p> <p>issue keyring-WqJMI0 mapping-oracle mapping-root vmware-root</p> <p>[root@ocp etc]# </p> <p> </p> <p></p> <p></p> <p>2、bash的工作特性之命令执行状态返回值和命令行展开所涉及的内容及其示例演示。</p> <p> 命令的状态结果</p> <p><span class="Apple-tab-span"> </span>成功:0</p> <p><span class="Apple-tab-span"> </span>失败:1-255</p> <p></p> <p>[root@ocp etc]# rm -rf /tmp/passwd</p> <p>[root@ocp etc]# echo $?</p> <p>0</p> <p>[root@ocp etc]# more /tmp/passwd</p> <p>/tmp/passwd: No such file or directory</p> <p>[root@ocp etc]# echo $?</p> <p>0</p> <p>[root@ocp etc]# moore /tmp/passwd</p> <p>-bash: moore: command not found</p> <p>[root@ocp etc]# echo $?</p> <p>127</p> <p>[root@ocp etc]# </p> <p>命令行展开:</p> <p> ~: 展开为用户的主目录</p> <p><span class="Apple-tab-span"> </span>~USERNAME:展开为指定用户的主目录</p> <p>[root@ocp ~]# cd ~</p> <p>[root@ocp ~]# cd ~oracle</p> <p>[root@ocp oracle]# ls</p> <p>backup Desktop</p> <p>[root@ocp oracle]# pwd</p> <p>/home/oracle</p> <p><span class="Apple-tab-span"> </span>{}:可承载一个以逗号分隔的列表,并将其展开为多个路径</p> <p><span class="Apple-tab-span"> </span>/tmp/{a,b} = /tmp/a, /tmp/b</p> <p><span class="Apple-tab-span"> </span>/tmp/{tom,jerry}/hi = /tmp/tom/hi, /tmp/jerry/hi</p> <p></p> <p>示例演示:</p> <p>创建x-a,y_a,x_b,y_b:</p> <p>mkdir {x,y}_{a,b}</p> <p>[root@ocp oracle]# cd /tmp</p> <p>[root@ocp tmp]# mkdir {x,y}_{a,b}</p> <p>[root@ocp tmp]# ls</p> <p>issue keyring-WqJMI0 mapping-oracle mapping-root vmware-root x_a x_b y_a y_b</p> <p>[root@ocp tmp]# </p> <p></p> <p>3、使用命令行展开功能完成以下练习:</p> <p>(1)、创建/tmp目录下的:a_c,a_d,b_c,b_d:</p> <p>[root@ocp tmp]# mkdir {a,b}_{c,d}</p> <p>[root@ocp tmp]# ls</p> <p>a_c a_d b_c b_d issue keyring-WqJMI0 mapping-oracle mapping-root vmware-root x_a x_b y_a y_b</p> <p>[root@ocp tmp]# </p> <p>(2)、创建/tmp/mylinux目录下的:</p> <p>[root@ocp tmp]# ls</p> <p>issue keyring-WqJMI0 mapping-oracle mapping-root vmware-root</p> <p>[root@ocp tmp]# mkdir -p mylinux/{bin,boot/grub,dev,etc/{rc.d/init.d,sysconfig/network-scripts},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{lock,log,rum}}</p> <p>[root@ocp tmp]# tree</p> <p>.</p> <p>|– issue</p> <p>|– keyring-WqJMI0</p> <p>| `– socket</p> <p>|– mapping-oracle</p> <p>|– mapping-root</p> <p>|– mylinux</p> <p>| |– bin</p> <p>| |– boot</p> <p>| | `– grub</p> <p>| |– dev</p> <p>| |– etc</p> <p>| | |– rc.d</p> <p>| | | `– init.d</p> <p>| | `– sysconfig</p> <p>| | `– network-scripts</p> <p>| |– lib</p> <p>| | `– modules</p> <p>| |– lib64</p> <p>| |– proc</p> <p>| |– sbin</p> <p>| |– sys</p> <p>| |– tmp</p> <p>| |– usr</p> <p>| | `– local</p> <p>| | |– bin</p> <p>| | `– sbin</p> <p>| `– var</p> <p>| |– lock</p> <p>| |– log</p> <p>| `– rum</p> <p>`– vmware-root</p> <p> |– vmware-apploader-2684.log</p> <p> `– vmware-apploader-2700.log</p> <p></p> <p></p> <p>4、文件的元数据信息有哪些,分别表示什么含义,如何查看?如何修改文件的时间戳信息。</p> <p>文件的元数据包含访问权限、文件拥有者以及文件数据块的分布信息等等</p> <p>stat /PATH/TO/SOMEFILE:获取指定文件的元数据</p> <p>[root@ocp ~]# stat /etc/issue</p> <p> File: `/etc/issue'</p> <p> Size: 74 Blocks: 16 IO Block: 4096 regular file</p> <p>Device: fd00h/64768d Inode: 11206843 Links: 1</p> <p>Access: (0644/-rw-r–r–) Uid: ( 0/ root) Gid: ( 0/ root)</p> <p>Access: 2016-06-19 16:11:01.000000000 +0800</p> <p>Modify: 2009-08-04 16:25:07.000000000 +0800</p> <p>Change: 2016-06-19 16:10:56.000000000 +0800</p> <p>[root@ocp ~]# </p> <p><span class="Apple-tab-span"> </span></p> <p>三个时间戳:</p> <p><span class="Apple-tab-span"> </span>access time:访问时间,简写为atime,读取文件内容</p> <p><span class="Apple-tab-span"> </span>modify time: 修改时间, mtime,改变文件内容(数据)</p> <p><span class="Apple-tab-span"> </span>change time: 改变时间, ctime,元数据发生改变</p> <p> 使用touch命令可以修改文件的时间戳信息</p> <p> touch命令:</p> <p><span class="Apple-tab-span"> </span>touch [OPTION]… FILE…</p> <p><span class="Apple-tab-span"> </span>-a: only atime</p> <p><span class="Apple-tab-span"> </span>-m: only mtime</p> <p><span class="Apple-tab-span"> </span>-t STAMP:</p> <p></p> <p>5、如何定义一个命令的别名,如何在命令中引用另外一个命令的执行结果?</p> <p>命令的别名通过alias命令实现,</p> <p>alias NAME='VALUE'</p> <p>撤消别名:unalias</p> <p>unalias [-a] name [name …]</p> <p></p> <p>可以使用管道,实现在命令中引用另外一个命令的执行结果</p> <p></p> <p>6、显示/var目录下所有以l开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其它字符)的文件或目录。</p> <p></p> <p>[root@ocp ~]# ls /var</p> <p>account crash db games lib local log nis preserve run tmp www</p> <p>cache cvs empty gdm lin3b lock mail opt racoon spool tux yp</p> <p>[root@ocp ~]# ls -d /var/l*[0-9]*[[:lower:]]</p> <p>/var/lin3b</p> <p>[root@ocp ~]# </p> <p></p> <p>7、显示/etc目录下,以任意一位数字开头,且以非数字结尾的文件或目录:</p> <p></p> <p>[root@ocp etc]# ls -d /etc/[0-9]*[^0-9]</p> <p>/etc/1xy</p> <p>[root@ocp etc]# </p> <p></p> <p>8、显示/etc/目录下,以非字母开头,后面跟了一个字母及其它任意长度任意字符的文件或目录</p> <p>[root@ocp etc]# ls -d /etc/[^[:alpha:]][[:alpha:]]*</p> <p>/etc/1xy</p> <p></p> <p>9、在/tmp目录下创建以tfile开头,后面跟当前日期时间的文件,文件名如tfile-2016-5-27-09-32-22</p> <p></p> <p>[root@ocp etc]# touch /tmp/tfile-`date "+%Y-%m-%d-%H-%M-%S"`</p> <p>[root@ocp etc]# ls /tmp</p> <p>issue keyring-WqJMI0 mapping-oracle mapping-root mylinux tfile-2016-06-19-22-28-11 vmware-root</p> <p>[root@ocp etc]# date</p> <p>Sun Jun 19 22:28:39 CST 2016</p> <p></p> <p>10、复制/etc目录下所有p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中</p> <p>[root@ocp etc]# ls /tmp</p> <p>issue keyring-WqJMI0 mapping-oracle mapping-root mylinux tfile-2016-06-19-22-28-11 vmware-root</p> <p>[root@ocp etc]# cp -r /etc/p*[^0-9] /tmp/mytest1</p> <p>cp: target `/tmp/mytest1' is not a directory</p> <p>[root@ocp etc]# mkdir /tmp/mytest1</p> <p>[root@ocp etc]# cp -r /etc/p*[^0-9] /tmp/mytest1</p> <p>[root@ocp etc]# ls /tmp/mytest1</p> <p>pam.d pango passwd- php.d pinforc pm prelink.cache prelink.conf.d profile protocols</p> <p>pam_smb.conf passwd pcmcia php.ini pki ppp prelink.conf printcap profile.d</p> <p>[root@ocp etc]# </p> <p></p> <p>11、复制/etc目录下所有以.d结尾的文件或目录到/tmp/mytest2目录中</p> <p></p> <p>[root@ocp etc]# cp -r /etc/*.d /tmp/mytest2</p> <p>cp: target `/tmp/mytest2' is not a directory</p> <p>[root@ocp etc]# mkdir /tmp/mytest2</p> <p>[root@ocp etc]# cp -r /etc/*.d /tmp/mytest2</p> <p>[root@ocp etc]# ls /tmp/mytest2</p> <p>cron.d dnsmasq.d ld.so.conf.d makedev.d pam.d profile.d rc2.d rc5.d readahead.d sane.d yum.repos.d</p> <p>depmod.d gre.d logrotate.d modprobe.d php.d rc0.d rc3.d rc6.d reader.conf.d setuptool.d</p> <p>dev.d init.d lsb-release.d netplug.d prelink.conf.d rc1.d rc4.d rc.d rwtab.d xinetd.d</p> <p></p> <p>12、复制/etc目录下所有以l或m或n开头,以.conf结尾的文件到/tmp/mytest3目录中</p> <p></p> <p>[root@ocp etc]# cp -r /etc/[l,m,n]*.conf /tmp/mytest3</p> <p>cp: target `/tmp/mytest3' is not a directory</p> <p>[root@ocp etc]# mkdir /tmp/mytest3</p> <p>[root@ocp etc]# cp -r /etc/[l,m,n]*.conf /tmp/mytest3</p> <p>[root@ocp etc]# ls /tmp/mytest3</p> <p>ldap.conf lftp.conf libuser.conf ltrace.conf modprobe.conf multipath.conf nsswitch.conf</p> <p>ld.so.conf libaudit.conf logrotate.conf mke2fs.conf mtools.conf nscd.conf ntp.conf</p> <p></p> 最后修改:2021 年 12 月 10 日 10 : 53 AM © 允许规范转载 赞赏 如果觉得我的文章对你有用,请随意赞赏 赞赏作者 支付宝微信