关于LINUX的samba命令

今天请教了前辈的LINUX命令,当我想独占服务器上的A文件上,发现已经有用户正在使用,可以打下如下命令:

smbstatus |grep DEF_M

显示如下

[albert@koidemrp ~]$ smbstatus |grep DEF_M

PID NAME
9844 /mnt/home/home/novellx/KOIDE/MRP/DEF_M.CDX Mon Feb 18 09:45:45 2008
9828 /mnt/home/home/novellx/KOIDE/MRP/DEF_M.CDX Mon Feb 18 09:41:08 2008
9799 /mnt/home/home/novellx/KOIDE/MRP/DEF_M.CDX Mon Feb 18 09:39:57 2008
9844 /mnt/home/home/novellx/KOIDE/MRP/DEF_M.DBF Mon Feb 18 09:45:45 2008
9828 /mnt/home/home/novellx/KOIDE/MRP/DEF_M.DBF Mon Feb 18 09:41:08 2008
9799 /mnt/home/home/novellx/KOIDE/MRP/DEF_M.DBF Mon Feb 18 09:39:57 2008

根据PID输入:

smbstatus |grep 9844

[albert@koidemrp ~]$ smbstatus |grep 9844
novellx 9844 mrp03 Mon Feb 18 07:48:07 2008
program 9844 mrp03 Mon Feb 18 07:48:06 2008
exe 9844 mrp03 Mon Feb 18 07:48:08 2008

就可以知道mrp03的电脑使用文件。

备注:

linux命令摘录。以备后查。

grep
1.作用
grep命令可以指定文件中搜索特定的内容,并将含有这些内容的行标准输出。 grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。

2.格式
grep [options]

3.主要参数
[options]主要参数:
-c:只输出匹配行的计数。
-I:不区分大小写(只适用于单字符)。
-h:查询多文件时不显示文件名。
-l:查询多文件时只输出包含匹配字符的文件名。
-n:显示匹配行及行号。
-s:不显示不存在或无匹配文本的错误信息。
-v:显示不包含匹配文本的所有行。

pattern正则表达式主要参数:
\ :忽略正则表达式中特殊字符的原有含义。
^:匹配正则表达式的开始行。
$:匹配正则表达式的结束行。
<:从匹配正则表达式的行开始。
>:到匹配正则表达式的行结束。
[ ]:单个字符,如[A]即A符合要求。
[ - ]:范围,如[AZ],即A、B、C一直到Z都符合要求。
。 :所有的单个字符。
* :有字符,长度可以为0。

正则表达式是Linux/Unix系统中非常重要的概念。正则表达式(也称为“regex”或“regexp”)是一个可以描述一类字符串的模式(Pattern)。如果一个字符串可以用某个正则表达式来描述,我们就说这个字符和该正则表达式匹配(Match)。这和DOS中用户可以使用通配符“*”代表任意字符类似。在Linux系统上,正则表达式通常被用来查找文本的模式,以及对文本执行“搜索-替换”操作和其它功能。

4.应用实例
查询DNS服务是日常工作之一,这意味着要维护覆盖不同网络的大量IP地址。有时IP地址会超过2000个。如果要查看nnn.nnn网络地址,但是却忘了第二部分中的其余部分,只知到有两个句点,例如nnn nn..。要抽取其中所有nnn.nnn IP地址,使用[0-9 ]{3 }.[0-0。含义是任意数字出现3次,后跟句点,接着是任意数字出现3次,后跟句点。

$grep '[0-9 ]{3 }.[0-0' ipfile

补充说明,grep家族还包括fgrep和egrep。 fgrep是fix grep,允许查找字符串而不是一个模式;egrep是扩展grep,支持基本及扩展的正则表达式,但不支持q模式范围的应用及与之相对应的一些更加规范的模式。