⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 linux shell简介.htm

📁 linuxSir 网站的精华文章
💻 HTM
📖 第 1 页 / 共 5 页
字号:
      是区分大小写的。如果已经仔细读过前面部分的话,您想到可以用:<BR><CODE><BR>cd 
      /u<TAB>sr<TAB>l<TAB>/d<TAB><BR></CODE></P>
      <P>扩展成了'/usr/src/linux/drivers/',因此应该是'Documentation'(大写的'D')。</P>
      <P>这种补齐对命令也有效:<BR>
      <DIV class=codeblock><CODE>[tom@belbo tom]$ gre&lt;TAB&gt;<BR>grecord 
      grefer grep<BR>[tom@belbo tom]$ gre</CODE></DIV><BR>在这里 shell 
      将列出所有以字符串'gre'开头的已知命令。<BR><FONT id=2.2 
      size=4><B><BR>二、命令行的历史记录<BR></B></FONT>
      <P></P>
      <P>通过按向上方向键,您可以向后遍历近来在该控制台下输入的命令。用向下方向键可以向前遍历。与 SHIFT 
      键连用的话,您还可以遍历以往在该控制台中的输出。您也可以编辑旧的命令,然后再运行。</P>
      <P>按 <CTRL r>后,shell 
      就进入"reverse-i(ncremental)-search"(向后增量搜索)模式。现在输入您要找的命令的首字母:</P>
      <P>(reverse-i-search)`':. 敲入 'i'可能会变成:</P>
      <P>(reverse-i-search)`i': isdnctrl hangup ippp0</P>
      <P>如果您再按 <ENTER>键,上面的命令将再次执行。而如果您按了向右、向左方向键或 
      <ESC>,上面的命令将回到普通的命令行,这样您就可以进行适当编辑。</P>
      <P>编辑命令行</P>
      <P>通过光标和功能键(Home、End 等键),您可以浏览并编辑命令行,如果您需要,还可以用键盘的快捷方式来完成一般的编辑:<BR>
      <DIV class=codeblock><CODE>l &lt;CTRL k&gt;:删除从光标到行尾的部分<BR>l &lt;CTRL 
      u&gt;:删除从光标到行首的部分<BR>l &lt;ALT d&gt;:删除从光标到当前单词结尾的部分<BR>l &lt;CTRL 
      w&gt;:删除从光标到当前单词开头的部分<BR>l &lt;CTRL a&gt;:将光标移到行首<BR>l &lt;CTRL 
      e&gt;:将光标移到行尾<BR>l &lt;ALT a&gt;:将光标移到当前单词头部<BR>l &lt;ALT 
      e&gt;:将光标移到当前单词尾部<BR>l &lt;CTRL y&gt;:插入最近删除的单词<BR>l 
      &lt;!$&gt;:重复前一个命令最后的参数。</CODE></DIV>
      <P></P>
      <P>例如:您用命令 mkdir peter/pan/documents/tinkerbell 
      新建了一个目录,现在您向用命令'cd'进入该目录,您可以用 cd !$,shell 
      将把前一个命令'mkdir'的参数添加到现在的'cd'后面。</P>
      <P>当您更深入了解Linux后,将看到这些快捷方式在其他应用程序下输入时,有时也有效,比如,在浏览器中的输入框中。<BR><FONT id=2.3 
      size=4><B><BR>三、可用的 Shell 快捷方式<BR></B></FONT></P>
      <P>Red Hat Linux 带有不少快捷方式,其中一部分是 bash 
      原来就有的,而还有一些则是为您预先设置的(在后面您将看到如何设置)。</P>
      <P>由于 home 目录是每位用户的活动中心,许多 Unix 对此有特殊的快捷方式。</P>
      <P>'~'就是您的 home 目录的简写形式。我们假设您在其他目录,想把一个名为'sometext'的文件复制到您 home 目录下的 
      'docs'子目录中。除了输入:<BR>
      <DIV class=codeblock><CODE>cp sometext 
      /home/myusername/docs</CODE></DIV><BR>您还可以用简写:<BR>
      <DIV class=codeblock><CODE>cp sometext ~/docs</CODE></DIV>
      <P></P>
      <P>理论上,这也可以应用在命令'cd'上。无论当前路径在哪里,cd ~ 将回到您的 home 目录。其实还可以简化,只要键入 cd ,就可以返回 
      home 目录了。</P>
      <P>Red Hat Linux 为您提供了一些预先设置的快捷方式(称为'别名',aliases),比如:<BR>
      <DIV class=codeblock><CODE>l ll :将执行'ls -l -k'(以长格式列出目录内容,包括一些文件属性,并以 KB 
      而不是 byte 为单位显示文件大小)<BR>l ls :将执行'ls -F 
      --color=auto'(列出目录内容,加上文件类型标识,并使用颜色)</CODE></DIV><BR>现在,您应该对 shell 
      及一些快捷方式有了进一步的了解,下面我们来看看除了应用一些简单的命令,shell 还能作什么。
      <P></P>
      <P><FONT id=3 size=4><B>第三篇:命令的排列/命令的任务调度/命令的替换</B></FONT></P>
      <P><FONT id=3.1 size=4><B><BR>一、命令的排列<BR></B></FONT></P>
      <P>现在您将看到一些常用的命令排列。您可能想在一行中给出所有命令,然后就可以把注意力转移到其他地方。没问题,shell 
      允许您在不同的命令之间,放上特殊的排列字符(queuing characters) 。这儿将介绍最常用的两种。</P>
      <P>请注意,为了看起来更清楚,我在这些字符两旁加了空格。而在实际应用中,您不一定要这么做,'ls -a ; du -hs'和'ls -a;du 
      -hs'的效果是一样的。</P>
      <P>
      <DIV class=codeblock><CODE>command1 ; command2</CODE></DIV>
      <P></P>
      <P>先执行 command1 ,不管 command1 是否出错,接下来执行 command2 。</P>
      <P>例如:<BR>
      <DIV class=codeblock><CODE>ls -a ; du 
      -hs</CODE></DIV><BR>将先在屏幕上列出目录中的所有内容,然后列出所有目录及其子目录所占磁盘大小。<BR>
      <DIV class=codeblock><CODE>command1 &amp;&amp; 
      command2</CODE></DIV><BR>只有当 command1 正确运行完毕后,才执行 command2 。
      <P></P>
      <P><B>例如:</B><BR>
      <DIV class=codeblock><CODE>ls -a bogusdir &amp;&amp; du -hs</CODE></DIV>
      <P></P>
      <P>将返回 ls: bogusdir: No such file or directory 
      ,而'du'则根本没有运行(这是因为您没有'bogusdir'目录)。如果您将符号换成了';','du'将被执行。</P>
      <P>为了进一步说明';'和'&amp;&amp;'的区别,及一般命令排列的用处,下面举一个经典的例子:Linux 内核的编译和安装。</P>
      <P>要编译、安装 Linux ,您需要执行一串命令:'make dep'、'make clean'、'make bzImage'、'make 
      modules'、'make modules_install'和'make 
      install'。如果要等一个命令完成后,再输入下一个,再等,再输入,……,那就太麻烦了。另一方面,每个命令只有当前面的命令都正确执行完毕后,才能开始执行。如果您用';'来排列命令,则即使有命令执行失败,后面的也照常运行,最后,您可能在'/boot'目录下得到一个有问题的内核映像(image)。而用'&amp;&amp;':<BR>
      <DIV class=codeblock><CODE>make dep &amp;&amp; make clean &amp;&amp; make 
      bzImage &amp;&amp; make modules &amp;&amp; make modules_install &amp;&amp; 
      make install</CODE></DIV>
      <P></P>
      <P>不需要中途打断,就可以编译内核及其模块,并完成后面的安装。<BR><FONT id=3.2 
      size=4><B><BR>二、命令的任务调度<BR></B></FONT></P>
      <P>当您在终端里运行一个命令或开启一个程序时,终端要等到命令或程序运行完毕后,才能再被使用。在 Unix 
      中,我们称这样的命令或程序在前台(foreground)运行。如果您想在终端下运行另一个命令,则需要再打开一个新的终端。</P>
      <P>但这里还有一个更优雅的办法,称为任务调度(jobbing)或后台(backgrounding)。当您运用任务的调度或将命令置于后台,终端就立即解放了,这样一来,终端立即就可以接受新的输入。为实现这样的目的,您只需在命令后面添加一个 
      &amp; :<BR>
      <DIV class=codeblock><CODE>gqview &amp;</CODE></DIV>
      <P></P>
      <P>告诉 shell 将图片查看器'GQview'放到后台去执行(即当成 job 来运行)。</P>
      <P>命令 jobs 将告诉您,在这个终端窗口中,运行着哪些命令与程序:<BR>
      <DIV class=codeblock><CODE>jobs<BR>[1]+ Running gqview &amp;</CODE></DIV>
      <P></P>
      <P>当您要关闭终端窗口时,这一点就很重要,因为关闭终端将导致所有在其中运行的任务都将被中止,在此例中,如果您关闭了终端,由这个终端开启的 
      GQview 程序也将被关闭。</P>
      <P>但如何将前台运行的一个程序放到后台去?没问题:<BR>
      <DIV class=codeblock><CODE>gqview<BR>&lt;CTRL z&gt;<BR>[2]+ Stopped 
      gqview<BR>bg<BR>[2]+ gqview &amp;</CODE></DIV>
      <P></P>
      <P>组合键 <CTRL z>将挂起终端中正在运行的程序,然后您就可以用 bg 命令将其放到后台去执行。</P>
      <P>请注意,在后台运行图形应用程序有时候是有用处的,这样可以在终端下显示这个程序的出错信息,虽然这对您可能没有直接的帮助,当如果碰到了麻烦,向别人询问时,这些出错提示就有用武之地了。</P>
      <P>一些图形程序,很可能还处在测试期(Beta),尽管在后台执行,也会在终端中输出一些信息。如果您对此不满,可以用下面命令:<BR>
      <DIV class=codeblock><CODE>command &amp;&gt;/dev/null 
      &amp;</CODE></DIV><BR>这不仅将程序送到后台执行,还将其输出发到'/dev/null'文件。'/dev/null'是系统的"碎纸机" 
      (shredder),所有送到那里的信息都将消失殆尽。<BR><FONT id=3.3 
      size=4><B><BR>三、命令的替换<BR></B></FONT>
      <P></P>
      <P>命令替换(Command substitution)是一项很实用的功能。我们假设,您想看看 XFree86 文档中的 
      'README.mouse'文件,但您不知道这个文件的位置。但您是位机灵的用户,已经听说了'locate'命令,也安装了'slocate'包,您就可以用:<BR>
      <DIV class=codeblock><CODE>locate 
      README.mouse</CODE></DIV><BR>发现那个文件在'/usr/X11R6/lib/X11/doc'。现在您就可以在终端里用'less'或在文件管理器中进入那个目录然后读取文件。而命令替换可以给您带来一些便捷:<BR>
      <DIV class=codeblock><CODE>less $(locate README.mouse)</CODE></DIV>
      <P></P>
      <P>一步到位。命令'locate README.mouse'的输出(= 
      /usr/X11R6/lib/X11/doc/README.mouse)作为'less'的参数,然后就可以显示文件内容了。</P>
      <P>这种机制的语法是:<BR>
      <DIV class=codeblock><CODE>command1 $(command2)</CODE></DIV>
      <P></P>
      <P>除了'$( )',您还可以用后引号(backquote):<BR>
      <DIV class=codeblock><CODE>command1 `command2`</CODE></DIV>
      <P></P>
      <P>这样虽然可以减少输入,但可读性差,而且很容易就和没有替换功能的一般单引号混淆。我更欣赏前一种方法,但这最终起决于您。</P>
      <P>这里有另外一个例子。我们假设,您打算结束一个名为'rob'的程序。您先得用命令'pidof'找出相应的进程号(Process 
      ID),然后以这个 PID 为参数,运行'kill'命令,这样就可以结束'rob'程序。除了用:<BR>
      <DIV class=codeblock><CODE>pidof rob<BR>567<BR>kill 567</CODE></DIV>
      <P></P>
      <P>您还可以试试:<BR>
      <DIV class=codeblock><CODE>kill `pidof rob`</CODE></DIV>
      <P></P>
      <P>怎么样,效率有所提高吧?</P>
      <P>在下一篇中,我将接着介绍 shell 的另外两种实用的机制:文件名匹配、输出重定向。</P>
      <P><FONT id=4 size=4><B>第四篇:文件名匹配/输出重定向</B></FONT></P>
      <P><FONT id=4.1 size=4><B><BR>一、文件名匹配<BR></B></FONT></P>
      <P>文件名匹配使得您不必一一写出名称,就可以指定多个文件。您将用到一些特殊的字符,称为通配符(wildcards)。</P>
      <P>假设您想用'rm'命令删除目录下所有以字符串'.bak'结尾的文件。除了在'rm'后跟上所有文件名作为参数,您还可以用通配符'*':<BR>
      <DIV class=codeblock><CODE>rm *.bak</CODE></DIV>
      <P></P>
      <P>'*'可匹配一个或多个字符。在本例中,您告诉 shell 将命令'rm'的参数扩展到"所有以'*.bak'结尾的文件",shell 
      就将扩展后的参数告诉'rm'命令。</P>
      <P>您将看到,shell 在命令执行前,就将读取并解释命令行。正是因为这个,您才可以将通配符用于 shell 命令的参数中。</P>
      <P>让我们更进一步地来认识通配符'*'。假定您有个目录,其中含文件'124.bak'、'346.bak'及'583.bak'。您想只保留文件'583.bak',可以用:<BR>
      <DIV class=codeblock><CODE>rm *4*.bak</CODE></DIV>
      <P></P>
      <P>shell 就将'*4*.bak'扩展成"所有含'4'并以'.bak'结尾的字符串"。</P>
      <P>注意到 rm 4*.bak 无法工作,因为这匹配的是以'4'开头的文件。由于目录中没有这样的文件,shell 
      将这个模式扩展为空的字符串,故'rm'将返回出错信息:<BR>
      <DIV class=codeblock><CODE>rm: cannot remove `4*.bak': No such file or 
      directory</CODE></DIV>
      <P></P>
      <P>如果您想保留文件'345.bak',而删除'124.bak'和'583.bak'。这看起来有些难度,因为被删文件的名称除了后缀其他都不同。但幸运的是,您可以用不含有来指定文件:<BR>
      <DIV class=codeblock><CODE>rm *[!6].bak</CODE></DIV>
      <P></P>
      <P>这将被读为:除了以'6.bak'结尾的文件,删除其他所有以'.bak'结尾的文件。您必须将取反号(negation 
      sign)与取反字符(这里是 6)放到括号中,不然的话,shell 会将惊叹号(exclamation mark)解释成历史记录替换的开始(the 
      beginning of a history substitution)。取反号在本篇介绍的所有匹配模式中都有效。</P>
      <P><B>请注意:</B>通配符'*'与取反号连用,很容易产生问题。猜猜<BR>
      <DIV class=codeblock><CODE>rm 
      *[!6]*.bak</CODE></DIV><BR>表示什么?这个命令将删除所有文件,甚至包括名称中包含'6'的文件。如果您将通配符'*'放到了取反号前面和后面,实际上取反号将失效,因为 
      shell 将其解释为"所有名称中任何位置都不含该字符的文件"。在我们的例子里,只有文件'666.bak'不符合该模式。
      <P></P>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -