linux命令prmk Linux命令procsee

linux make命令什么意思无论是在Linux还是在Unix环境中,make都是一个非常重要的编译命令 。不管是自己进行项目开发还是安装应用软件,我们都经常要用到
make或make
install 。利用make工具,我们可以将大型的开发项目分解成为多个更易于管理的模块,对于一个包括几百个源文件的应用程序,使用make和
makefile工具就可以简洁明快地理顺各个源文件之间纷繁复杂的相互关系 。而且如此多的源文件,如果每次都要键入gcc命令进行编译的话,那对程序员
来说简直就是一场灾难 。而make工具则可自动完成编译工作,并且可以只对程序员在上次编译后修改过的部分进行编译 。因此,有效的利用make和
makefile工具可以大大提高项目开发的效率 。同时掌握make和makefile之后,您也不会再面对着Linux下的应用软件手足无措了 。
但令人遗憾的是,在许多讲述Linux应用的书籍上都没有详细介绍这个功能强大但又非常复杂的编译工具 。在这里我就向大家详细介绍一下make及其描述文件
makefile 。
Makefile文件
Make工具最主要也是最基本的功能就是通过makefile文件来描述源程序之间的相互关系并自动维护编译工作 。而makefile 文件需要按照某种语法进行编写,文件

需要说明如何编译各个源文件并连接生成可执行文件,并要求定义源文件之间的依赖关系 。makefile 文件是许多编译器--包括 Windows NT
下的编译器--维护编译信息的常用方法,只是在集成开发环境中,用户通过友好的界面修改 makefile 文件而已 。
在 UNIX 系统中,习惯使用 Makefile 作为 makfile 文件 。如果要使用其他文件作为 makefile , 则可利用类似下面的 make 命令选项指定 makefile 文件:
$ make -f Makefile.debug
例如,一个名为prog的程序由三个C源文件filea.c、fileb.c和filec.c以及库文件LS编译生成,这三个文件还分别包含自
己的头文件a.h
、b.h和c.h 。通常情况下,C编译器将会输出三个目标文件filea.o、fileb.o和filec.o 。假设filea.c和fileb.c都要
声明用到一个名为defs的文件 , 但filec.c不用 。即在filea.c和fileb.c里都有这样的声明:
#include "defs"
那么下面的文档就描述了这些文件之间的相互联系:
#It is a example for describing makefile
prog : filea.o fileb.o filec.o
cc filea.o fileb.o filec.o -LS -o prog
filea.o : filea.c a.h defs
cc -c filea.c
fileb.o : fileb.c b.h defs
cc -c fileb.c
filec.o : filec.c c.h
cc -c filec.c
这个描述文档就是一个简单的makefile文件 。
从上面的例子注意到,第一个字符为 # 的行为注释行 。第一个非注释行指定prog由三个目标文件filea.o、fileb.o和filec.o链接生成 。第三行描述了如何从prog所依赖的文件建立可执行文件 。接下来的4、6、8行分别指定三个目标文件,以及它们所依赖的.c和.h文件以及defs文件 。而5、7、9行则指定了如何从目标所依赖的文
件建立目标 。
当filea.c或a.h文件在编译之后又被修改,则 make 工具可自动重新编译filea.o,如果在前后两次编译之间,filea.C 和a.h 均没有被修改,而且 test.o 还存在的话,就没有必要重新编译 。这种依赖关系在多源文件的程序编译中尤其重要 。通过这种依赖关系的定义,make 工具可避免许多不必要的编译工作 。当然 , 利用 Shell
脚本也可以达到自动编译的效果,但是,Shell 脚本将全部编译任何源文件,包括哪些不必要重新编译的源文件,而 make 工具则可根据目标上一次编译的时间和目标所依赖的源文件的更新时间而自动判断应当编译哪个源文件 。
Makefile文件作为一种描述文档一般需要包含以下内容:
◆ 宏定义
◆ 源文件之间的相互依赖关系
◆ 可执行的命令
Makefile中允许使用简单的宏指代源文件及其相关编译信息,在Linux中也称宏为变量 。在引用宏时只需在变量前加$符号,但值得注意的是,如果变量名的长度超过一个字符,在引用时就必须加圆括号() 。下面都是有效的宏引用:
$(CFLAGS)
$2
$Z
$(Z)
其中最后两个引用是完全一致的 。需要注意的是一些宏的预定义变量 , 在Unix系统中 , $*、$@、$?和$四个特殊宏的值在执行命令的过程中会发生相应的变化,而在GNU make中则定义了更多的预定义变量 。关于预定义变量的详细内容,宏定义的使用可以使我们脱离那些冗长乏味的编译选项,为编写makefile文
件带来很大的方便 。
# Define a macro for the object files
OBJECTS= filea.o fileb.o filec.o
# Define a macro for the library file
LIBES= -LS
# use macros rewrite makefile
prog: $(OBJECTS)
cc $(OBJECTS) $(LIBES) -o prog
……
此时如果执行不带参数的make命令,将连接三个目标文件和库文件LS;但是如果在make命令后带有新的宏定义:
make "LIBES= -LL -LS"
则命令行后面的宏定义将覆盖makefile文件中的宏定义 。若LL也是库文件,此时make命令将连接三个目标文件以及两个库文件LS和LL 。
在Unix系统中没有对常量NULL作出明确的定义,因此我们要定义NULL字符串时要使用下述宏定义:
STRINGNAME=
Make命令
在make命令后不仅可以出现宏定义,还可以跟其他命令行参数,这些参数指定了需要编译的目标文件 。其标准形式为:
target1 [target2 …]:[:][dependent1 …][;commands][#…]
[(tab) commands][#…]
方括号中间的部分表示可选项 。Targets和dependents当中可以包含字符、数字、句点和"/"符号 。除了引用 , commands中不能含有"#",也不允许换行 。
在通常的情况下命令行参数中只含有一个":",此时command序列通常和makefile文件中某些定义文件间依赖关系的描述行有关 。如果与目标相关连的那些描述行指定了相关的command序列,那么就执行这些相关的command命令,即使在分号和(tab)后面的aommand字段甚至有可能是NULL 。如果那些与目标相关连的行没有指定command,那么将调用系统默认的目标文件生成规则 。
如果命令行参数中含有两个冒号"::",则此时的command序列也许会和makefile中所有描述文件依赖关系的行有关 。此时将执行那些与目标相关连的描述行所
指向的相关命令 。同时还将执行build-in规则 。
如果在执行command命令时返回了一个非"0"的出错信号,例如makefile文件中出现了错误的目标文件名或者出现了以连字符打头的命令字符串,make操作一般会就此终止,但如果make后带有"-i"参数,则make将忽略此类出错信号 。
Make命本身可带有四种参数:标志、宏定义、描述文件名和目标文件名 。其标准形式为:
Make [flags] [macro definitions] [targets]
Unix系统下标志位flags选项及其含义为:
-f file指定file文件为描述文件,如果file参数为"-"符,那么描述文件指向标准输入 。如果没有"-f"参数,则系统将默认当前目录下名为makefile或者名为Makefile的文件为描述文件 。在Linux中,GNU make 工具在当前工作目录中按照GNUmakefile、makefile、Makefile的顺序搜索 makefile文件 。
-i 忽略命令执行返回的出错信息 。
-s 沉默模式,在执行之前不输出相应的命令行信息 。
-r 禁止使用build-in规则 。
-n 非执行模式,输出所有执行命令 , 但并不执行 。
-t 更新目标文件 。
-q make操作将根据目标文件是否已经更新返回"0"或非"0"的状态信息 。
-p 输出所有宏定义和目标文件描述 。
-d Debug模式 , 输出有关文件和检测时间的详细信息 。
Linux下make标志位的常用选项与Unix系统中稍有不同,下面我们只列出了不同部分:
-c dir 在读取 makefile 之前改变到指定的目录dir 。
-I dir 当包含其他 makefile文件时,利用该选项指定搜索目录 。
-h help文挡 , 显示所有的make选项 。
-w 在处理 makefile 之前和之后,都显示工作目录 。
通过命令行参数中的target,可指定make要编译的目标,并且允许同时定义编译多个目标,操作时按照从左向右的顺序依次编译target选项中指定的目标文件 。如果命令行中没有指定目标,则系统默认target指向描述文件中第一个目标文件 。
通常 , makefile 中还定义有 clean 目标,可用来清除编译过程中的中间文件,例如:
clean:
rm -f *.o
运行 make clean 时,将执行 rm -f *.o 命令,最终删除所有编译过程中产生的所有中间文件 。
隐含规则
在make 工具中包含有一些内置的或隐含的规则,这些规则定义了如何从不同的依赖文件建立特定类型的目标 。Unix系统通常支持一种基于文件扩展名即文件名后缀的隐含规则 。这种后缀规则定义了如何将一个具有特定文件名后缀的文件(例如.c文件) , 转换成为具有另一种文件名后缀的文件(例如.o文件):
.c:.o
$(CC) $(CFLAGS) $(CPPFLAGS) -c -o $@ $
系统中默认的常用文件扩展名及其含义为:
.o目标文件
.cC源文件
.fFORTRAN源文件
.s汇编源文件
.yYacc-C源语法
.lLex源语法
在早期的Unix系统系统中还支持Yacc-C源语法和Lex源语法 。在编译过程中,系统会首先在makefile文件中寻找与目标文件相关的.C文件,如果还有与之相依赖的.y和.l文件 , 则首先将其转换为.c文件后再编译生成相应的.o文件;如果没有与目标相关的.c文件而只有相关的.y文件,则系统将直接编译.y文件 。
而GNU make 除了支持后缀规则外还支持另一种类型的隐含规则--模式规则 。这种规则更加通用,因为可以利用模式规则定义更加复杂的依赖性规则 。模式规则看起来非常类似于正则规则 , 但在目标名称的前面多了一个 % 号,同时可用来定义目标和依赖文件之间的关系,例如下面的模式规则定义了如何将任意一个 file.c 文件转换为 file.o 文件:
%.c:%.o
$(CC) $(CFLAGS) $(CPPFLAGS) -c -o $@ $
#EXAMPLE#
下面将给出一个较为全面的示例来对makefile文件和make命令的执行进行进一步的说明,其中make命令不仅涉及到了C源文件还包括了Yacc语法 。本例选自"Unix
Programmer's Manual 7th Edition, Volume 2A" Page 283-284
下面是描述文件的具体内容:
#Description file for the Make command
#Send to print
P=und -3 | opr -r2
#The source files that are needed by object files
FILES= Makefile version.c defs main.c donamc.c misc.c file.c \
dosys.c gram.y lex.c gcos.c
#The definitions of object files
OBJECTS= vesion.o main.o donamc.o misc.o file.o dosys.o gram.o
LIBES= -LS
LINT= lnit -p
CFLAGS= -O
make: $(OBJECTS)
cc $(CFLAGS) $(OBJECTS) $(LIBES) -o make
size make
$(OBJECTS): defs
gram.o: lex.c
cleanup:
-rm *.o gram.c
install:
@size make /usr/bin/make
cp make /usr/bin/make ; rm make
#print recently changed files
print: $(FILES)
pr $? | $P
touch print
test:
make -dp | grep -v TIME1zap
/usr/bin/make -dp | grep -v TIME2zap
diff 1zap 2zap
rm 1zap 2zap
lint: dosys.c donamc.c file.c main.c misc.c version.c gram.c
$(LINT) dosys.c donamc.c file.c main.c misc.c version.c \
gram.c
rm gram.c
arch:
ar uv /sys/source/s2/make.a $(FILES)
通常在描述文件中应象上面一样定义要求输出将要执行的命令 。在执行了make命令之后,输出结果为:
$ make
cc -c version.c
cc -c main.c
cc -c donamc.c
cc -c misc.c
cc -c file.c
cc -c dosys.c
yacc gram.y
mv y.tab.c gram.c
cc -c gram.c
cc version.o main.o donamc.o misc.o file.o dosys.o gram.o \
-LS -o make
13188 3348 3044=19580b=046174b
最后的数字信息是执行"@size make"命令的输出结果 。之所以只有输出结果而没有相应的命令行,是因为"@size make"命令以"@"起始,这个符号禁止打印输出它所在的命令行 。
描述文件中的最后几条命令行在维护编译信息方面非常有用 。其中"print"命令行的作用是打印输出在执行过上次"make print"命令后所有改动过的文件名称 。系
统使用一个名为print的0字节文件来确定执行print命令的具体时间,而宏$?则指向那些在print文件改动过之后进行修改的文件的文件名 。如果想要指定执行print命令后,将输出结果送入某个指定的文件,那么就可修改P的宏定义:
make print "P= catzap"
在Linux中大多数软件提供的是源代码,而不是现成的可执行文件,这就要求用户根据自己系统的实际情况和自身的需要来配置、编译源程序后,软件才能使用 。只有掌握了make工具,才能让我们真正享受到到Linux这个自由软件世界的带给我们无穷乐趣 。
本回答由电脑网络分类达人 李孝忠推荐
Linux下常用文本处理命令 Linux下常用文本处理命令大全
Linux下面有很多经典的非常有用的命令,其中处理文本的命令就有很多 。下面就让我们一起看看这些经典的Linux文本处理命令有哪些吧 。
一. sort
文件排序, 通常用在管道中当过滤器来使用. 这个命令可以依据指定的关键字或指定的字符位置, 对文件行进行排序. 使用-m选项, 它将会合并预排序的输入文件. 想了解这个命令的全部参数请参考这个命令的info页.
二. tsort
拓扑排序, 读取以空格分隔的有序对, 并且依靠输入模式进行排序.
三. uniq
这个过滤器将会删除一个已排序文件中的重复行. 这个命令经常出现在sort命令的管道后边.
四. expand, unexpand
expand命令将会把每个tab转化为一个空格. 这个命令经常用在管道中.
unexpand命令将会把每个空格转化为一个tab. 效果与expand命令相反.
五. cut
一个从文件中提取特定域的工具. 这个命令与awk中使用的print $N命令很相似, 但是更受限. 在脚本中使用cut命令会比使用awk命令来得容易一些. 最重要的选项就是-d(字段定界符)和-f(域分隔符)选项.
六. paste
将多个文件, 以每个文件一列的形式合并到一个文件中, 合并后文件中的每一列就是原来的一个文件. 与cut结合使用, 经常用于创建系统log文件.
七. join
这个命令与paste命令属于同类命令. 但是它能够完成某些特殊的目地. 这个强力工具能够以一种特殊的形式来合并两个文件, 这种特殊的形式本质上就是一个关联数据库的简单版本.
join命令只能够操作两个文件. 它可以将那些具有特定标记域(通常是一个数字标签)的行合并起来, 并且将结果输出到stdout. 被加入的文件应该事先根据标记域进行排序以便于能够正确的匹配.
八. head
把文件的头部内容打印到stdout上(默认为10行, 可以自己修改). 这个命令有一些比较有趣的选项.
九. tail
将一个文件结尾部分的内容输出到stdout中(默认为10行). 通常用来跟踪一个系统logfile的.修改情况, 如果使用-f选项的话, 这个命令将会继续显示添加到文件中的行.
十. wc
wc可以统计文件或I/O流中的”单词数量”:
十一. fold
将输入按照指定宽度进行折行. 这里有一个非常有用的选项-s, 这个选项可以使用空格进行断行(译者: 事实上只有外文才需要使用空格断行, 中文是不需要的)(请参考例子 12-23和例子 A-1).
十二. fmt
一个简单的文件格式器, 通常用在管道中, 将一个比较长的文本行输出进行”折行”.
十三. col
这个命令用来滤除标准输入的反向换行符号. 这个工具还可以将空白用等价的tab来替换. col工具最主要的应用还是从特定的文本处理工具中过滤输出, 比如groff和tbl. (译者: 主要用来将man页转化为文本.)
十四. column
列格式化工具. 通过在合适的位置插入tab, 这个过滤工具会将列类型的文本转化为”易于打印”的表格式进行输出.
十五. colrm
列删除过滤器. 这个工具将会从文件中删除指定的列(列中的字符串)并且写到文件中, 如果指定的列不存在, 那么就回到stdout. colrm 2 4 filename将会删除filename文件中每行的第2到第4列之间的所有字符. p=""/filename将会删除filename文件中每行的第2到第4列之间的所有字符.
Caution: 如果这个文件包含tab和不可打印字符, 那将会引起不可预期的行为. 在这种情况下, 应该通过管道的手段使用expand和unexpand来预处理colrm.
十六. nl
计算行号过滤器. nl filename将会把filename文件的所有内容都输出到stdout上, 但是会在每个非空行的前面加上连续的行号. 如果没有filename参数, 那么就操作stdin.
nl命令的输出与cat -n非常相似, 然而, 默认情况下nl不会列出空行.
十七. pr
格式化打印过滤器. 这个命令会将文件(或stdout)分页, 将它们分成合适的小块以便于硬拷贝打印或者在屏幕上浏览. 使用这个命令的不同的参数可以完成好多任务, 比如对行和列的操作, 加入行, 设置页边, 计算行号, 添加页眉, 合并文件等等. pr命令集合了许多命令的功能, 比如nl, paste, fold, column, 和expand.
pr -o 5 –width=65 fileZZZ | more 这个命令对fileZZZ进行了比较好的分页, 并且打印到屏幕上. 文件的缩进被设置为5, 总宽度设置为65.
一个非常有用的选项-d, 强制隔行打印(与sed -G效果相同).
十八. gettext
GNU gettext包是专门用来将程序的输出翻译或者本地化为不同国家语言的工具集. 在最开始的时候仅仅支持C语言, 现在已经支持了相当数量的其它程序语言和脚本语言.
想要查看gettext程序如何在shell脚本中使用. 请参考info页.
十九. msgfmt
一个产生二进制消息目录的程序. 这个命令主要用来本地化.
二十. iconv
一个可以将文件转化为不同编码格式(字符集)的工具. 这个命令主要用来本地化.
二十一. recode
可以认为这个命令是上边iconv命令的专业版本. 这个非常灵活的并可以把整个文件都转换为不同编码格式的工具并不是Linux标准安装的一部分.
二十二. TeX, gs
TeX和Postscript都是文本标记语言, 用来对打印和格式化的视频显示进行预拷贝.
TeX是Donald Knuth精心制作的排版系统. 通常情况下, 通过编写脚本的手段来把所有的选项和参数封装起来一起传到标记语言中是一件很方便的事情.
linux的常用命令有那些linux常用命令(基?。?
1. man 对你熟悉或不熟悉的命令提供帮助解释
eg:man ls 就可以查看ls相关的用法
注:按q键或者ctrl c退出linux命令prmk , 在linux下可以使用ctrl c终止当前程序运行 。
2. ls 查看目录或者文件的属*linux命令prmk,列举出任一目录下面的文件
eg: ls /usr/man
ls -l
a.d表示目录(directory) , 如果是一个”-”表示是文件,如果是l则表示是一个连接文件(link)
b.表示文件或者目录许可权限.分别用可读(r),可写(w),可运行(x) 。
【linux命令prmk Linux命令procsee】3. cp 拷贝文件
eg: cp filename1 filename2 //把filename1拷贝成filename2
cp 1.c netseek/2.c //将1.c拷到netseek目录下命名为2.c
4. rm 删除文件和目录
eg: rm 1.c //将1.c这个文件删除
5. mv 移走目录或者改文件名
eg: mv filename1 filename2 //将filename1 改名为filename2
mv qib.tgz ../qib.tgz //移到上一级目录
6. cd 改变当前目录 pwd 查看当前所在目录完整路径
eg: pwd //查看当前所在目录路径
cd netseek //进入netseek这个目录
cd //退出当前目录
7. cat , more命令
将某个文件的内容显示出来 。两个命令所不同的是:cat把文件内容一直打印出来 , 而 more则分屏显示
eg; cat1.c //就可以把代码粘帖到1.c文件里 , 按ctrl d 保存代码 。
cat 1.c 或more 1.c //都可以查看里面的内容 。
gcc -o 1 1.c //将1.c编译成.exe文件,我们可以用此命编译出代码 。
8.chmod 命令 权限修改 用法:chmod 一位8进制数 filename 。
eg: chmod u x filenmame //只想给自己运行 , 别人只能读
//u表示文件主人,g 表示文件文件所在组 。o 表示其他人 ;r 表可读,w 表可写,x 表可以运行
chmod g x filename //同组的人来执行
9. clear,date命令
clear:清屏 , 相当与DOS下的cls;date:显示当前时间 。
10. mount 加载一个硬件设备
用法:mount [参数] 要加载的设备 载入点
eg: mount /dev/cdrom
cd /mnt/cdrom //进入光盘目录
11. su 在不退出登陆的情况下,切换到另外一个人的身份
用法: su -l 用户名(如果用户名缺省,则切换到root状态)
eg:su -l netseek (切换到netseek这个用户 , 将提示输入密码)
12.whoami,whereis,which,id
//whoami:确认自己身份
//whereis:查询命令所在目录以及帮助文档所在目录
//which:查询该命令所在目录(类似whereis)
//id:打印出自己的UID以及GID 。(UID:用户身份唯一标识 。GID:用户组身份唯一标识 。每一个用户只能有一个唯一的UID和 GID)
eg: whoami //显示你自已登陆的用户名
whereis bin 显示bin所在的目录,将显示为:/usr/local/bin
which bin
13. grep,find
grep:文本内容搜索;find:文件或者目录名以及权限属主等匹配搜索
eg: grep success */*查找当前目录下面所有文件里面含有success字符的文件
14. kill 可以杀死某个正在进行或者已经是dest状态的进程
eg; ps ax
15. passwd 可以设置口令
16. history 用户用过的命令
eg: history //可以显示用户过去使用的命令
17. !! 执行最近一次的命令
18. mkdir命令
eg: mkdir netseek //创建netseek这个目录
19. tar 解压命令
eg: tar -zxvf nmap-3.45.tgz //将这个解压到nmap-3.45这个目录里
20. finger 可以让使用者查询一些其他使用者的资料
eg: finger //查看所用用户的使用资料
finger root //查看root的资料
linux查看内存使用情况linux查看内存使用情况的方法是linux命令prmk,1,proc 。meminfo,查看 RAM 使用情况最简单的方法是通过 ,procmeminfo 。这个动态更新的虚拟文件实际上是许多其linux命令prmk他内存相关工具 free,ps , top的组合显示 。
2,atop 。atop 命令是一个终端环境的监控命令 。它显示的是各种系统资源,CPU, memory, network , IOkernel的综合,并且在高负载的情况下进行linux命令prmk了彩色标注 。
3 , free 。free 命令是一个快速查看内存使用情况的方法,它是对,proc,meminfo 收集到的信息的一个概述 。
4,GNOME System Monitor 。GNOME System Monitor 是一个显示最近一段时间内的 CPU内存交换区及网络的使用情况的视图工具 。它还提供了一种查看 CPU 及内存使用情况的方法 。
5,htop 。htop 命令显示了每个进程的内存实时使用率 。它提供了所有进程的常驻内存大?。绦蜃苣诖娲笮 。蚕砜獯笮〉鹊谋ǜ妫?列表可以水平及垂直滚动 。6,KDE System Monitor功能同 4 中介绍的 GENOME 版本 。
Linux系统最基本,经常用的命令有哪些呢?Linux必学linux命令prmk的60个命令(3)-系统管理
由 zhanjun 在 周四, 2006-04-13 12:41 提交
Linux必学的60个命令:系统管理相关命令
Linux必学的系统管理命令
作者:曹元其 发文时间:2004.10.18
对于Linux系统来说linux命令prmk,无论是中央处理器、内存、磁盘驱动器、键盘、鼠标linux命令prmk,还是用户等都是文件,Linux系统管理的命令是它正常运行的核心 。熟悉了Linux常用的文件处理命令以后,这一讲介绍对系统和用户进行管理的命令 。
cat cd
chmod chown
cp cut
名称:cat
使用权限:所有使用者
使用方式:cat [-AbeEnstTuv] [--help] [--version] fileName
说明:把档案串连接后传到基本输出(萤幕或加fileName 到另一个档案)
参数:
-n 或 --number 由 1 开始对所有输出的行数编号
-b 或 --number-nonblank 和 -n 相似,只不过对于空白行不编号
-s 或 --squeeze-blank 当遇到有连续两行以上的空白行 , 就代换为一行的空白行
-v 或 --show-nonprinting
范例:
cat -n textfile1textfile2 把 textfile1 的档案内容加上行号后输入 textfile2 这个档案里
cat -b textfile1 textfile2textfile3 把 textfile1 和 textfile2 的档案内容加上行号(空白行不加)之后将内容附加到 textfile3
名称 : cd
使用权限 : 所有使用者
使用方式 : cd [dirName]
说明 : 变换工作目录至 dirName 。其中 dirName 表示法可为绝对路径或相对路径 。若目录名称省略,则变换至使用者的 home directory (也就是刚 login 时所在的目录) 。
另外,"~" 也表示为 home directory 的意思 , "." 则是表示目前所在的目录,".." 则表示目前目录位置的上一层目录 。
范例 : 跳到 /usr/bin/ :
cd /usr/bin
跳到自己的 home directory :
cd ~
跳到目前目录的上上两层 :
cd ../..
指令名称 : chmod
使用权限 : 所有使用者
使用方式 : chmod [-cfvR] [--help] [--version] mode file...
说明 : Linux/Unix 的档案存取权限分为三级 : 档案拥有者、群组、其linux命令prmk他 。利用 chmod 可以藉以控制档案如何被他人所存取 。
把计 :
mode : 权限设定字串,格式如下 : [ugoa...][[ -=][rwxX]...][,...],其中u 表示该档案的拥有者,g 表示与该档案的拥有者属于同一个群体(group)者,o 表示其他以外的人,a 表示这三者皆是 。
表示增加权限、- 表示取消权限、= 表示唯一设定权限 。
r 表示可读取,w 表示可写入,x 表示可执行 , X 表示只有当该档案是个子目录或者该档案已经被设定过为可执行 。
-c : 若该档案权限确实已经更改,才显示其更改动作
-f : 若该档案权限无法被更改也不要显示错误讯息
-v : 显示权限变更的详细资料
-R : 对目前目录下的所有档案与子目录进行相同的权限变更(即以递回的方式逐个变更)
--help : 显示辅助说明
--version : 显示版本
范例 :将档案 file1.txt 设为所有人皆可读取 :
chmod ugo r file1.txt
将档案 file1.txt 设为所有人皆可读取 :
chmod a r file1.txt
将档案 file1.txt 与 file2.txt 设为该档案拥有者,与其所属同一个群体者可写入,但其他以外的人则不可写入 :
chmod ug w,o-w file1.txt file2.txt
将 ex1.py 设定为只有该档案拥有者可以执行 :
chmod u x ex1.py
将目前目录下的所有档案与子目录皆设为任何人可读取 :
chmod -R a r *
此外chmod也可以用数字来表示权限如 chmod 777 file
语法为:chmod abc file
其中a,b,c各为一个数字,分别表示User、Group、及Other的权限 。
r=4,w=2,x=1
若要rwx属性则4 2 1=7;
若要rw-属性则4 2=6;
若要r-x属性则4 1=7 。
范例:
chmod a=rwx file

chmod 777 file
效果相同
chmod ug=rwx,o=x file

chmod 771 file
效果相同
若用chmod 4755 filename可使此程式具有root的权限
指令名称 : chown
使用权限 : root
使用方式 : chmod [-cfhvR] [--help] [--version] user[:group] file...
说明 : Linux/Unix 是多人多工作业系统,所有的档案皆有拥有者 。利用 chown 可以将档案的拥有者加以改变 。一般来说,这个指令只有是由系统管理者(root)所使用 , 一般使用者没有权限可以改变别人的档案拥有者 , 也没有权限可以自己的档案拥有者改设为别人 。只有系统管理者(root)才有这样的权限 。
把计 :
user : 新的档案拥有者的使用者 IDgroup : 新的档案拥有者的使用者群体(group)-c : 若该档案拥有者确实已经更改 , 才显示其更改动作-f : 若该档案拥有者无法被更改也不要显示错误讯息-h : 只对于连结(link)进行变更,而非该 link 真正指向的档案-v : 显示拥有者变更的详细资料-R : 对目前目录下的所有档案与子目录进行相同的拥有者变更(即以递回的方式逐个变更)--help : 显示辅助说明--version : 显示版本
范例 :
将档案 file1.txt 的拥有者设为 users 群体的使用者 jessie :
chown jessie:users file1.txt
将目前目录下的所有档案与子目录的拥有者皆设为 users 群体的使用者 lamport :
chmod -R lamport:users *
名称:cp
使用权限:所有使用者
使用方式:
cp [options] source dest
cp [options] source... directory
说明:将一个档案拷贝至另一档案,或将数个档案拷贝至另一目录 。
把计?
-a 尽可能将档案状态、权限等资料都照原状予以复制 。
-r 若 source 中含有目录名,则将目录下之档案亦皆依序拷贝至目的地 。
-f 若目的地已经有相同档名的档案存在,则在复制前先予以删除再行复制 。
范例:
将档案 aaa 复制(已存在) , 并命名为 bbb :
cp aaa bbb
将所有的C语言程式拷贝至 Finished 子目录中 :
cp *.c Finished
名称:cut
使用权限:所有使用者
用法:cut -cnum1-num2 filename
说明:显示每行从开头算起 num1 到 num2 的文字 。
范例:
shell cat example
test2
this is test1
shell cut -c0-6 example ## print 开头算起前 6 个字元
test2
this i
名称 : find
用法 : find
使用说明 :
将档案系统内符合 expression 的档案列出来 。你可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来 。
find 根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部份为 path,之后的是 expression 。如果 path 是空字串则使用目前路径,如果 expression 是空字串则使用 -print 为预设 expression?
expression 中可使用的选项有二三十个之多,在此只介绍最常用的部份 。
-mount, -xdev : 只检查和指定目录在同一个档案系统下的档案 , 避免列出其它档案系统中的档案
-amin n : 在过去 n 分钟内被读取过
-anewer file : 比档案 file 更晚被读取过的档案
-atime n : 在过去 n 天过读取过的档案
-cmin n : 在过去 n 分钟内被修改过
-cnewer file :比档案 file 更新的档案
-ctime n : 在过去 n 天过修改过的档案
-empty : 空的档案-gid n or -group name : gid 是 n 或是 group 名称是 name
-ipath p, -path p : 路径名称符合 p 的档案 , ipath 会忽略大小写
-name name, -iname name : 档案名称符合 name 的档案 。iname 会忽略大小写
-size n : 档案大小 是 n 单位,b 代表 512 位元组的区块,c 表示字元数,k 表示 kilo bytes,w 是二个位元组 。-type c : 档案类型是 c 的档案 。
d: 目录
c: 字型装置档案
b: 区块装置档案
p: 具名贮列
f: 一般档案
l: 符号连结
s: socket
-pid n : process id 是 n 的档案
你可以使用 ( ) 将运算式分隔 , 并使用下列运算 。
exp1 -and exp2
! expr
-not expr
exp1 -or exp2
exp1, exp2
范例:
将目前目录及其子目录下所有延伸档名是 c 的档案列出来 。
# find . -name "*.c"
将目前目录其其下子目录中所有一般档案列出
# find . -ftype f
将目前目录及其子目录下所有最近 20 分钟内更新过的档案列出
# find . -ctime -20
名称:less
使用权限:所有使用者
使用方式:
less [Option] filename
说明:
less 的作用与 more 十分相似 , 都可以用来浏览文字档案的内容,不同的是 less 允许使用者往回卷动
以浏览已经看过的部份 , 同时因为 less 并未在一开始就读入整个档案,因此在遇上大型档案的开启时,会比一般的文书编辑器(如 vi)来的快速 。
范例:
指令名称 : ln
使用权限 : 所有使用者
使用方式 : ln [options] source dist,其中 option 的格式为 :
[-bdfinsvF] [-S backup-suffix] [-V {numbered,existing,simple}]
[--help] [--version] [--]
说明 : Linux/Unix 档案系统中,有所谓的连结(link),linux命令prmk我们可以将其视为档案的别名,而连结又可分为两种 : 硬连结(hard link)与软连结(symbolic link),硬连结的意思是一个档案可以有多个名称,而软连结的方式则是产生一个特殊的档案,该档案的内容是指向另一个档案的位置 。硬连结是存在同一个档案系统中,而软连结却可以跨越不同的档案系统 。
ln source dist 是产生一个连结(dist)到 source,至于使用硬连结或软链结则由参数决定 。
不论是硬连结或软链结都不会将原本的档案复制一份,只会占用非常少量的磁碟空间 。
-f : 链结时先将与 dist 同档名的档案删除-d : 允许系统管理者硬链结自己的目录-i : 在删除与 dist 同档名的档案时先进行询问-n : 在进行软连结时,将 dist 视为一般的档案-s : 进行软链结(symbolic link)-v : 在连结之前显示其档名-b : 将在链结时会被覆写或删除的档案进行备份-S SUFFIX : 将备份的档案都加上 SUFFIX 的字尾-V METHOD : 指定备份的方式--help : 显示辅助说明--version : 显示版本
范例 :
将档案 yy 产生一个 symbolic link : zz
ln -s yy zz
将档案 yy 产生一个 hard link : zz
ln yy xx
名称:locate
使用权限:所有使用者
使用方式: locate [-q] [-d ] [--database=]
locate [-r ] [--regexp=]
locate [-qv] [-o ] [--output=]
locate [-e ] [-f ] [-l ] [-c]
[-U ] [-u]
locate [-Vh] [--version] [--help]
说明:
locate 让使用者可以很快速的搜寻档案系统内是否有指定的档案 。其方法是先建立一个包括系统内所有档案名称及路径的资料库,之后当寻找时就只需查询这个资料库 , 而不必实际深入档案系统之中了 。
在一般的 distribution 之中,资料库的建立都被放在 contab 中自动执行 。一般使用者在使用时只要用
# locate your_file_name
的型式就可以了 。参数:
-u
-U
建立资料库,-u 会由根目录开始,-U 则可以指定开始的位置 。
-e

排除在寻找的范围之外 。
-l
如果 是 1.则启动安全模式 。在安全模式下 , 使用者不会看到权限无法看到的档案 。这会始速度减慢,因为 locate 必须至实际的档案系统中取得档案的权限资料 。
-f
将特定的档案系统排除在外,例如我们没有到理要把 proc 档案系统中的档案放在资料库中 。
-q
安静模式,不会显示任何错误讯息 。
-n
至多显示 个输出 。
-r
使用正规运算式 做寻找的条件 。
-o
指定资料库存的名称 。
-d
指定资料库的路径
-h
显示辅助讯息
-v
显示更多的讯息
-V
显示程式的版本讯息 范例:
locate chdrv : 寻找所有叫 chdrv 的档案
locate -n 100 a.out : 寻找所有叫 a.out 的档案,但最多只显示 100 个
locate -u : 建立资料库
名称 : ls
使用权限 : 所有使用者
使用方式 : ls [-alrtAFR] [name...]
说明 : 显示指定工作目录下之内容(列出目前工作目录所含之档案及子目录) 。
-a 显示所有档案及目录 (ls内定将档案名或目录名称开头为"."的视为隐藏档,不会列出)
-l 除档案名称外 , 亦将档案型态、权限、拥有者、档案大小等资讯详细列出
-r 将档案以相反次序显示(原定依英文字母次序)
-t 将档案依建立时间之先后次序列出
-A 同 -a ,但不列出 "." (目前目录) 及 ".." (父目录)
-F 在列出的档案名称后加一符号;例如可执行档则加 "*", 目录则加 "/"
-R 若目录下有档案,则以下之档案亦皆依序列出
范例:
列出目前工作目录下所有名称是 s 开头的档案,愈新的排愈后面 :
ls -ltr s*
将 /bin 目录以下所有目录及档案详细资料列出 :
ls -lR /bin
列出目前工作目录下所有档案及目录;目录于名称后加 "/", 可执行档于名称后加 "*" :
ls -AF
名称:more
使用权限:所有使用者
使用方式:more [-dlfpcsu] [-num] [ /pattern] [ linenum] [fileNames..]
说明:类似 cat ,不过会以一页一页的显示方便使用者逐页阅读 , 而最基本的指令就是按空白键(space)就往下一页显示,按 b 键就会往回(back)一页显示,而且还有搜寻字串的功能(与 vi 相似),使用中的说明文件,请按 h。
参数:-num 一次显示的行数
-d 提示使用者,在画面下方显示 [Press space to continue, q to quit.] , 如果使用者按错键,则会显示 [Press h for instructions.] 而不是 哔 声
-l 取消遇见特殊字元 ^L(送纸字元)时会暂停的功能
-f 计算行数时,以实际上的行数,而非自动换行过后的行数(有些单行字数太长的会被扩展为两行或两行以上)
-p 不以卷动的方式显示每一页 , 而是先清除萤幕后再显示内容
-c 跟 -p 相似,不同的是先显示内容再清除其他旧资料
-s 当遇到有连续两行以上的空白行 , 就代换为一行的空白行
-u 不显示下引号 (根据环境变数 TERM 指定的 terminal 而有所不同)
/ 在每个档案显示前搜寻该字串(pattern),然后从该字串之后开始显示
num 从第 num 行开始显示
fileNames 欲显示内容的档案,可为复数个数
范例:
more -s testfile 逐页显示 testfile 之档案内容,如有连续两行以上空白行则以一行空白行显示 。
more20 testfile 从第 20 行开始显示 testfile 之档案内容 。
名称:mv
使用权限:所有使用者
使用方式:
mv [options] source dest
mv [options] source... directory
说明:将一个档案移至另一档案,或将数个档案移至另一目录 。
参数:-i 若目的地已有同名档案,则先询问是否覆盖旧档 。
范例:
将档案 aaa 更名为 bbb :
mv aaa bbb
将所有的C语言程式移至 Finished 子目录中 :
mv -i *.c
名称:rm
使用权限:所有使用者
使用方式:rm [options] name...
说明:删除档案及目录 。
把计?
-i 删除前逐一询问确认 。
-f 即使原档案属性设为唯读,亦直接删除,无需逐一确认 。
-r 将目录及以下之档案亦逐一删除 。
范例:
删除所有C语言程式档;删除前逐一询问确认 :
rm -i *.c
将 Finished 子目录及子目录中所有档案删除 :
rm -r Finished
名称:rmdir
使用权限:于目前目录有适当权限的所有使用者
使用方式: rmdir [-p] dirName
说明: 删除空的目录 。
参数: -p 是当子目录被删除后使它也成为空目录的话 , 则顺便一并删除 。
范例:
将工作目录下,名为 AAA 的子目录删除 :
rmdir AAA
在工作目录下的 BBB 目录中 , 删除名为 Test 的子目录 。若 Test 删除后,BBB 目录成为空目录,则 BBB 亦予删除 。
rmdir -p BBB/Test
名称:split
使用权限:所有使用者
使用方式:split [OPTION] [INPUT [PREFIX]]
说明:
将一个档案分割成数个 。而从 INPUT 分割输出成固定大小的档案,其档名依序为 PREFIXaa, PREFIXab...;PREFIX 预设值为 `x 。若没有 INPUT 档或为 `-,则从标准输入读进资料 。
匡兜?
-b, --bytes=SIZE
SIZE 值为每一输出档案的大小 , 单位为 byte 。
-C, --line-bytes=SIZE
每一输出档中,单行的最大 byte 数 。
-l, --lines=NUMBER
NUMBER 值为每一输出档的列数大小 。
-NUMBER
与 -l NUMBER 相同 。
--verbose
于每个输出档被开启前,列印出侦错资讯到标准错误输出 。
--help
显示辅助资讯然后离开 。
--version
列出版本资讯然后离开 。
SIZE 可加入单位: b 代表 512, k 代表 1K,m 代表 1 Meg 。
范例:
PostgresSQL 大型资料库备份与回存:
因 Postgres 允许表格大过你系统档案的最大容量,所以要将表格 dump 到单一的档案可能会有问题 , 使用 split进行档案分割 。
% pg_dump dbname | split -b 1m - filename.dump.
重新载入
% createdb dbname
% cat filename.dump.* | pgsql dbname
名称:touch
使用权限:所有使用者
使用方式:
touch [-acfm]
[-r reference-file] [--file=reference-file]
[-t MMDDhhmm[[CC]YY][.ss]]
[-d time] [--date=time] [--time={atime,access,use,mtime,modify}]
[--no-create] [--help] [--version]
file1 [file2 ...]
说明:
touch 指令改变档案的时间记录 。ls -l 可以显示档案的时间记录 。
参数:
a 改变档案的读取时间记录 。
m 改变档案的修改时间记录 。
c 假如目的档案不存在,不会建立新的档案 。与 --no-create 的效果一样 。
f 不使用,是为了与其他 unix 系统的相容性而保留 。
r 使用参考档的时间记录 , 与 --file 的效果一样 。
d 设定时间与日期,可以使用各种不同的格式 。
t 设定档案的时间记录 , 格式与 date 指令相同 。
--no-create 不会建立新档案 。
--help 列出指令格式 。
--version 列出版本讯息 。
范例:
最简单的使用方式 , 将档案的时候记录改为现在的时间 。若档案不存在,系统会建立一个新的档案 。
touch file
touch file1 file2
将 file 的时间记录改为 5 月 6 日 18 点 3 分 , 公元两千年 。时间的格式可以参考 date 指令,至少需输入 MMDDHHmm ,就是月日时与分 。
touch -c -t 05061803 file
touch -c -t 050618032000 file
将 file 的时间记录改变成与 referencefile 一样 。
touch -r referencefile file
将 file 的时间记录改成 5 月 6 日 18 点 3 分,公元两千年 。时间可以使用 am, pm 或是 24 小时的格式,日期可以使用其他格式如 6 May 2000。
touch -d "6:03pm" file
touch -d "05/06/2000" file
touch -d "6:03pm 05/06/2000" file
df
1.作用
df命令用来检查文件系统的磁盘空间占用情况,使用权限是所有用户 。
2.格式
df [options]
3.主要参数
-s:对每个Names参数只给出占用的数据块总数 。
-a:递归地显示指定目录中各文件及子目录中各文件占用的数据块数 。若既不指定-s,也不指定-a,则只显示Names中的每一个目录及其中的各子目录所占的磁盘块数 。
-k:以1024字节为单位列出磁盘空间使用情况 。
-x:跳过在不同文件系统上的目录不予统计 。
-l:计算所有的文件大?。杂擦唇游募蚣扑愣啻?。
-i:显示inode信息而非块使用量 。
-h:以容易理解的格式印出文件系统大小,例如136KB、254MB、21GB 。
-P:使用POSIX输出格式 。
-T:显示文件系统类型 。
4.说明
df命令被广泛地用来生成文件系统的使用统计数据,它能显示系统中所有的文件系统的信息,包括总容量、可用的空闲空间、目前的安装点等 。
超级权限用户使用df命令时会发现这样的情况:某个分区的容量超过了100% 。这是因为Linux系统为超级用户保留了10%的空间,由其单独支配 。也就是说,对于超级用户而言,他所见到的硬盘容量将是110% 。这样的安排对于系统管理而言是有好处的,当硬盘被使用的容量接近100%时系统管理员还可以正常工作 。
5.应用实例
Linux支持的文件系统非常多 , 包括JFS、ReiserFS、ext、ext2、ext3、ISO9660、XFS、Minx、vfat、MSDOS等 。使用df -T命令查看磁盘空间时还可以得到文件系统的信息:
#df -T
文件系统 类型 容量 已用 可用 已用% 挂载点
/dev/hda7 reiserfs 5.2G 1.6G 3.7G 30% /
/dev/hda1 vfat 2.4G 1.6G 827M 66% /windows/C
/dev/hda5 vfat 3.0G 1.7G 1.3G 57% /windows/D
/dev/hda9 vfat 3.0G 2.4G 566M 82% /windows/E
/dev/hda10 NTFS 3.2G 573M 2.6G 18% /windows/F
/dev/hda11 vfat 1.6G 1.5G 23M 99% /windows/G
从上面除了可以看到磁盘空间的容量、使用情况外,分区的文件系统类型、挂载点等信息也一览无遗 。
top
1.作用
top命令用来显示执行中的程序进程,使用权限是所有用户 。
2.格式
top [-] [d delay] [q] [c] [S] [s] [i] [n]
3.主要参数
d:指定更新的间隔,以秒计算 。
q:没有任何延迟的更新 。如果使用者有超级用户,则top命令将会以最高的优先序执行 。
c:显示进程完整的路径与名称 。
S:累积模式,会将己完成或消失的子行程的CPU时间累积起来 。
s:安全模式 。
i:不显示任何闲置(Idle)或无用(Zombie)的行程 。
n:显示更新的次数,完成后将会退出top 。
4.说明
top命令是Linux系统管理的一个主要命令,通过它可以获得许多信息 。这里我们结合图1来说明它给出的信息 。
图1 top命令的显示
在图1中,第一行表示的项目依次为当前时间、系统启动时间、当前系统登录用户数目、平均负载 。第二行显示的是所有启动的进程、目前运行的、挂起 (Sleeping)的和无用(Zombie)的进程 。第三行显示的是目前CPU的使用情况 , 包括系统占用的比例、用户使用比例、闲置(Idle)比例 。第四行显示物理内存的使用情况,包括总的可以使用的内存、已用内存、空闲内存、缓冲区占用的内存 。第五行显示交换分区使用情况 , 包括总的交换分区、使用的、空闲的和用于高速缓存的大小 。第六行显示的项目最多,下面列出了详细解释 。
PID(Process ID):进程标示号 。
USER:进程所有者的用户名 。
PR:进程的优先级别 。
NI:进程的优先级别数值 。
VIRT:进程占用的虚拟内存值 。
RES:进程占用的物理内存值 。
SHR:进程使用的共享内存值 。
S:进程的状态,其中S表示休眠 , R表示正在运行,Z表示僵死状态,N表示该进程优先值是负数 。
%CPU:该进程占用的CPU使用率 。
%MEM:该进程占用的物理内存和总内存的百分比 。
TIME+:该进程启动后占用的总的CPU时间 。
Command:进程启动的启动命令名称,如果这一行显示不下,进程会有一个完整的命令行 。
top命令使用过程中,还可以使用一些交互的命令来完成其它参数的功能 。这些命令是通过快捷键启动的 。
空格:立刻刷新 。
P:根据CPU使用大小进行排序 。
T:根据时间、累计时间排序 。
q:退出top命令 。
m:切换显示内存信息 。
t:切换显示进程和CPU状态信息 。
c:切换显示命令名称和完整命令行 。
M:根据使用内存大小进行排序 。
W:将当前设置写入~/.toprc文件中 。这是写top配置文件的推荐方法 。
可以看到,top命令是一个功能十分强大的监控系统的工具,对于系统管理员而言尤其重要 。但是,它的缺点是会消耗很多系统资源 。
5.应用实例
使用top命令可以监视指定用户 , 缺省情况是监视所有用户的进程 。如果想查看指定用户的情况,在终端中按“U”键,然后输入用户名,系统就会切换为指定用户的进程运行界面 , 见图2所示 。
图2 使用top命令监视指定用户
free
1.作用
free命令用来显示内存的使用情况,使用权限是所有用户 。
2.格式
free [-b|-k|-m] [-o] [-s delay] [-t] [-V]
3.主要参数
-b -k -m:分别以字节(KB、MB)为单位显示内存使用情况 。
-s delay:显示每隔多少秒数来显示一次内存使用情况 。
-t:显示内存总和列 。
-o:不显示缓冲区调节列 。
4.应用实例
free命令是用来查看内存使用情况的主要命令 。和top命令相比,它的优点是使用简单 , 并且只占用很少的系统资源 。通过-S参数可以使用free命令不间断地监视有多少内存在使用,这样可以把它当作一个方便实时监控器 。
#free -b -s5
使用这个命令后终端会连续不断地报告内存使用情况(以字节为单位),每5秒更新一次 。
quota
1.作用
quota命令用来显示磁盘使用情况和限制情况 , 使用权限超级用户 。
2.格式
quota [-g][-u][-v][-p] 用户名 组名
3.参数
-g:显示用户所在组的磁盘使用限制 。
-u:显示用户的磁盘使用限制 。
-v:显示没有分配空间的文件系统的分配情况 。
-p:显示简化信息 。
4.应用实例
在企业应用中磁盘配额非常重要,普通用户要学会看懂自己的磁盘使用情况 。要查询自己的磁盘配额可以使用下面命令(下例中用户账号是caojh):
#quota caojh
Disk quotas for user caojh(uid 502):
Filesystem blocks quota limit grace files quota limit grace
/dev/hda3 58 200000 400000 41 500 1000
以上显示ID号为502的caojh账号,文件个数设置为500~1000个 , 硬盘空间限制设置为200M
linux命令prmk的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于Linux命令procsee、linux命令prmk的信息别忘了在本站进行查找喔 。

    推荐阅读