1. 不建议在根目录下随意mkdir,容易破坏相对完整的根目录结构。
2. /bin , /sbin 两个目录
/bin 一般存放的是系统指令
/sbin 一般存放系统管理方面的指令
/usr/bin 和 /usr/sbin 存放的则是用户安装的第三方指令
3. /etc 存放系统功能配置信息,service 配置信息。
4. /misc 挂载目录
/proc 系统内存里的数据文件,包括进程编号:PID
5. cat /proc/cpuinfo 查看完整的cpu信息
6. /srv 存放下载文件
7. 安装系统时精确分区的作用是节约磁盘的查找数据时间,所以最好给/var,/home等单独划分区。
8. /tmp 该文件夹权限是777,经常用作临时文件夹或做测试用。
9. /var 系统产生的业务数据,如www,mysql,log,lock等服务
10. /dev 设备信息
11. /home 当前用户家目录,注意不能进其他用户的家目录,root除外
12. /mnt 挂载点的集合
13. 系统观察 uname -r -a 所有的系统信息, cat /etc/issue
14. 强制位:
其表述是在权限的“x” 位置上, 如:rws或rwS,有x(执行)权限的是s,没有的是S。
suid,文件拥有者来说,只针对文件,以文件拥有者的身份执行,例如:切换 /bin/ls 的s属性可以访问一些未授权的目录,如chmod u+s /bin/ls
sgid,用户组来说,一般针对目录,方便继承所属组目录,如 chmod g+s /tmp/xxx
15. 冒险位:
其表述是在权限的“x” 位置上, 如:rwt或rwT,有x(执行)权限的是t,没有的是T。
加在目录上并且是在o组上才有意义。例如 /tmp 的权限设置是 drwxrwxrwt ,表明可以读写,但目录内的内容,只有文件拥有者才能删除,其他人无法删除,root除外。
16. 设置强制位 chmod 4755 xxx 那么xxx的权限是 -rwsr-xr-x
设置强制位 chmod 2755 xxx 那么xxx的权限是 -rwxr-sr-x
设置冒险位 chmod 1755 xxx 那么xxx的权限是 -rwxr-xr-t
17. umask
设定文件的默认权限 ,在/etc/profile 下可永久设定,shell中可临时指定。
设置前提:
文件权限基数 666
目录权限基数 777
umask 对于一般用户建立的默认权限是 002 ; 对于系统用户默认权限是 022
换算过程:
假如要设置 umask 是 023,过程如下
目录基数 rwx rwx rwx (777)
umask — -w- -wx (023)
得到 rwx r-x r– (754),那么就成功设定默认创建目录权限是754.
快捷方法是上面直接相减(777-023=754),此方法只针对目录可以直接减。
而针对文件,要注意,奇数需要+1,例如:
要设置的umask 是023, 注意这里,3是奇数,所以 (666-023 = 643) 这里还得+1, 643+1 = 644,得到设定成功的默认文件权限是644.
而对于umask尾数不是奇数的,还是可以直接减的 ,如umask是002的,则(666-002 = 664)成功设定默认文件权限案是664.
18. chattr 设定文件状态属性
例如 chattr + A install.log 这里可以使得该文件的访问时间被锁死
chattr +S 强制修改时执行同步
+s 完全删除,无法找回
+a 只能写入数据,不能删除数据
+c 压缩文件,用的时候自动解压
+i 不能删除,改名,新增,链接
19. lsattr 查看文件状态属性
20. 用户管理。
用户配置文件 /etc/passwd ,可在此文件修改uid。启动一个服务就有一个用户去管理它,所以linux有很多用户。
uid : 0~499 是系统用户 , 500~60000 是普通用户
表示是: u : x : 10 : 14 : usr : /var : /sbin/nologin
没有密码 : uid : gid : 用户描述 : 家目录 :登陆用的shell
密码配置文件 /etc/shadow
表示是: root : ——- : 13072 : 0 : 99999 : 7 : 2 : 13108 : 空白
root : 密码 :密码修改日期 :密码不可更改天数(间隔几天后才能修改) : 密码有效期 :到期前提前几天提示修改密码 : 默认-1,到期后依旧能用,这里是到期后2天后失效 :帐号取消日期 :空白保留
21. 一个group里面包括,组管理员设定 : 主属组 (primary group 组管理员) 和 附属组
/etc/group 组信息
/etc/gshadow
etc/gshadow是/etc/group的加密资讯文件,比如用户组(Group)管理密码就是存放在这个文件。/etc/gshadow 和/etc/group是互补的两个文件;对于大型服务器,针对很多用户和组,定制一些关系结构比较复杂的权限模型,设置用户组密码是极有必要的。比如我们不想让一些非用户组成员永久拥有用户组的权限和特性,这时我们可以通过密码验证的方式来让某些用户临时拥有一些用户组特性,这时就要用到用户组密码;
/etc/gshadow 格式如下,每个用户组独占一行;
groupname:password:admin,admin,…:member,member,…
第一字段:用户组
第二字段:用户组密码,这个段可以是空的或!,如果是空的或有!,表示没有密码;
第三字段:用户组管理者,这个字段也可为空,如果有多个用户组管理者,用,号分割;
第四字段:组成员,如果有多个成员,用,号分割;
22. system-config-users 图形界面来管理用户,只能管理普通用户。
23. 添加用户
useradd -c lamp -s /sbin/nologin -d /var/nginx (-d 是迁移家目录)
-D 查看默认信息当前用户
-r
-n
id nginx (查看nginx用户的id,gid信息)
24. 修改用户
usermod -d /home/nginx -m 用户
-m 这里必须和-d一起使用,目的是为用户 的家目录 设置新地址
-G
-g
25. 删除用户
userdel -r 删除用户的信息,加上 -r 是要连家目录一并删除。
26. passwd 用户 添加用户密码
echo 密码
| passwd –stdin rhce 直接修改用户rhce 密码,不用弹出提示
27. who 查看当前登陆用户
w 查看登陆用户并显示负载值
finger 用户
groups 用户 查看用户所在组
28. 网卡配置目录
/etc/sysconfig/newwork-scripts/ eth0
eth1
- lo
系统配置终端字符界面 setup 命令
重启网络服务:
1. service network restart (重启网络服务)
2. service NetworkManager restart (重启图形化网卡配置界面)
29. /etc/default/useradd 修改默认参数信息
30 . echo $PATH 打印系统环境变量
31. 文件的查找
which 在$PATH里面查找
whereis
locate
find
Linux中find常见用法示例
#-print 将查找到的文件输出到标准输出
#-exec command {} ; —–将查到的文件执行command操作,{} 和 ;之间有空格
#-ok 和-exec相同,只不过在操作前要询用户
-perm #按执行权限来查找
-user username #按文件属主来查找
-group groupname #按组来查找
-mtime -n +n #按文件更改时间来查找文件,-n指n天以内,+n指n天以前
-atime -n +n #按文件访问时间来查GIN: 0px
>-perm #按执行权限来查找<br>-user username #按文件属主来查找<br>-group groupname #按组来查找<br>-mtime -n +n #按文件更改时间来查找文件,-n指n天以内,+n指n天以前<br>-atime -n +n #按文件访问时间来查找文件,-n指n天以内,+n指n天以前</div>
</div>
<div>-ctime -n +n #按文件创建时间来查找文件,-n指n天以内,+n指n天以前 <br>-nogroup #查无有效属组的文件,即文件的属组在/etc/groups中不存在<br>-nouser #查无有效属主的文件,即文件的属主在/etc/passwd中不存<br>-newer f1 !f2 找文件,-n指n天以内,+n指n天以前 <br>-ctime -n +n #按文件创建时间来查找文件,-n指n天以内,+n指n天以前 <br>-nogroup #查无有效属组的文件,即文件的属组在/etc/groups中不存在<br>-nouser #查无有效属主的文件,即文件的属主在/etc/passwd中不存<br>-newer f1 !f2 #查更改时间比f1新但比f2旧的文件<br>-type b/d/c/p/l/f #查是块设备、目录、字符设备、管道、符号链接、普通文件<br>-size n[c] #查长度为n块[或n字节]的文件<br>-depth #使查找在进入子目录前先行查找完本目录<br>-fstype #查更改时间比f1新但比f2旧的文件<br>-type b/d/c/p/l/f #查是块设备、目录、字符设备、管道、符号链接、普通文件<br>-size n[c] #查长度为n块[或n字节]的文件<br>-depth #使查找在进入子目录前先行查找完本目录<br>-fstype #查位于某一类型文件系统中的文件,这些文件系统类型通常可 在/etc/fstab中找到<br>-mount #查文件时不跨越文件系统mount点<br>-follow #如果遇到符号链接文件,就跟踪链接所指的文件<br>-cpio %; #查位于某一类型文件系统中的文件,这些文件系统类型通常可 在/etc/fstab中找到<br>-mount #查文件时不跨越文件系统mount点<br>-follow #如果遇到符号链接文件,就跟踪链接所指的文件<br>-cpio #对匹配的文件使用cpio命令,将他们备份到磁带设备中<br>-prune #忽略某个目录
<div>====================================================<br>$find ~ -name
.txt-print #在$HOME中查.txt文件并显示<br>$find . -name
.txt-print<br>$find . -name
[A-Z]-pri26nbsp; #对匹配的文件使用cpio命令,将他们备份到磁带设备中<br>-prune #忽略某个目录</div>
<div>=====================================================<br>$find ~ -name
.txt-print #在$HOME中查.txt文件并显示<br>$find . -name
.txt-print<br>$find . -name
[A-Z]-print #查以大写字母开头的文件<br>$find /etc -name
host-print #查以host开头的文件<br>$find . -name
[a-z][a-z][0–9][0–9].txt-print #查以两个小写字母和两个数字开头的txt文件<br>$find . -perm 755 -print<br>$find . -perm -007 -exec ls -l {} ; #查所有用户都可读写执行的文件同-perm 777<br>$find . -type d -print<br>$find . ! -type d -print <br>$find . -type l -print</div>
<div>$find . -size +1000000c -print #查长度大于1Mb的文件<br>$find . -size 100c -print # 查长度为100c的文件<br>$find . -size +10 -print #查长度超过期作废10块的文件(1块=512字节)</div>
<div>$cd /<br>$find etc home apps -depth -print | cpio -ivcdC65536 -o /dev/rmt0<br>$find /etc -name
passwd-exec grep
cnscn{} ; #看是否存在cnscn用户<br>$find . -name
yao| xargs file<br>$find . -name
yao| xargs echo `
> /tmp/core.log$find . -name
yao*
| xargs chmod o-wfind -name april fprint file 在当前目录下查找以april开始的文件,并把结果输出到file中
find -name ap -o -name may 查找以ap或may开头的文件
find /mnt -name tom.txt -ftype vfat 在/mnt下查找名称为tom.txt且文件系统类型为vfat的文件
find /mnt -name t.txt ! -ftype vfat 在/mnt下查找名称为tom.txt且文件系统类型不为vfat的文件
find /tmp -name wa -type l 在/tmp下查找名为wa开头且类型为符号链接的文件
find /home -mtime -2 在/home下查最近两天内改动过的文件
find /home -atime -1 查1天之内被存取过的文件
find /home -mmin +60 在/home下查60分钟前改动过的文件
find /home -amin +30 查最近30分钟前被存取过的文件
find /home -newer tmp.txt 在/home下查更新时间比tmp.txt近的文件或目录
find /home -anewer tmp.txt 在/home下查存取时间比tmp.txt近的文件或目录
find /home -used -2 列出文件或目录被改动过之后,在2日内被存取过的文件或目录
find /home -user cnscn 列出/home目录内属于用户cnscn的文件或目录
find /home -uid +501 列出/home目录内用户的识别码大于501的文件或目录
find /home -group cnscn 列出/home内组为cnscn的文件或目录
find /home -gid 501 列出/home内组id为501的文件或目录
find /home -nouser 列出/home内不属于本地用户的文件或目录
find /home -nogroup 列出/home内不属于本地组的文件或目录
find /home -name tmp.txt -maxdepth 4 列出/home内的tmp.txt 查时深度最多为3层
find /home -name tmp.txt -mindepth 3 从第2层开始查
find /home -empty 查找大小为0的文件或空目录
find /home -size +512k 查大于512k的文件
find /home -size -512k 查小于512k的文件
find /home -links +2 查硬连接数大于2的文件或目录
find /home -perm 0700 查权限为700的文件或目录
find /tmp -name tmp.txt -exec cat {} ;
find /tmp -name tmp.txt -ok rm {} ;
find / -atime -2 # 查找在系统中最后48小时访问的文件
find / -empty # 查找在系统中为空的文件或者文件夹
find / -group cat # 查找在系统中属于 groupcat的文件
find / -mmin -5 # 查找在系统中最后5分钟里修改过的文件
find / -mtime -1 #查找在系统中最后24小时里修改过的文件
find / -nouser #查找在系统中属于作废用户的文件
find / -user fred #查找在系统中属于FRED这个用户的文件
-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
查当前目录下的所有普通文件,并在- e x e c选项中使用ls -l命令将它们列出
在/ l o g s目录中查找更改时间在5日以前的文件并删除它们:
$ find logs -type f -mtime +5 -exec -ok rm {} ;
查询当天修改过的文件
[root@book class]# find ./ -mtime -1 -type f -exec ls -l {} ;
查询文件并询问是否要显示
[root@book class]# find ./ -mtime -1 -type f -ok ls -l {} ;
< ls … ./classDB.inc.php > ? y
-rw-r–r– 1 cnscn cnscn 13709 1月 12 12:22 ./classDB.inc.php
[root@book class]# find ./ -mtime -1 -type f -ok ls -l {} ;
< ls … ./classDB.inc.php > ? n
[root@book class]#
查询并交给awk去处理
[root@book class]# who | awk ’{print $1
$2}’cnscn pts/0
awk—grep—sed
//dev///g
文件系统
sda2
sda1
[root@book class]# df -k | awk ‘{print $1}’ | grep -v ’none’
文件系统
/dev/sda2
/dev/sda1
,最后打印出所有包含
SYSCALL_VECTOR的文件名</span></strong></strong>
<div>A) find /tmp -name
.h` | xargs -n50 grep SYSCALL_VECTORB) grep SYSCALL_VECTOR /tmp/.h | cut -d’:’ -f1| uniq > filename
C) find /tmp -name
*.h
-exec grep SYSCALL_VECTOR
{} ; -printfind / -name filename -ok rm -rf {} ;
find . -size +3000k -exec ls -ld {} ;
find .c -exec cp ‘{}’ /tmp ‘;’
find dir -name filename -print | cpio -pdv newdir
# A=
find ./ -name
php
| ls -l –full-time $A 2>/dev/null | grep 2004-11-30 16:36:37
find 实例
,最后打印出所有包含
SYSCALL_VECTOR的文件名,有以下几种方法实现<br>find /usr/linux -name
.h| xargs -n50 grep SYSCALL_VECTOR<br>grep SYSCALL_VECTOR /usr/linux/*.h | cut -d’:’ -f1 | uniq > filename<br>find /usr/linux -name
.h-exec grep
SYSCALL_VECTOR{} ; -print</span></div>
<div><span><br></span></div>
<div><span>我用find / -name filename| rm -rf,不成功,请问为什么不成功?<br>find / -name filename -exec rm -rf {} ;<br>find . -name filename |rm -rf试一下{} 表示你找出来的结果。<br>; 则相当于“宪法”,没什么说头,就是这么规定的,在 -exec 后面需要一个表示该命令终结的的符号。可以在 man find 中找到答案。<br>要让rm识别find的结果,如下:<br>find / -name filename |xargs rm -rf<br>之所以find . -name filename |rm -rf不通过,是因为rm命令不接受从标准输入传过来的指令<br></span></div>
<div><span><br></span></div>
<div><span><strong>查找含特定字符串的文件</strong><br>例如查找当前目录下含有
the string you want find…字符串的文件:<br>$find . -type f -exec grep “the string you want find…” {} ; -print</span></div>
<div><span> 从根目录开始查tmpfile,一旦查到马上删除<br>find / -name
tmpfile-exec rm {} ;</span></div>
<div><span><br></span></div>
<div><span><strong>find 的perm问题</strong><br>请问一下以下命令什么意思?关键是那个数字前的-,其他都还知道<br>find -name
.-perm -007<br>我知道<br>find -name
.-perm 755<br>这个是用来查找权限位为755的隐藏文件<br>噢,对了还有,我上边的命令都省略了find的pathname参数 find默认是查找当前工作目录的吗?<br>如果我用 -ok 替代 -exec, 那么还需要加上 {} ; 吗?<br>这个已经清楚,仍然需要,因为 -ok 只是 -exec 的提示模式,它只是多了一个确认操作的步骤,刚才没有读懂那几句E文的意思 呵呵 不好意思<br>-007是指查找所有用户都可读、写、执行的文件,要小心呀~~~<br>解释解释?<br>find -name
.-perm -007 和 find -name
.` -perm 777 有区别吗?-007是怎么来得呢?
不过有一个问题
我用 find . -perm -100 会列出当前目录 . , 这是为什么呢?
-007是指查找所有用户都可读、写、执行的文件,要小心呀~~~
-007是查找含其它用户(不同组,非属主)可读,写,执行的文件.并不一定要同组可读写,-是指最少权限为007.
下面引用由一颗小白菜在 2002/10/01 10:16am 发表的内容:
OK了, 呵呵
不过有一个问题
我用 find . -perm -100 会列出当前目录 . , 这是为什么呢?
这种方法不会准确的找出目录的. -100是指权限至少是属主可运行.
在unix系统下,你可以拥有对目录文件的执行权你才可以进入一个目录.这便是目录文件被列出的原因.
find . -perm -001 -print找到往往是目录文件.
我的意思当然不是使用这种方法来找目录,只不过不明白其中的 -100 意义了
那以此类推,是不是 -010是指权限至少是owner同组可执行的吗?也就是说其实这里的010和-是分开的,-表示一个至少的意思,而且010才是真正用来描述权限位的?
这样子就明白了 谢谢你噢
find .c -exec cp ‘{}’ /tmp ‘;’
如果有特殊文件,可以用cpio,也可以用这样的语法:
find dir -name filename -print | cpio -pdv newdir
比如要查找磁盘中大于3M的文件:
find . -size +3000k -exec ls -ld {} ;
可以使用这一行命令来实现:
A=
find ~ -print
| ls -l –full-time $A 2>/dev/null | grep Jun 27
| grep 1998创建一个脚本judgetime,内容如下:
ls -l $|awk ‘{split($8,hour,
:
);if((hour[1]>23 || hour[1] < 1)&&hour[1]<24)print}’到要查找的目录下,运行
find ./ -name `
-exec judgetime {} ;<br>注意时间格式为24小时制。<br>thank you ,如果我要精确到分钟呢<br>touch -t 04241112 starttemp #精确到12分钟<br>touch -t 04241220 endtemp #截止到12点20<br>find [dir] -newer starttemp -a ! -newer endtemp -exec ls -l {} ;<br>newer?<br>那昨天12:10文件如何呢?<br>每天执行的时候,用当天的日期和时间戳替换一下不就行了吗?<br>我不知道他是不是把所有的11:00~12:00的都找出来,是不是只执行一次还是每天都执行?<br>这种情况俺猜想是自己的东西放在哪忘了,只记得当时是深夜了。<br>有道理!<br>不愧是斑竹!<br>不光知道怎么解决问题,还知道在什么情况下出现这类问题,佩服佩服!<br>问题又出现了。创建这个文件的时候。本来应该是时间的一栏现在写上了2002,而不是12:00.<br>等到12:00过了吧!</span></div>
<div><span><br></span></div>
<div><span><strong>删除指定日期的文件</strong><br>find ./ -name 文件名 -exec rm -f {} ;<br>例:删除当前30天内没用过的文件,用如下命令:<br>find / -atime +30 -exec rm -f {} ;<br>我自己试着写了一小段SHELL,也用ll ,grep, rm 几个命令,用起来还差强人意。<br>对过滤出来的文件名列表中用了一个FOR语句,再执行rm 。现在我想把这段SHELL 扩展一下让它每天定时运行将 n 天前的文件删掉,有没有人能给我一些提示,谢谢!<br>还有个问题,对于前面那位朋友提到的
find / -atime +30 -exec rm -f {} ;方法,我很早就试过几次,不过好像都不太对,参数 -atime n 是查找n天前被访问过的文件,我不明白的是这里的时间参照点是什么,以及这个n天是怎么计算的。<br>问 题二、对于
ll |cut -f 1这个命令我是不是用错了,我只想取出 ll 中列出的文件名,但用cut -f 命令做不到 ,我只好换用 ll |cut -c 59- 这种方式得到我要的文件名,but it’s a pool idear !我也试过用awk ,好像也不对,看看大家可不可以给我一些小小的提醒,TKS SO MUCH<br>问题三、如何改变 I结点 的日期格式 我现在的系统显示的格式是:<br>-rw-r—– 1 msahz01 users 2253 2002年2月 2日 poheader.i<br>我想把这换成<br>-rw-rw-rw- 1 house users 2193 Apr 19 2001 hkdisp.p<br>如何才能做到这点?<br>awk 应该可以<br>ll | awk ‘{print $9}’<br> 删除多少天之前的文件<br>find /yourpath -mtime +31 -exec rm {} ;<br>find /yourpath -mtime +366 -exec rm {} ;</span></div>
<div><span>find中, -ctime, -mtime及其-atime有何区别</span></div>
<div><span>请问 -ctime 和 -mtime 有什么关系 ?<br>如果父目录的 ctime 改变, 那它下面的文件的 ctime 就会自动都改了吗 ?<br>-ctime 和 -mtime ,-atime 这些信息是存在哪儿呢 ?</span></div>
<div><span>我用 -mtime -1 找到了新建或改的文件.<br>但怎样才能找到一天内 mv 来的文件呢( 它们的时间是原有的时间,早于一天 ) ?</span></div>
<div><span>用-newer选项啊。<br>你可以先touch一个你想要的时间的文件如下:<br>$ touch -t 08190800 test<br>$ ls -l test<br>-rw-r–r– 1 dba other 0 Aug 19 08:00 test<br>然后<br>$ find . -newer test -print<br>.<br>./.sh_history<br>$ ls -l .sh_history<br>-rw——- 1 dba other 154 Aug 20 17:39 .sh_history</span></div>
<div><span>用touch可以写出你想要的任何时间的文件,然后用-newer ,! -newer选项即可成功。</span></div>
<div><span>1.ctime含inode信息修改的时间.mtime只指文件内容建立或修改的时间.<br>2 不会.<br>3.这些信息应该是存在文件系统的超级块里.</span></div>
<div><span>我查了书 -ctime 是指 inode 的改变(或称文件的状态改变).<br>请问 inode 存了哪些信息 ?<br>做了些小测试,-mtime 改, -ctime 一定也改.<br>改文件名, -ctime 也会改.<br>谁能回答 i-node 存了哪些东西 ?</span></div>
<div><span>vi /usr/include/sys/inode.h</span></div>
<div><span>班主,我不能 access /usr/include/sys/inode.h .<br>摘书如下:<br>Directories contain directory entries. Each entry contains a file or subdirectory name and an index node reference number (i-node number). To increase speed and enhance use of disk space, the data in a file is stored at various locations in the computer’s memory. The i-node contains the addresses used to locate all the scattered blocks of data associated with a file. The i-node also records other information about the file including time of modification and access, access modes, number of links, file owner, and file type.<br>可我发现 -atime 改了, -ctime 还没改. why ?<br>( 我先 cat 一个 ASCII 文件,再用 -atime -1 有它用 -ctime -1 居然没有它.)<br>着岂不跟 inode 信息改变, ctime 就改矛盾吗?</span></div>
<div><span>我不同意你贴出来的那段文章,正如我提到的那样,atime,ctime,mtime是放到超级块里,在sco unix下是一种叫stat的结构.(stat_32),不同的系统文件系统可能不同.<br>sco 下inode的结构如下:</span></div>
<div><span>typedef struct inode<br>{<br>struct inode *i_forw; /* inode hash chain */<br>struct inode *i_back; /* ‘’ */<br>struct inode *av_forw; /* freelist chain */<br>struct inode *av_back; /* ‘’ */<br>int *i_fsptr; /*
typelesspointer to fs dependent */<br>ino32_t i_number; /* i number, 1-to-1 with dev address */<br>ushort i_ftype; /* file type = IFDIR, IFREG, etc. */<br>short i_fstyp; /* File system type */<br>off_t i_size; /* size of file */<br>ushort i_uid; /* owner */<br>ushort i_gid; /* group of owner */<br>ushort i_flag;<br>ushort i_want; /* i_flag extension to avoid MP races */<br>ushort i_count; /* reference count */<br>short i_nlink; /* directory entries */<br>dev_t i_rdev; /* Raw device number */<br>#define i_namtype i_rdev /* i_ftype==IFNAM subtype */<br>dev_t i_dev; /* device where inode resides */<br>struct mount *i_mton;/* ptr to mount table entry that */<br>/* this directory is mounted on */<br>struct region *i_rp; /* ptr to shared region if any */<br>struct stdata *i_sp; /* ptr to associated stream */<br>struct iisem *isem; /* ptr to XENIX semaphores */<br>struct iisd *isd; /* ptr to XENIX shared data */<br>} i_un;<br>#define i_mnton i_un.i_mton /* i_ftype==IFDIR IMOUNT */<br>#define i_rptr i_un.i_rp /* i_ftype==IFREG || i_ftype==IFBLK */<br>#define i_sptr i_un.i_sp /* i_ftype==IFCHR || i_ftype==IFIFO */<br>#define i_sem i_un.isem /* i_ftype==IFNAM && i_namtype==IFSEM */<br>#define i_sd i_un.isd /* i_ftype==IFNAM && i_namtype==IFSHD */</span></div>
<div><span>struct fstypsw *i_fstypp; /* ptr to file system switch FSPTR */<br>long *i_filocks; /* pointer to filock (structure) list */<br>unsigned long i_mappages; /* number of pages currently cached */<br>unsigned long i_vcode; /* read-ahead block save (NFS) */<br>short i_wcnt; /* write open count or ITEXT count */<br>struct lockb i_cilock; /* tas to synchronize i_flag changes */<br>ushort i_rdlocks; /* count of non-exclusive lockers */<br>} inode_t;</span></div>
<div><span>所以,访问一个文件不能改变inode信息.<br>使用chown, chgrp, chmod命令可以很好的比较mtime和ctime<br>chown改变一个文件的属主,用ctime可以找到,用mtime便找不到.<br>试试看.</span></div>
<div><span>多谢斑竹! 我是在 Solaris 上面试的.我是对 -ctime 不明白.<br>试的结果如下:<br>修改文件,-mtime 改了, -ctime 也会改.<br>访问文件,-atime 改了, -ctime 没变.<br>chown, chgrp, chmod,mv, 都会使 -ctime 改变,但不影响 -atime 和 -mtime.<br>touch 可以改 -mtime and/or -atime,但 touch -a 只改访问时间时,-ctime也改了.<br>touch -m 改修改时间时,-ctime当然也改了.<br>好象还有别的很多东西可以令 -ctime 改变, 搞不清楚.<br>有什么方法可以显示 -mtime,atime,ctime 吗?<br>可以用 -ctime 来实现对目录的增量文件进行备份或 transfer 吗 ?<br>多谢!</span></div>
<div><span>没有什么工具显示,(可能是俺不知道)<br>把下面程序里的st_mtime换成st_ctime,或st_atime便可以得到你要的了.<br>#include<br>int<br>main (int argc, char **argv)<br>{<br>struct stat buf;<br>char date[80];<br>char fname[80];<br>printf(
Enter filename (with full path) to check mtime : );<br>scanf(
%s,fname);<br>stat(fname, &buf);<br>printf (
mtime (in sec) of %s = %ld, fname, buf.st_mtime);<br>strcpy(date, ctime((time_t *)&(buf.st_mtime)));<br>printf (
mtime (in date) of %s = %s`, fname, date);
}
atime ls -lu 最近访问文件的时间
ctime ls -li 最近文件有所改变的状态 ,如文件修改,属性属主 改变 ,节点 ,链接变化等 ,应该是不拘泥只是时间前后的改变
mtime 用 ls -l 看到
atime 用 ls -lu 看到
ctime 用 ls -lc 看到. (ls -li 只有 inode number)
摘书如下:
-c Uses time of last modification of the i-node (file
created, mode changed, and so forth) for sorting (-t)
or printing (-l or -n).
-u Uses time of last access instead of last modification
for sorting (with the -t option) or printing (with the
-l option).
-i For each file, prints the i-node number in the first
column of the report.
我在sco unix5.0.5中试了一下,好像不对:chmod,chgrp等不会改变ls -il显示的时间;vi,touch倒是有影响