赞
踩
第一部分
一、查看目录(ls)
A.ls
查看当前目录
B.ls path(要查看的目录的路径)
例如:ls /mnt/hgfs
显示/mnt/hgfs目录下的内容
C.ls -l
显示当前目录内容的属性信息
d rwx r-x r-x 2 cyg cyg 4096 2012-07-06 10:06 cyg
d:目录的标识
rwx :文件所有者权限(r:读 w:写 x:执行)
r-x :同组用户操作权限(r:读 -:没有写权限 x:执行)
r-x :其他用户操作权限(r:读 -:没有写权限 x:执行)
2:目录的链接数
cyg :表示文件的创建者
cyg :文件所在组
4096:文件的大小(字节)
2012-07-06 10:06:最后一次的修改时间
cyg :文件名
D.查看一个指定文件的属性信息
ls -l 文件名
此时显示文件的属性信息
ls -l 目录名
此时显示目录内部文件的属性信息
E.ls *
递归一级显示当前子目录的内容
F.ls -a
显示当前目录下所有文件,包括以"."开头的隐藏文件
二、查看文本文件的内容
1.cat
cat hello.c
显示hello.c文件的内容
cat -n hello.c
显示hello.c文件的内容并且显示行号
cat /etc/passwd
显示/etc/passwd文件的内容
注意:/etc/passwd代表/etc目录下的passwd文件
2.more/less分屏显示
more /etc/passwd
可以通过"回车键"进行向后翻屏
less /etc/passwd
可以通过"b"键向前翻,"d"键向后翻,"q"键退出
3.head
head -10 /etc/passwd
从文件头显示10行
4.tail
tail -10 /etc/passwd
从文件尾显示10行
三、删除文件
rm hello.c
删除hello.c文件
rm -r 目录名
删除这个目录
rm -f 文件名
强制删除这个文件
最常用的组合:rm -rf 文件/目录
rm -rf /home/cyg/hello.c
强制性删除/home/cyg/hello.c文件
四、拷贝文件/目录
拷贝文件:
cp /home/cyg/hello.c /mnt/hgfs/share
将/home/cyg/hello.c拷贝到/mnt/hgfs/share目录下
拷贝目录:
cp /home/cyg/dir /mnt/hgfs/share -a
将/home/cyg/dir目录拷贝到/mnt/hgfs/share目录下
注意:拷贝目录的时候需要跟上"-a"参数
备份当前目录的文件/目录
文件:
cp file file-bak
目录:
cp dir dir-bak -a
五、移动文件
mv /home/cyg/hello.c /mnt/hgfs/share
将/home/cyg/hello.c文件移动到/mnt/hgfs/share目录下
mv /home/cyg/dir /mnt/hgfs/share
将/home/cyg/dir移动到/mnt/hgfs/share目录下
对当前目录的一个文件/目录重命名
mv hello.c test.c
将当前目录下hello.c改名为test.c
练习:
1.将/etc/passwd文件拷贝到用户主目录
2.分别显示/etc/passwd文件的前10行和后10行
3.在用户主目录下新建目录PASSWD
4.将用户主目录下passwd文件移动到PASSWD目录下
5.将PASSWD进行备份成PASSWD-BAK
6.查看passwd文件的大小,文件所有者,当前用户对其有什么操作权限
六、切换目录
1.进入当前子目录
cd 目录名
2.切换到其他目录
cd path
cd /mnt/hgfs/share
切换到/mnt/hgfs/share目录下
3.切换到上级目录
cd ..
4.切换到上一次操作目录
cd -
5.回到用户主目录
cd 回车
七、查找字符串
1.在一个指定文件搜索字符串
grep "main" hello.c
搜索以"main"开头的行
grep -n "^main" hello.c
搜索以"main"结尾的行
grep -n "main$" hello.c
搜索只有"main"的行
grep -n "^main$" hello.c
注意:-n 显示字符串所在的行号
2.在当前目录下所有文件中搜索字符串,不包括子目录
grep "main" *
3.在当前所有文件中搜索字符串,包括子目录
grep "main" * -nR
注意:-nR递归搜索子目录
八、查找文件
find -name filename
在当前目录下查找hello.c文件,包括子目录
find -name "hello.c"
九、按次序显示一个文件内容
sort file
默认是从小到大,按ASCII码排序
sort -r file
从大到小,按ASCII码排序
sort -n file
从小到大排序,按10进制排序
注意:sort命令在进行排序的时候,并不会改变file类容
sort -n -r file -o file
以10进制,按从大到小的顺序对file文件进行排序,并将排序的结果放到file文件中
九、去掉文件中相邻重复的行
uniq test.c
十、比较两个文件是否相同
diff test.c test1.c
比较这个两个文件是否相同
十一、file查看文件的类型
file a.out
得到的信息:
a.out: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV),
dynamically linked (uses shared libs), for GNU/Linux 2.6.15,not stripped
十二、压缩文件
1.gzip压缩
gzip hello.c
压缩hello.c为hello.c.gz
2.bzip2压缩
bzip2 hello.c
压缩hello.c为hello.c.bz2
注意:gzip和bzip2压缩只能是一个文件而不能是一个目录
十三、解压缩
1.解压gzip压缩的文件
gunzip hello.c.gz
解压为hello.c
2.解压bzip2压缩的文件
bunzip2 hello.c.bz2
十四、打包(tar)
-c 创建
-x 释放
-z 以gzip压缩形式操作
-j 以bzip2压缩形式操作
-f 指定文件名(创建的时候)
-v 显示过程信息
A.把一个目录进行打包
tar -cvf test.tar test
将test目录打包成test.tar
B.把一个*.tar包进行释放
tar -xvf test.tar
C.把一个目录进行打包并且压缩
gzip压缩格式
tar -czvf test.tar.gz test
将test目录打包并且以gzip压缩
bzip2压缩格式
tar -cjvf test.tar.bz2 test
将test目录打包并且以bzip2压缩
D.解压缩
test.tar.gz
tar -xzvf test.tar.gz
test.tar.bz2
tar -xjvf test.tar.bz2
十五、显示操作进程信息
ps -ef
显示操作系统中所有的进程
十六、杀死一个进程
kill pid
killall 进程名
//强制杀死
kill -9 pid
十七、查看文件系统磁盘使用情况
df -h
十八、查看一个目录占磁盘空间的大小
du -sh
十九、改变目录和文件的权限
r:读
w:写
x:执行
u:所有者
g:所在组
o:其他用户
chmod u+r test.c
给test.c的所有者添加读权限
chmod u-x test.c
对test.c的所有者除去执行权限
八进制
- rw- r-- -wx .... test.c
- 110 100 011
=>0643
chmod 777 test.c
二十、改变文件所有者
chown root test.c
将test.c的文件所有者改为root
二十一、改变文件的所在组
chgrp root test.c
将test.c的文件所在组改为root
二十二、linux中文输入安装
ibus-setup
二十三、检查是否安装TFTP
dpkg -l | grep tftp
GCC编译过程:
1 预处理: (gcc -E)将头文件、宏定义、条件编译等进行处理,生成*.i文件;
2 编译器:(gcc –S)将c 翻译成汇编,生成*.S文件;
3 汇编处理:(gcc –c)将汇编生成*.o文件;
4 链接:将所有的*.o文件拼接成执行文件;
Gdb调试流程:
二十四、生成调试文件
ctags -R
二十五、查找当前目录里的某个文件
find -name 文件名
二十六、安装 tree 命令
apt-get install tree
第二部分
linux find命令参数及用法详解--linux查找文件命令
将档案系统内符合 expression 的档案列出来。你可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。
find 根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部份为 path,之后的是 expression。如果 path 是空字串则使用目前路径,如果 expression 是空字串则使用 -print 为预设 expression。
由于find具有强大的功能,所以它的选项也很多,其中大部分选项都值得我们花时间来了解一下。即使系统中含有网络文件系统( NFS),find命令在该文件系统中同样有效,只你具有相应的权限。
在运行一个非常消耗资源的find命令时,很多人都倾向于把它放在后台执行,因为遍历一个大的文件系统可能会花费很长的时间(这里是指30G字节以上的文件系统)。
一、find 命令格式
1、find命令的一般形式为;
find pathname -options [-print -exec -ok ...]
2、find命令的参数;
pathname: find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。
-print: find命令将匹配的文件输出到标准输出。
-exec: find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为\'command\' { } ;,注意{ }和;之间的空格。
-ok: 和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。
3、find命令选项
-name
按照文件名查找文件。
-perm
按照文件权限来查找文件。
-prune
使用这一选项可以使find命令不在当前指定的目录中查找,如果同时使用-depth选项,那么-prune将被find命令忽略。
-user
按照文件属主来查找文件。
-group
按照文件所属的组来查找文件。
-mtime -n +n
按照文件的更改时间来查找文件, - n表示文件更改时间距现在n天以内,+ n表示文件更改时间距现在n天以前。find命令还有-atime和-ctime 选项,但它们都和-m time选项。
-nogroup
查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。
-nouser
查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。
-newer file1 ! file2
查找更改时间比文件file1新但比文件file2旧的文件。
-type
查找某一类型的文件,诸如:
b - 块设备文件。
d - 目录。
c - 字符设备文件。
p - 管道文件。
l - 符号链接文件。
f - 普通文件。
-size n:[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计。
-depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。
-fstype:查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息。
-mount:在查找文件时不跨越文件系统mount点。
-follow:如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。
-cpio:对匹配的文件使用cpio命令,将这些文件备份到磁带设备中。
另外,下面三个的区别:
-amin n
查找系统中最后N分钟访问的文件
-atime n
查找系统中最后n*24小时访问的文件
-cmin n
查找系统中最后N分钟被改变文件状态的文件
-ctime n
查找系统中最后n*24小时被改变文件状态的文件
-mmin n
查找系统中最后N分钟被改变文件数据的文件
-mtime n
查找系统中最后n*24小时被改变文件数据的文件
4、使用exec或ok来执行shell命令
使用find时,只要把想要的操作写在一个文件里,就可以用exec来配合find查找,很方便的
在有些操作系统中只允许-exec选项执行诸如l s或ls -l这样的命令。大多数用户使用这一选项是为了查找旧文件并删除它们。建议在真正执行rm命令删除文件之前,最好先用ls命令看一下,确认它们是所要删除的文件。
exec选项后面跟随着所要执行的命令或脚本,然后是一对儿{ },一个空格和一个,最后是一个分号。为了使用exec选项,必须要同时使用print选项。如果验证一下find命令,会发现该命令只输出从当前路径起的相对路径及文件名。
例如:为了用ls -l命令列出所匹配到的文件,可以把ls -l命令放在find命令的-exec选项中
# find . -type f -exec ls -l { } ;
-rw-r--r-- 1 root root 34928 2003-02-25 ./conf/httpd.conf
-rw-r--r-- 1 root root 12959 2003-02-25 ./conf/magic
-rw-r--r-- 1 root root 180 2003-02-25 ./conf.d/README
上面的例子中,find命令匹配到了当前目录下的所有普通文件,并在-exec选项中使用ls -l命令将它们列出。
在/logs目录中查找更改时间在5日以前的文件并删除它们:
$ find logs -type f -mtime +5 -exec rm { } ;
记住:在shell中用任何方式删除文件之前,应当先查看相应的文件,一定要小心!当使用诸如mv或rm命令时,可以使用-exec选项的安全模式。它将在对每个匹配到的文件进行操作之前提示你。
在下面的例子中, find命令在当前目录中查找所有文件名以.LOG结尾、更改时间在5日以上的文件,并删除它们,只不过在删除之前先给出提示。
$ find . -name *.conf -mtime +5 -ok rm { } ;
< rm ... ./conf/httpd.conf > ? n
按y键删除文件,按n键不删除。
任何形式的命令都可以在-exec选项中使用。
在下面的例子中我们使用grep命令。find命令首先匹配所有文件名为“ passwd*”的文件,例如passwd、passwd.old、passwd.bak,然后执行grep命令看看在这些文件中是否存在一个sam用户。
# find /etc -name passwd* -exec grep sam { } ;
sam:x:501:501::/usr/sam:/bin/bash
二、find命令的例子;
1、查找当前用户主目录下的所有文件:
下面两种方法都可以使用
$ find $HOME -print
$ find ~ -print
2、让当前目录中文件属主具有读、写权限,并且文件所属组的用户和其他用户具有读权限的文件;
$ find . -type f -perm 644 -exec ls -l { } ;
3、为了查找系统中所有文件长度为0的普通文件,并列出它们的完整路径;
$ find / -type f -size 0 -exec ls -l { } ;
4、查找/var/logs目录中更改时间在7日以前的普通文件,并在删除之前询问它们;
$ find /var/logs -type f -mtime +7 -ok rm { } ;
5、为了查找系统中所有属于root组的文件;
$find . -group root -exec ls -l { } ;
-rw-r--r-- 1 root root 595 10月 31 01:09 ./fie1
6、find命令将删除当目录中访问时间在7日以来、含有数字后缀的admin.log文件。
该命令只检查三位数字,所以相应文件的后缀不要超过999。先建几个admin.log*的文件 ,才能使用下面这个命令
$ find . -name admin.log[0-9][0-9][0-9] -atime -7 -ok
rm { } ;
< rm ... ./admin.log001 > ? n
< rm ... ./admin.log002 > ? n
< rm ... ./admin.log042 > ? n
< rm ... ./admin.log942 > ? n
7、为了查找当前文件系统中的所有目录并排序;
$ find . -type d | sort
8、为了查找系统中所有的rmt磁带设备;
$ find /dev/rmt -print
三、xargs
xargs - build and execute command lines from standard input
在使用find命令的-exec选项处理匹配到的文件时, find命令将所有匹配到的文件一起传递给exec执行。但有些系统对能够传递给exec的命令长度有限制,这样在find命令运行几分钟之后,就会出现溢出错误。错误信息通常是“参数列太长”或“参数列溢出”。这就是xargs命令的用处所在,特别是与find命令一起使用。
find命令把匹配到的文件传递给xargs命令,而xargs命令每次只获取一部分文件而不是全部,不像-exec选项那样。这样它可以先处理最先获取的一部分文件,然后是下一批,并如此继续下去。
在有些系统中,使用-exec选项会为处理每一个匹配到的文件而发起一个相应的进程,并非将匹配到的文件全部作为参数一次执行;这样在有些情况下就会出现进程过多,系统性能下降的问题,因而效率不高;
而使用xargs命令则只有一个进程。另外,在使用xargs命令时,究竟是一次获取所有的参数,还是分批取得参数,以及每一次获取参数的数目都会根据该命令的选项及系统内核中相应的可调参数来确定。
来看看xargs命令是如何同find命令一起使用的,并给出一些例子。
下面的例子查找系统中的每一个普通文件,然后使用xargs命令来测试它们分别属于哪类文件
#find . -type f -print | xargs file
./.kde/Autostart/Autorun.desktop: UTF-8 Unicode English text
./.kde/Autostart/.directory: ISO-8859 text
......
在整个系统中查找内存信息转储文件(core dump) ,然后把结果保存到/tmp/core.log 文件中:
$ find / -name core -print | xargs echo >/tmp/core.log
上面这个执行太慢,我改成在当前目录下查找
#find . -name file* -print | xargs echo > /temp/core.log
# cat /temp/core.log
./file6
在当前目录下查找所有用户具有读、写和执行权限的文件,并收回相应的写权限:
# ls -l
drwxrwxrwx 2 sam adm 4096 10月 30 20:14 file6
-rwxrwxrwx 2 sam adm 0 10月 31 01:01 http3.conf
-rwxrwxrwx 2 sam adm 0 10月 31 01:01 httpd.conf
# find . -perm -7 -print | xargs chmod o-w
# ls -l
drwxrwxr-x 2 sam adm 4096 10月 30 20:14 file6
-rwxrwxr-x 2 sam adm 0 10月 31 01:01 http3.conf
-rwxrwxr-x 2 sam adm 0 10月 31 01:01 httpd.conf
用grep命令在所有的普通文件中搜索hostname这个词:
# find . -type f -print | xargs grep hostname
./httpd1.conf:# different IP addresses or hostnames and have them handled by the
./httpd1.conf:# VirtualHost: If you want to maintain multiple domains/hostnames
on your
用grep命令在当前目录下的所有普通文件中搜索hostnames这个词:
# find . -name * -type f -print | xargs grep hostnames
./httpd1.conf:# different IP addresses or hostnames and have them handled by the
./httpd1.conf:# VirtualHost: If you want to maintain multiple domains/hostnames
on your
注意,在上面的例子中, 用来取消find命令中的*在shell中的特殊含义。
find命令配合使用exec和xargs可以使用户对所匹配到的文件执行几乎所有的命令。
四、find 命令的参数
下面是find一些常用参数的例子,有用到的时候查查就行了,像上面前几个贴子,都用到了其中的的一些参数,也可以用man或查看论坛里其它贴子有find的命令手册
1、使用name选项
文件名选项是find命令最常用的选项,要么单独使用该选项,要么和其他选项一起使用。
可以使用某种文件名模式来匹配文件,记住要用引号将文件名模式引起来。
不管当前路径是什么,如果想要在自己的根目录$HOME中查找文件名符合*.txt的文件,使用~作为 \'pathname\'参数,波浪号~代表了你的$HOME目录。
$ find ~ -name *.txt -print
想要在当前目录及子目录中查找所有的‘ *.txt’文件,可以用:
$ find . -name *.txt -print
想要的当前目录及子目录中查找文件名以一个大写字母开头的文件,可以用:
$ find . -name [A-Z]* -printhttp://www.linuxso.com/command/find.html
第三部分
linux中grep命令的用法
Category: linux, Author: admin, Popularity: 78%
1.作用
linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。
2.格式
grep [options]
3.主要参数
[options]主要参数:
-c:只输出匹配行的计数。
-I:不区分大小写(只适用于单字符)。
-h:查询多文件时不显示文件名。
-l:查询多文件时只输出包含匹配字符的文件名。
-n:显示匹配行及行号。
-s:不显示不存在或无匹配文本的错误信息。
-v:显示不包含匹配文本的所有行。
pattern正则表达式主要参数:
\:忽略正则表达式中特殊字符的原有含义。
^:匹配正则表达式的开始行。
$: 匹配正则表达式的结束行。
\<:从匹配正则表达式的行开始。
\>:到匹配正则表达式的行结束。
[ ]:单个字符,如[A]即A符合要求 。
[ - ]:范围,如[A-Z],即A、B、C一直到Z都符合要求 。
。:所有的单个字符。
* :有字符,长度可以为0。
4.grep命令使用简单实例
$ grep ‘test’ d*
显示所有以d开头的文件中包含test的行。
$ grep ‘test’ aa bb cc
显示在aa,bb,cc文件中匹配test的行。
$ grep ‘[a-z]\{5\}’ aa
显示所有包含每个字符串至少有5个连续小写字符的字符串的行。
$ grep ‘w
如果west被匹配,则es就被存储到内存中,并标记为1,然后搜索任意个字符(.*),这些字符后面紧跟着另外一个es(\1),找到就显示该行。如果用egrep或grep -E,就不用”\”号进行转义,直接写成’w(es)t.*\1′就可以了。
5.grep命令使用复杂实例
假设您正在’/usr/src/linux/Doc’目录下搜索带字符串’magic’的文件:
$ grep magic /usr/src/linux/Doc/*
sysrq.txt:* How do I enable the magic SysRQ key?
sysrq.txt:* How do I use the magic SysRQ key?
其中文件’sysrp.txt’包含该字符串,讨论的是 SysRQ 的功能。
默认情况下,’grep’只搜索当前目录。如果此目录下有许多子目录,’grep’会以如下形式列出:
grep: sound: Is a directory
这可能会使’grep’的输出难于阅读。这里有两种解决的办法:
明确要求搜索子目录:grep -r
或忽略子目录:grep -d skip
如果有很多输出时,您可以通过管道将其转到’less’上阅读:
$ grep magic /usr/src/linux/Documentation/* | less
这样,您就可以更方便地阅读。
有一点要注意,您必需提供一个文件过滤方式(搜索全部文件的话用 *)。如果您忘了,’grep’会一直等着,直到该程序被中断。如果您遇到了这样的情况,按 <CTRL c> ,然后再试。
下面还有一些有意思的命令行参数:
grep -i pattern files :不区分大小写地搜索。默认情况区分大小写,
grep -l pattern files :只列出匹配的文件名,
grep -L pattern files :列出不匹配的文件名,
grep -w pattern files :只匹配整个单词,而不是字符串的一部分(如匹配’magic’,而不是’magical’),
grep -C number pattern files :匹配的上下文分别显示[number]行,
grep pattern1 | pattern2 files :显示匹配 pattern1 或 pattern2 的行,
grep pattern1 files | grep pattern2 :显示既匹配 pattern1 又匹配 pattern2 的行。
这里还有些用于搜索的特殊符号:
\< 和 \> 分别标注单词的开始与结尾。
例如:
grep man * 会匹配 ‘Batman’、’manic’、’man’等,
grep ‘\<man’ * 匹配’manic’和’man’,但不是’Batman’,
grep ‘\<man\>’ 只匹配’man’,而不是’Batman’或’manic’等其他的字符串。
‘^’:指匹配的字符串在行首,
‘$’:指匹配的字符串在行尾,
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。