<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>漫步 &#187; Unix</title>
	<atom:link href="http://roamlog.info/tag/unix/feed" rel="self" type="application/rss+xml" />
	<link>http://roamlog.info</link>
	<description>WordPress, Design, Web2.0, Software, IT, News</description>
	<lastBuildDate>Thu, 29 Dec 2011 11:05:33 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.8.6</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>man 使用技巧两则</title>
		<link>http://roamlog.info/archives/man-tricks.html</link>
		<comments>http://roamlog.info/archives/man-tricks.html#comments</comments>
		<pubDate>Sun, 09 Sep 2007 01:16:07 +0000</pubDate>
		<dc:creator>漫步</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[man]]></category>
		<category><![CDATA[Unix]]></category>

		<guid isPermaLink="false">http://roamlog.cn/index.php/2007/09/09/man-tricks/</guid>
		<description><![CDATA[记得我初学 Linux 使用时，首先了解的就是如何在 Linux 系统中获得帮助的课程。当然，这其中少不了 man 命令的介绍。今天，在 Linux.com 网站读到一篇介绍 man 使用技巧的文章，个人感觉很受用，现介绍给大家分享。

使用书签

man 其实是调用 less 来显示手册页的。因此，在阅读内容比较长的页面时，可以使用书签来标记需要重复阅读的重要内容。标记的方法为：先按 m 键，然后在 mark: 后输入标记字母，如 a。需要说明的是，标记符是区分大小写的，也就是说 a 与 A 是两个不同的标记符。
当你需要返回先前设置的书签时，可以按 ‘ 键（单引号）。此时会显示 goto mark:，输入你设置的标记符即可。


测试命令

当你在阅读 man 手册页时想要对命令的用法进行尝试的话，那么可以使用 !。这让你不必打开新的终端，也不用离开 man 手册的阅读页面。在按下 ! 之后，你就可以自由输入所要测试的命令了。完成后，按回车键将返回到 man 手册的阅读页面。



摘至[LinuxToy]
]]></description>
			<content:encoded><![CDATA[<p>记得我初学 Linux 使用时，首先了解的就是如何在 Linux 系统中获得帮助的课程。当然，这其中少不了 man 命令的介绍。今天，在 Linux.com 网站读到一篇介绍 man 使用技巧的文章，个人感觉很受用，现介绍给大家分享。<a id="more-1391"></a></p>
<ol>
<li><strong>使用书签</strong>
<p><img src='http://roamlog.cn/wp-content/uploads/2007/09/man-trick1.png' alt='man-trick1.png' /></p>
<p>man 其实是调用 less 来显示手册页的。因此，在阅读内容比较长的页面时，可以使用书签来标记需要重复阅读的重要内容。标记的方法为：先按 <strong>m</strong> 键，然后在 mark: 后输入标记字母，如 a。需要说明的是，标记符是区分大小写的，也就是说 a 与 A 是两个不同的标记符。</p>
<p>当你需要返回先前设置的书签时，可以按 <strong>‘</strong> 键（单引号）。此时会显示 goto mark:，输入你设置的标记符即可。
</p>
</li>
<li><strong>测试命令</strong>
<p><img src='http://roamlog.cn/wp-content/uploads/2007/09/man-trick2.png' alt='man-trick2.png' /></p>
<p>当你在阅读 man 手册页时想要对命令的用法进行尝试的话，那么可以使用 <strong>!</strong>。这让你不必打开新的终端，也不用离开 man 手册的阅读页面。在按下 <strong>!</strong> 之后，你就可以自由输入所要测试的命令了。完成后，按回车键将返回到 man 手册的阅读页面。
</p>
</li>
</ol>
<p>摘至[<a href="http://linuxtoy.org/archives/man-tricks.html">LinuxToy</a>]</p>
<img src="http://roamlog.info/?ak_action=api_record_view&id=60&type=feed" alt="" />]]></content:encoded>
			<wfw:commentRss>http://roamlog.info/archives/man-tricks.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>提醒:免费提供Unix/Linux体验和测试环境</title>
		<link>http://roamlog.info/archives/unix-linux-taste-test-environment.html</link>
		<comments>http://roamlog.info/archives/unix-linux-taste-test-environment.html#comments</comments>
		<pubDate>Thu, 22 Mar 2007 06:18:47 +0000</pubDate>
		<dc:creator>漫步</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Unix]]></category>

		<guid isPermaLink="false">http://roamlog.cn/index.php/2007/03/22/unix-linux-taste-test-environment/</guid>
		<description><![CDATA[[color=red]今天收到一封邮件,看了下,蛮有意思的[/color]
尊敬的Sun技术社区用户：漫步（zbsdg）
免费提供Unix/Linux体验和测试环境
http://www.unix-center.net/
Unix体验中心(Unix-Center.Net)的目标是为研究、学习和使用各种版本的Unix和类Unix操作系统的教师、学生和工程技术人员提供一个体验和测试各种版本的Unix和类Unix系统的软硬件平台。该平台能够为所有注册用户免费提供如下服务：
－－ SSH登录
－－ C/C++，Fortran和Java语言开发工具
本站的注册用户可以远程登录进入多个不同的系统，享受该系统上普通用户的所有权限，学习和使用各种版本的Unix和类Unix操作系统的常用命令和功能。开发人员更可以将自己正在开发的应用程序上载到Unix体验中心的服务器，在不同的软硬件平台上编译和运行，充分体验多处理器、多核、多线程的高性能计算的乐趣。

2007年3 月1 日，本站第一台服务器Sun Fire X4100正式投入使用：
硬件环境：2 颗AMD Opteron 280芯片，CPU 主频为2.4 GHz，双核单线程，配置4 GB内存
软件环境：Solaris 10 Update 3 for x84/x64
2007年4 月1 日，本站又将有一台Sun Fire T1000服务器投入使用：
硬件环境：1 颗UltraSPARC T1芯片，CPU 主频为1.0 GHz，八核四线程，配置4 GB内存
软件环境：Solaris 10 Update 3 for SPARC
预计在2007年4 月，本站还将增加一批新的服务器，届时将可以为网友提供FreeBSD，Ubuntu，Fedora等多个版本的Unix和类Unix操作系统。
本站所有服务器均为本站全体注册网友的公共资源，希望能够得到全体网友的关心的爱护。请各位网友不要进行任何未经许可的针对本站任何服务器的压力测试或者是安全测试，或者是利用本站的服务器进行针对其他计算机或者服务器的压力测试或者是安全测试。如果您不小心发现了本站任何服务器的管理员密码或者是系统漏洞，请您尽快与本站的系统管理员联系。
为了感谢各位Unix/Linux爱好者对本站的支持，本站将从2007年6月30日之前注册的网友中随机选取幸运网友1500名。所有的幸运网友都会收到本站赠送的《为什么时光不能够倒流》一书。
《为什么时光不能够倒流》一书由旅居美国的黄金雄博士撰写。黄金雄（西杰）出生台湾南部林边乡下，获得国立台湾大学学士、硕士，美国路易斯安那州立大学博士，现任德州州立大学资深教授，ACM／ICPC大学生软件竞赛亚洲区主任；上海交通大学客座教授及哈尔滨工程大学客座教授。本书以真实流畅、感人至深的语言，描述了20世纪四五十年代的台湾南部乡村生活，文字清新自然，令人耳目一新。作为一个长期旅居海外、事业辉煌的华人教授，作者用平实的语言讲述了他的童年生活和他心中的故乡，为我们了解台湾、了解美国、了解华人在海外的生活，提供了一个新视野。本书看似一本描绘母子、父子之间亲情的叙事抒情作品，实则是作者用心和泪对生活、对亲情的感悟。
感谢您对本站的关心和支持。
Sun技术社区 http://gceclub.sun.com.cn
]]></description>
			<content:encoded><![CDATA[<p>[color=red]今天收到一封邮件,看了下,蛮有意思的[/color]</p>
<p>尊敬的Sun技术社区用户：漫步（zbsdg）</p>
<p>免费提供Unix/Linux体验和测试环境</p>
<p>http://www.unix-center.net/</p>
<p>Unix体验中心(Unix-Center.Net)的目标是为研究、学习和使用各种版本的Unix和类Unix操作系统的教师、学生和工程技术人员提供一个体验和测试各种版本的Unix和类Unix系统的软硬件平台。该平台能够为所有注册用户免费提供如下服务：</p>
<p>－－ SSH登录<br />
－－ C/C++，Fortran和Java语言开发工具</p>
<p>本站的注册用户可以远程登录进入多个不同的系统，享受该系统上普通用户的所有权限，学习和使用各种版本的Unix和类Unix操作系统的常用命令和功能。开发人员更可以将自己正在开发的应用程序上载到Unix体验中心的服务器，在不同的软硬件平台上编译和运行，充分体验多处理器、多核、多线程的高性能计算的乐趣。<br />
<span id="more-27"></span><br />
2007年3 月1 日，本站第一台服务器Sun Fire X4100正式投入使用：</p>
<p>硬件环境：2 颗AMD Opteron 280芯片，CPU 主频为2.4 GHz，双核单线程，配置4 GB内存<br />
软件环境：Solaris 10 Update 3 for x84/x64</p>
<p>2007年4 月1 日，本站又将有一台Sun Fire T1000服务器投入使用：</p>
<p>硬件环境：1 颗UltraSPARC T1芯片，CPU 主频为1.0 GHz，八核四线程，配置4 GB内存<br />
软件环境：Solaris 10 Update 3 for SPARC</p>
<p>预计在2007年4 月，本站还将增加一批新的服务器，届时将可以为网友提供FreeBSD，Ubuntu，Fedora等多个版本的Unix和类Unix操作系统。</p>
<p>本站所有服务器均为本站全体注册网友的公共资源，希望能够得到全体网友的关心的爱护。请各位网友不要进行任何未经许可的针对本站任何服务器的压力测试或者是安全测试，或者是利用本站的服务器进行针对其他计算机或者服务器的压力测试或者是安全测试。如果您不小心发现了本站任何服务器的管理员密码或者是系统漏洞，请您尽快与本站的系统管理员联系。</p>
<p>为了感谢各位Unix/Linux爱好者对本站的支持，本站将从2007年6月30日之前注册的网友中随机选取幸运网友1500名。所有的幸运网友都会收到本站赠送的《为什么时光不能够倒流》一书。</p>
<p>《为什么时光不能够倒流》一书由旅居美国的黄金雄博士撰写。黄金雄（西杰）出生台湾南部林边乡下，获得国立台湾大学学士、硕士，美国路易斯安那州立大学博士，现任德州州立大学资深教授，ACM／ICPC大学生软件竞赛亚洲区主任；上海交通大学客座教授及哈尔滨工程大学客座教授。本书以真实流畅、感人至深的语言，描述了20世纪四五十年代的台湾南部乡村生活，文字清新自然，令人耳目一新。作为一个长期旅居海外、事业辉煌的华人教授，作者用平实的语言讲述了他的童年生活和他心中的故乡，为我们了解台湾、了解美国、了解华人在海外的生活，提供了一个新视野。本书看似一本描绘母子、父子之间亲情的叙事抒情作品，实则是作者用心和泪对生活、对亲情的感悟。</p>
<p>感谢您对本站的关心和支持。</p>
<p>Sun技术社区 http://gceclub.sun.com.cn</p>
<img src="http://roamlog.info/?ak_action=api_record_view&id=27&type=feed" alt="" />]]></content:encoded>
			<wfw:commentRss>http://roamlog.info/archives/unix-linux-taste-test-environment.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>UNIX 高手的 10 个习惯</title>
		<link>http://roamlog.info/archives/ten-habits-of-unix-superior.html</link>
		<comments>http://roamlog.info/archives/ten-habits-of-unix-superior.html#comments</comments>
		<pubDate>Tue, 13 Feb 2007 01:52:58 +0000</pubDate>
		<dc:creator>漫步</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Unix]]></category>

		<guid isPermaLink="false">http://roamlog.cn/index.php/2007/02/13/ten-habits-of-unix-superior/</guid>
		<description><![CDATA[UNIX 高手的 10 个习惯
克服不良的 UNIX 使用模式
采用 10 个能够提高您的 UNIX; 命令行效率的好习惯——并在此过程中摆脱不良的使用模式。本文循序渐进地指导您学习几项用于命令行操作的技术，这些技术非常好，但是通常被忽略。了解常见错误和克服它们的方法，以便您能够确切了解为何值得采用这些 UNIX 习惯。
引言
当您经常使用某个系统时，往往会陷入某种固定的使用模式。有时，您没有养成以尽可能最好的方式做事的习惯。有时，您的不良习惯甚至会导致出现混乱。纠正此类缺点的最佳方法之一，就是有意识地采用抵制这些坏习惯的好习惯。本文提出了 10 个值得采用的 UNIX 命令行习惯——帮助您克服许多常见使用怪癖，并在该过程中提高命令行工作效率的好习惯。下面列出了这 10 个好习惯，之后对进行了更详细的描述。
采用 10 个好习惯
要采用的十个好习惯为：
1.在单个命令中创建目录树。
2.更改路径；不要移动存档。
3.将命令与控制操作符组合使用。
4.谨慎引用变量。
5.使用转义序列来管理较长的输入。
6.在列表中对命令分组。
7.在 find 之外使用 xargs。
8.了解何时 grep 应该执行计数——何时应该绕过。
9.匹配输出中的某些字段，而不只是对行进行匹配。
10.停止对 cat 使用管道。

在单个命令中创建目录树
清单 1 演示了最常见的 UNIX 坏习惯之一：一次定义一个目录树。
清单 1. 坏习惯 1 的示例：单独定义每个目录树

~ $ mkdir tmp
~ $ cd tmp
~/tmp $ mkdir a
~/tmp $ cd a
~/tmp/a $ mkdir b
~/tmp/a $ cd b
~/tmp/a/b/ $ mkdir [...]]]></description>
			<content:encoded><![CDATA[<p>UNIX 高手的 10 个习惯</p>
<p>克服不良的 UNIX 使用模式</p>
<p>采用 10 个能够提高您的 UNIX; 命令行效率的好习惯——并在此过程中摆脱不良的使用模式。本文循序渐进地指导您学习几项用于命令行操作的技术，这些技术非常好，但是通常被忽略。了解常见错误和克服它们的方法，以便您能够确切了解为何值得采用这些 UNIX 习惯。</p>
<p>引言</p>
<p>当您经常使用某个系统时，往往会陷入某种固定的使用模式。有时，您没有养成以尽可能最好的方式做事的习惯。有时，您的不良习惯甚至会导致出现混乱。纠正此类缺点的最佳方法之一，就是有意识地采用抵制这些坏习惯的好习惯。本文提出了 10 个值得采用的 UNIX 命令行习惯——帮助您克服许多常见使用怪癖，并在该过程中提高命令行工作效率的好习惯。下面列出了这 10 个好习惯，之后对进行了更详细的描述。</p>
<p>采用 10 个好习惯</p>
<p>要采用的十个好习惯为：<br />
1.在单个命令中创建目录树。<br />
2.更改路径；不要移动存档。<br />
3.将命令与控制操作符组合使用。<br />
4.谨慎引用变量。<br />
5.使用转义序列来管理较长的输入。<br />
6.在列表中对命令分组。<br />
7.在 find 之外使用 xargs。<br />
8.了解何时 grep 应该执行计数——何时应该绕过。<br />
9.匹配输出中的某些字段，而不只是对行进行匹配。<br />
10.停止对 cat 使用管道。<br />
<span id="more-22"></span></p>
<p>在单个命令中创建目录树</p>
<p>清单 1 演示了最常见的 UNIX 坏习惯之一：一次定义一个目录树。</p>
<p>清单 1. 坏习惯 1 的示例：单独定义每个目录树</p>
<p class=shell>
~ $ mkdir tmp<br />
~ $ cd tmp<br />
~/tmp $ mkdir a<br />
~/tmp $ cd a<br />
~/tmp/a $ mkdir b<br />
~/tmp/a $ cd b<br />
~/tmp/a/b/ $ mkdir c<br />
~/tmp/a/b/ $ cd c<br />
~/tmp/a/b/c $
</p>
<p>使用 mkdir 的 -p 选项并在单个命令中创建所有父目录及其子目录要容易得多。但是即使对于知道此选项的管理员，他们在命令行上创建子目录时也仍然束缚于逐步创建每级子目录。花时间有意识地养成这个好习惯是值得的：</p>
<p>清单 2. 好习惯 1 的示例：使用一个命令来定义目录树</p>
<p class=shell>
~ $ mkdir -p tmp/a/b/c
</p>
<p>您可以使用此选项来创建整个复杂的目录树（在脚本中使用是非常理想的），而不只是创建简单的层次结构。例如：</p>
<p>清单 3. 好习惯 1 的另一个示例：使用一个命令来定义复杂的目录树</p>
<p class=shell>
~ $ mkdir -p project/{lib/ext,bin,src,doc/{html,info,pdf},demo/stat/a}
</p>
<p>过去，单独定义目录的唯一借口是您的 mkdir 实现不支持此选项，但是在大多数系统上不再是这样了。IBM、AIX&#174;、mkdir、GNU mkdir 和其他遵守单一 UNIX 规范 (Single UNIX Specification) 的系统现在都具有此选项。</p>
<p>对于仍然缺乏该功能的少数系统，您可以使用 mkdirhier 脚本（请参见参考资料），此脚本是执行相同功能的 mkdir 的包装：</p>
<p class=shell>
~ $ mkdirhier project/{lib/ext,bin,src,doc/{html,info,pdf},demo/stat/a}
</p>
<p>更改路径；不要移动存档</p>
<p>另一个不良的使用模式是将 .tar 存档文件移动到某个目录，因为该目录恰好是您希望在其中提取 .tar 文件的目录。其实您根本不需要这样做。您可以随心所欲地将任何 .tar 存档文件解压缩到任何目录——这就是 -C 选项的用途。在解压缩某个存档文件时，使用 -C 选项来指定要在其中解压缩该文件的目录：</p>
<p>清单 4. 好习惯 2 的示例：使用选项 -C 来解压缩 .tar 存档文件</p>
<p class=shell>
~ $ tar xvf -C tmp/a/b/c newarc.tar.gz
</p>
<p>相对于将存档文件移动到您希望在其中解压缩它的位置，切换到该目录，然后才解压缩它，养成使用 -C 的习惯则更加可取——当存档文件位于其他某个位置时尤其如此。</p>
<p>将命令与控制操作符组合使用</p>
<p>您可能已经知道，在大多数 Shell 中，您可以在单个命令行上通过在命令之间放置一个分号 (;) 来组合命令。该分号是 Shell 控制操作符，虽然它对于在单个命令行上将离散的命令串联起来很有用，但它并不适用于所有情况。例如，假设您使用分号来组合两个命令，其中第二个命令的正确执行完全依赖于第一个命令的成功完成。如果第一个命令未按您预期的那样退出，第二个命令仍然会运行——结果会导致失败。相反，应该使用更适当的控制操作符（本文将描述其中的部分操作符）。只要您的 Shell 支持它们，就值得养成使用它们的习惯。</p>
<p>仅当另一个命令返回零退出状态时才运行某个命令</p>
<p>使用 &#038;&#038; 控制操作符来组合两个命令，以便仅当 第一个命令返回零退出状态时才运行第二个命令。换句话说，如果第一个命令运行成功，则第二个命令将运行。如果第一个命令失败，则第二个命令根本就不运行。例如：</p>
<p>清单 5. 好习惯 3 的示例：将命令与控制操作符组合使用</p>
<p class=shell>
~ $ cd tmp/a/b/c &#038;&#038; tar xvf ~/archive.tar
</p>
<p>在此例中，存档的内容将提取到 ~/tmp/a/b/c 目录中，除非该目录不存在。如果该目录不存在，则 tar 命令不会运行，因此不会提取任何内容。</p>
<p>仅当另一个命令返回非零退出状态时才运行某个命令</p>
<p>类似地，|| 控制操作符分隔两个命令，并且仅当第一个命令返回非零退出状态时才运行第二个命令。换句话说，如果第一个命令成功，则第二个命令不会运行。如果第一个命令失败，则第二个命令才会 运行。在测试某个给定目录是否存在时，通常使用此操作符，如果该目录不存在，则创建它：</p>
<p>清单 6. 好习惯 3 的另一个示例：将命令与控制操作符组合使用</p>
<p class=shell>
~ $ cd tmp/a/b/c || mkdir -p tmp/a/b/c
</p>
<p>您还可以组合使用本部分中描述的控制操作符。每个操作符都影响最后的命令运行：</p>
<p>清单 7. 好习惯 3 的组合示例：将命令与控制操作符组合使用</p>
<p class=shell>
~ $ cd tmp/a/b/c || mkdir -p tmp/a/b/c &#038;&#038; tar xvf -C tmp/a/b/c ~/archive.tar
</p>
<p>谨慎引用变量</p>
<p>始终要谨慎使用 Shell 扩展和变量名称。一般最好将变量调用包括在双引号中，除非您有不这样做的足够理由。类似地，如果您直接在字母数字文本后面使用变量名称，则还要确保将该变量名称包括在方括号 ([]) 中，以使其与周围的文本区分开来。否则，Shell 将把尾随文本解释为变量名称的一部分——并且很可能返回一个空值。清单 8 提供了变量的各种引用和非引用及其影响的示例。</p>
<p>清单 8. 好习惯 4 的示例：引用（和非引用）变量</p>
<p class=shell>
~ $ ls tmp/<br />
a b<br />
~ $ VAR=&#8221;tmp/*&#8221;<br />
~ $ echo $VAR<br />
tmp/a tmp/b<br />
~ $ echo &#8220;$VAR&#8221;<br />
tmp/*<br />
~ $ echo $VARa</p>
<p>~ $ echo &#8220;$VARa&#8221;</p>
<p>~ $ echo &#8220;${VAR}a&#8221;<br />
tmp/*a<br />
~ $ echo ${VAR}a<br />
tmp/a<br />
~ $
</p>
<p>使用转义序列来管理较长的输入</p>
<p>您或许看到过使用反斜杠 () 来将较长的行延续到下一行的代码示例，并且您知道大多数 Shell 都将您通过反斜杠联接的后续行上键入的内容视为单个长行。然而，您可能没有在命令行中像通常那样利用此功能。如果您的终端无法正确处理多行回绕，或者您的命令行比通常小（例如在提示符下有长路经的时候），反斜杠就特别有用。反斜杠对于了解键入的长输入行的含义也非常有用，如以下示例所示：</p>
<p>清单 9. 好习惯 5 的示例：将反斜杠用于长输入</p>
<p class=shell>
~ $ cd tmp/a/b/c ||<br />
> mkdir -p tmp/a/b/c &#038;&#038;<br />
> tar xvf -C tmp/a/b/c ~/archive.tar
</p>
<p>或者，也可以使用以下配置：</p>
<p>清单 10. 好习惯 5 的替代示例：将反斜杠用于长输入</p>
<p class=shell>
~ $ cd tmp/a/b/c<br />
>                 ||<br />
> mkdir -p tmp/a/b/c<br />
>                    &#038;&#038;<br />
> tar xvf -C tmp/a/b/c ~/archive.tar
</p>
<p>然而，当您将输入行划分到多行上时，Shell 始终将其视为单个连续的行，因为它总是删除所有反斜杠和额外的空格。</p>
<p>注意：在大多数 Shell 中，当您按向上箭头键时，整个多行输入将重绘到单个长输入行上。</p>
<p>在列表中对命令分组</p>
<p>大多数 Shell 都具有在列表中对命令分组的方法，以便您能将它们的合计输出向下传递到某个管道，或者将其任何部分或全部流重定向到相同的地方。您一般可以通过在某个 Subshell 中运行一个命令列表或通过在当前 Shell 中运行一个命令列表来实现此目的。</p>
<p>在 Subshell 中运行命令列表</p>
<p>使用括号将命令列表包括在单个组中。这样做将在一个新的 Subshell 中运行命令，并允许您重定向或收集整组命令的输出，如以下示例所示：</p>
<p>清单 11. 好习惯 6 的示例：在 Subshell 中运行命令列表</p>
<p class=shell>
~ $ ( cd tmp/a/b/c/ || mkdir -p tmp/a/b/c &#038;&#038;<br />
> VAR=$PWD; cd ~; tar xvf -C $VAR archive.tar )<br />
> | mailx admin -S &#8220;Archive contents&#8221;
</p>
<p>在此示例中，该存档的内容将提取到 tmp/a/b/c/ 目录中，同时将分组命令的输出（包括所提取文件的列表）通过邮件发送到地址 admin。</p>
<p>当您在命令列表中重新定义环境变量，并且您不希望将那些定义应用于当前 Shell 时，使用 Subshell 更可取。</p>
<p>在当前 Shell 中运行命令列表</p>
<p>将命令列表用大括号 ({}) 括起来，以在当前 Shell 中运行。确保在括号与实际命令之间包括空格，否则 Shell 可能无法正确解释括号。此外，还要确保列表中的最后一个命令以分号结尾，如以下示例所示：</p>
<p>清单 12. 好习惯 6 的另一个示例：在当前 Shell 中运行命令列表</p>
<p class=shell>
~ $ { cp ${VAR}a . &#038;&#038; chown -R guest.guest a &#038;&#038;<br />
> tar cvf newarchive.tar a; } | mailx admin -S &#8220;New archive&#8221;
</p>
<p>在 find 之外使用 xargs</p>
<p>使用 xargs 工具作为筛选器，以充分利用从 find 命令挑选的输出。find 运行通常提供与某些条件匹配的文件列表。此列表被传递到 xargs 上，后者然后使用该文件列表作为参数来运行其他某些有用的命令，如以下示例所示：</p>
<p>清单 13. xargs 工具的经典用法示例</p>
<p class=shell>
~ $ find some-file-criteria some-file-path |<br />
> xargs some-great-command-that-needs-filename-arguments
</p>
<p>然而，不要将 xargs 仅看作是 find 的辅助工具；它是一个未得到充分利用的工具之一，当您养成使用它的习惯时，将会希望进行所有试验，包括以下用法。</p>
<p>传递空格分隔的列表</p>
<p>在最简单的调用形式中，xargs 就像一个筛选器，它接受一个列表（每个成员分别在单独的行上）作为输入。该工具将那些成员放置在单个空格分隔的行上：</p>
<p>清单 14. xargs 工具产生的输出示例</p>
<p class=shell>
~ $ xargs<br />
a<br />
b<br />
c<br />
Control-D<br />
a b c<br />
~ $
</p>
<p>您可以发送通过 xargs 来输出文件名的任何工具的输出，以便为其他某些接受文件名作为参数的工具获得参数列表，如以下示例所示：</p>
<p>清单 15. xargs 工具的使用示例</p>
<p class=shell>
~/tmp $ ls -1 | xargs<br />
December_Report.pdf README a archive.tar mkdirhier.sh<br />
~/tmp $ ls -1 | xargs file<br />
December_Report.pdf: PDF document, version 1.3<br />
README: ASCII text<br />
a: directory<br />
archive.tar: POSIX tar archive<br />
mkdirhier.sh: Bourne shell script text executable<br />
~/tmp $
</p>
<p>xargs 命令不只用于传递文件名。您还可以在需要将文本筛选到单个行中的任何时候使用它：</p>
<p>清单 16. 好习惯 7 的示例：使用 xargs 工具来将文本筛选到单个行中</p>
<p class=shell>
~/tmp $ ls -l | xargs<br />
-rw-r&#8211;r&#8211; 7 joe joe 12043 Jan 27 20:36 December_Report.pdf -rw-r&#8211;r&#8211; 1<br />
root root 238 Dec 03 08:19 README drwxr-xr-x 38 joe joe 354082 Nov 02<br />
16:07 a -rw-r&#8211;r&#8211; 3 joe joe 5096 Dec 14 14:26 archive.tar -rwxr-xr-x 1<br />
joe joe 3239 Sep 30 12:40 mkdirhier.sh<br />
~/tmp $
</p>
<p>谨慎使用 xargs</p>
<p>从技术上讲，使用 xargs 很少遇到麻烦。缺省情况下，文件结束字符串是下划线 (_)；如果将该字符作为单个输入参数来发送，则它之后的所有内容将被忽略。为了防止这种情况发生，可以使用 -e 标志，它在不带参数的情况下完全禁用结束字符串。</p>
<p>了解何时 grep 应该执行计数——何时应该绕过</p>
<p>避免通过管道将 grep 发送到 wc -l 来对输出行数计数。grep 的 -c 选项提供了对与特定模式匹配的行的计数，并且一般要比通过管道发送到 wc 更快，如以下示例所示：</p>
<p>清单 17. 好习惯 8 的示例：使用和不使用 grep 的行计数</p>
<p class=shell>
~ $ time grep and tmp/a/longfile.txt | wc -l<br />
2811</p>
<p>real    0m0.097s<br />
user    0m0.006s<br />
sys     0m0.032s<br />
~ $ time grep -c and tmp/a/longfile.txt<br />
2811</p>
<p>real    0m0.013s<br />
user    0m0.006s<br />
sys     0m0.005s<br />
~ $
</p>
<p>除了速度因素外，-c 选项还是执行计数的好方法。对于多个文件，带 -c 选项的 grep 返回每个文件的单独计数，每行一个计数，而针对 wc 的管道则提供所有文件的组合总计数。</p>
<p>然而，不管是否考虑速度，此示例都表明了另一个要避免地常见错误。这些计数方法仅提供包含匹配模式的行数——如果那就是您要查找的结果，这没什么问题。但是在行中具有某个特定模式的多个实例的情况下，这些方法无法为您提供实际匹配实例数量 的真实计数。归根结底，若要对实例计数，您还是要使用 wc 来计数。首先，使用 -o 选项（如果您的版本支持它的话）来运行 grep 命令。此选项仅输出匹配的模式，每行一个模式，而不输出行本身。但是您不能将它与 -c 选项结合使用，因此要使用 wc -l 来对行计数，如以下示例所示：</p>
<p>清单 18. 好习惯 8 的示例：使用 grep 对模式实例计数</p>
<p class=shell>
~ $ grep -o and tmp/a/longfile.txt | wc -l<br />
3402<br />
~ $
</p>
<p>在此例中，调用 wc 要比第二次调用 grep 并插入一个虚拟模式（例如 grep -c）来对行进行匹配和计数稍快一点。</p>
<p>匹配输出中的某些字段，而不只是对行进行匹配</p>
<p>当您只希望匹配输出行中特定字段 中的模式时，诸如 awk 等工具要优于 grep。</p>
<p>下面经过简化的示例演示了如何仅列出 12 月修改过的文件。</p>
<p>清单 19. 坏习惯 9 的示例：使用 grep 来查找特定字段中的模式</p>
<p class=shell>
~/tmp $ ls -l /tmp/a/b/c | grep Dec<br />
-rw-r&#8211;r&#8211;  7 joe joe  12043 Jan 27 20:36 December_Report.pdf<br />
-rw-r&#8211;r&#8211;  1 root root  238 Dec 03 08:19 README<br />
-rw-r&#8211;r&#8211;  3 joe joe   5096 Dec 14 14:26 archive.tar<br />
~/tmp $
</p>
<p>在此示例中，grep 对行进行筛选，并输出其修改日期和名称中带 Dec 的所有文件。因此，诸如 December_Report.pdf 等文件是匹配的，即使它自从一月份以来还未修改过。这可能不是您希望的结果。为了匹配特定字段中的模式，最好使用 awk，其中的一个关系运算符对确切的字段进行匹配，如以下示例所示：</p>
<p>清单 20. 好习惯 9 的示例：使用 awk 来查找特定字段中的模式</p>
<p class=shell>
~/tmp $ ls -l | awk &#8216;$6 == &#8220;Dec&#8221;&#8216;<br />
-rw-r&#8211;r&#8211;  3 joe joe   5096 Dec 14 14:26 archive.tar<br />
-rw-r&#8211;r&#8211;  1 root root  238 Dec 03 08:19 README<br />
~/tmp $
</p>
<p>有关如何使用 awk 的更多详细信息，请参见参考资料。</p>
<p>停止对 cat 使用管道</p>
<p>grep 的一个常见的基本用法错误是通过管道将 cat 的输出发送到 grep 以搜索单个文件的内容。这绝对是不必要的，纯粹是浪费时间，因为诸如 grep 这样的工具接受文件名作为参数。您根本不需要在这种情况下使用 cat，如以下示例所示：</p>
<p>清单 21. 好习惯和坏习惯 10 的示例：使用带和不带 cat 的 grep</p>
<p class=shell>
~ $ time cat tmp/a/longfile.txt | grep and<br />
2811</p>
<p>real    0m0.015s<br />
user    0m0.003s<br />
sys     0m0.013s<br />
~ $ time grep and tmp/a/longfile.txt<br />
2811</p>
<p>real    0m0.010s<br />
user    0m0.006s<br />
sys     0m0.004s<br />
~ $
</p>
<p>此错误存在于许多工具中。由于大多数工具都接受使用连字符 (-) 的标准输入作为一个参数，因此即使使用 cat 来分散 stdin 中的多个文件，参数也通常是无效的。仅当您使用带多个筛选选项之一的 cat 时，才真正有必要在管道前首先执行连接。</p>
<p>结束语：养成好习惯</p>
<p>最好检查一下您的命令行习惯中的任何不良的使用模式。不良的使用模式会降低您的速度，并且通常会导致意外错误。本文介绍了 10 个新习惯，它们可以帮助您摆脱许多最常见的使用错误。养成这些好习惯是加强您的 UNIX 命令行技能的积极步骤。</p>
<img src="http://roamlog.info/?ak_action=api_record_view&id=22&type=feed" alt="" />]]></content:encoded>
			<wfw:commentRss>http://roamlog.info/archives/ten-habits-of-unix-superior.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>使用OpenSSH安全远程登陆</title>
		<link>http://roamlog.info/archives/using-openssh-to-remote-connect.html</link>
		<comments>http://roamlog.info/archives/using-openssh-to-remote-connect.html#comments</comments>
		<pubDate>Thu, 08 Feb 2007 07:29:07 +0000</pubDate>
		<dc:creator>漫步</dc:creator>
				<category><![CDATA[FreeBSD]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[ssh]]></category>
		<category><![CDATA[Unix]]></category>

		<guid isPermaLink="false">http://roamlog.cn/index.php/2007/02/08/using-openssh-to-remote-connect/</guid>
		<description><![CDATA[使用OpenSSH安全远程登陆
FreeBSD下使用 OpenSSH。FreeBSD 6.0 默认已经把OpenSSH安装上了，这步可以省略了。OpenSSH是免费软件，可以到 OpenSSH 的主页上http://www.openssh.org 下载。
1.生成密钥对：
使用ssh-keygen来生成密钥对
比如要用DSA加密算法生成一个4096Bit的密钥对可以输入如下命令(具体参数请参阅man ssh-keygen)：
具体命令:ssh-keygen -b 4096 -t dsa
使用SecureCRT生成密钥对
SecureCRT最大只支持2048Bit的密钥。生成步骤是点选Tools－>Create Public Key…,选择密钥算法和密钥长度,输入完口令后再使劲晃鼠标以给它生成密钥的足够的随机量之后就等待计算机生成密钥对。切记一定要使劲晃鼠标 xD
生成的Key默认放在C:Documents and SettingsAdministratorApplication DataVanDyke下，文件Identity是私钥，文件Identity.pub是公钥。

特别要注意的是由SecureCRT生成的密钥对和用OpenSSH生成的密钥对在格式上不一样，而且二者都只能认识自己的密钥的格式，所以在用 SecureCRT同OpenSSH连接时分别都要用它们自己的密钥格式，可以用任何一个方法生成然后使用ssh-keygen -i 把SecureCRT生成的的密钥转换成OpenSSH的密钥格式,或者用ssh-keygen -e把OpenSSH的密钥格式转换成SecureCRT能够识别的IETF SECSH格式。
具体命令:ssh-keygen -i -f identity.pub > openssh.pubkey
2.密钥分发：
刚才生成了一对密钥，把私钥放在自己的机器上的C:Documents and SettingsAdministratorApplication DataVanDyke目录下。再把生成的公钥放在要连接的远程主机的~/.ssh/目录下并改名为authorized_keys,并且保证文件除了属主外没有被人修改的权限。
想新加用户，只需要把生成的密钥copy到authorized_keys即可
3.配置SSH服务端：
用ee /vi /vim 编辑 /etc/ssh/sshd_config 文件，

PermitRootLogin yes
#允许root login
ChallengeResponseAuthentication no
#关掉key interactive login

4.配置SSH客户端—SecureCRT：
SecureCRT–>SSH2–>Authentication–>PublicKey
重启sshd服务

/etc/rc.d/sshd reload

这样就可以更安全的远程登陆了 XD
感谢maxm耐心的指导
Update:
按照上面的步骤还是不行的话，你先看看authorized_keys的属性是什么

[root@betty] /home# ls -l /root/.ssh/
total 4
-rw-r–r– 1 weeker wheel 2228 Aug 3 16:49 [...]]]></description>
			<content:encoded><![CDATA[<p>使用OpenSSH安全远程登陆</p>
<p>FreeBSD下使用 OpenSSH。FreeBSD 6.0 默认已经把OpenSSH安装上了，这步可以省略了。OpenSSH是免费软件，可以到 OpenSSH 的主页上http://www.openssh.org 下载。</p>
<p>1.生成密钥对：<br />
使用ssh-keygen来生成密钥对<br />
比如要用DSA加密算法生成一个4096Bit的密钥对可以输入如下命令(具体参数请参阅man ssh-keygen)：<br />
具体命令:ssh-keygen -b 4096 -t dsa</p>
<p>使用SecureCRT生成密钥对<br />
SecureCRT最大只支持2048Bit的密钥。生成步骤是点选Tools－>Create Public Key…,选择密钥算法和密钥长度,输入完口令后再使劲晃鼠标以给它生成密钥的足够的随机量之后就等待计算机生成密钥对。切记一定要使劲晃鼠标 xD<br />
生成的Key默认放在C:Documents and SettingsAdministratorApplication DataVanDyke下，文件Identity是私钥，文件Identity.pub是公钥。<br />
<span id="more-9"></span><br />
特别要注意的是由SecureCRT生成的密钥对和用OpenSSH生成的密钥对在格式上不一样，而且二者都只能认识自己的密钥的格式，所以在用 SecureCRT同OpenSSH连接时分别都要用它们自己的密钥格式，可以用任何一个方法生成然后使用ssh-keygen -i 把SecureCRT生成的的密钥转换成OpenSSH的密钥格式,或者用ssh-keygen -e把OpenSSH的密钥格式转换成SecureCRT能够识别的IETF SECSH格式。<br />
具体命令:ssh-keygen -i -f identity.pub > openssh.pubkey</p>
<p>2.密钥分发：<br />
刚才生成了一对密钥，把私钥放在自己的机器上的C:Documents and SettingsAdministratorApplication DataVanDyke目录下。再把生成的公钥放在要连接的远程主机的~/.ssh/目录下并改名为authorized_keys,并且保证文件除了属主外没有被人修改的权限。</p>
<p>想新加用户，只需要把生成的密钥copy到authorized_keys即可</p>
<p>3.配置SSH服务端：<br />
用ee /vi /vim 编辑 /etc/ssh/sshd_config 文件，</p>
<p class=shell>
PermitRootLogin yes<br />
#允许root login<br />
ChallengeResponseAuthentication no<br />
#关掉key interactive login
</p>
<p>4.配置SSH客户端—SecureCRT：<br />
SecureCRT–>SSH2–>Authentication–>PublicKey</p>
<p>重启sshd服务</p>
<p class=shell>
/etc/rc.d/sshd reload
</p>
<p>这样就可以更安全的远程登陆了 XD<br />
感谢maxm耐心的指导</p>
<p>Update:<br />
按照上面的步骤还是不行的话，你先看看authorized_keys的属性是什么</p>
<p class=shell>
[root@betty] /home# ls -l /root/.ssh/<br />
total 4<br />
-rw-r–r– 1 weeker wheel 2228 Aug 3 16:49 authorized_keys
</p>
<p>现在的authorized_keys属于weeker用户，我们要改成root用户才能起作用。</p>
<p class=shell>[weeker@betty] ~/.ssh# chown root authorized_keys</p>
<p>sshd_config配置文件说明：</p>
<blockquote><p>
     Port　22　<br />
    “Port”设置sshd监听的端口号。　</p>
<p>    ListenAddress　192.168.1.1　<br />
    “ListenAddress”设置sshd服务器绑定的IP地址。　</p>
<p>    HostKey　/etc/ssh/ssh_host_key　</p>
<p>    “HostKey”设置包含计算机私人密匙的文件。　</p>
<p>    ServerKeyBits　1024　<br />
    “ServerKeyBits”定义服务器密匙的位数。　</p>
<p>    LoginGraceTime　600　<br />
    “LoginGraceTime”设置如果用户不能成功登录，在切断连接之前服务器需要等待的时间（以秒为单位）。　</p>
<p>    KeyRegenerationInterval　3600　<br />
    “KeyRegenerationInterval”设置在多少秒之后自动重新生成服务器的密匙（如果使用密匙）。重新生成密匙是为了防止用盗用的密匙解密被截获的信息。　</p>
<p>    PermitRootLogin　no　<br />
    “PermitRootLogin”设置root能不能用ssh登录。这个选项一定不要设成“yes”。　</p>
<p>    IgnoreRhosts　yes　<br />
    “IgnoreRhosts”设置验证的时候是否使用“rhosts”和“shosts”文件。　</p>
<p>    IgnoreUserKnownHosts　yes　<br />
    “IgnoreUserKnownHosts”设置ssh　daemon是否在进行RhostsRSAAuthentication安全验证的时候忽略用户的“$HOME/.ssh/known_hosts”　</p>
<p>    StrictModes　yes　<br />
    “StrictModes”设置ssh在接收登录请求之前是否检查用户家目录和rhosts文件的权限和所有权。这通常是必要的，因为新手经常会把自己的目录和文件设成任何人都有写权限。　</p>
<p>    X11Forwarding　no　<br />
    “X11Forwarding”设置是否允许X11转发。　</p>
<p>    PrintMotd　yes　<br />
    “PrintMotd”设置sshd是否在用户登录的时候显示“/etc/motd”中的信息。　</p>
<p>    SyslogFacility　AUTH　<br />
    “SyslogFacility”设置在记录来自sshd的消息的时候，是否给出“facility　code”。　</p>
<p>    LogLevel　INFO　<br />
    “LogLevel”设置记录sshd日志消息的层次。INFO是一个好的选择。查看sshd的man帮助页，已获取更多的信息。　</p>
<p>    RhostsAuthentication　no　<br />
    “RhostsAuthentication”设置只用rhosts或“/etc/hosts.equiv”进行安全验证是否已经足够了。　</p>
<p>    RhostsRSAAuthentication　no　<br />
    “RhostsRSA”设置是否允许用rhosts或“/etc/hosts.equiv”加上RSA进行安全验证。　</p>
<p>    RSAAuthentication　yes　<br />
    “RSAAuthentication”设置是否允许只有RSA安全验证。　</p>
<p>    PasswordAuthentication　yes　<br />
    “PasswordAuthentication”设置是否允许口令验证。　</p>
<p>    PermitEmptyPasswords　no　<br />
    “PermitEmptyPasswords”设置是否允许用口令为空的帐号登录。　</p>
<p>    AllowUsers　admin　<br />
    “AllowUsers”的后面可以跟着任意的数量的用户名的匹配串（patterns）或user@host这样的匹配串，这些字符串用空格隔开。主机名可以是DNS名或IP地址。
</p></blockquote>
<p><a href="http://blog.weeker.org/2006/05/29/215">[weeker]</a></p>
<img src="http://roamlog.info/?ak_action=api_record_view&id=9&type=feed" alt="" />]]></content:encoded>
			<wfw:commentRss>http://roamlog.info/archives/using-openssh-to-remote-connect.html/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
	</channel>
</rss>

