您的位置:首页 > 运维架构 > Linux

centos 目录文件管理 mkdir,rm,touch,误删文件extundelete,cp,mv,cat,more,less ,head,tail,chown,chmod ,umask 第四节课

2015-09-09 23:24 976 查看
centos 目录文件管理 mkdir,rm,touch,误删文件extundelete,cp,mv,cat,more,less ,head,tail,chown,chmod ,umask 第四节课

上半节课

mkdir
rm
touch
误删文件用extundelete

cp
mv
cat
more
less 分页器
head
tail

下半节课

文件类型
9位权限
一个inode对应一个文件,小文件多inode占用多
目录硬链接数:ls -la |grep "^d" |wc -l
chown
chmod
umask

mkdir -p

创建多个目录
mkdir 12 34 56

创建多个目录 mkdir 12 34 56

/bin/rm :直接跳过alias,直接执行rm,不提示

touch :若文件存在,更改文件的三个time

rm -rf 删除文件,目录,非空目录 r针对目录 f强制删除

误删文件用extundelete,不要再写,inode和文件名还在

1、安装依赖包 yum install -y e2fsprogs*

2、下载并安装extundelete

cp

拷文件 cp 12.log /tmp/1.txt 拷目录,加斜线/tmp/ cp -r 12 /tmp/
会不会覆盖,其实可以把目录当成一个文件 目标目录存在覆盖目录下的文件
-p 等于--preserve=模式,所有权,时间戳
-r --recursive 复制目录及目录内的所有项目
# touch 12/2.txt
# cp -r 12 /tmp/ cp:是否覆盖"/tmp/12/1.txt"? y
# ls /tmp 12
# ls /tmp/12 12 1.txt 2.txt
#/bin/cp -rp .* /tmp/c/ //当前目录下的文件拷贝到/tmp/c/下

mv

改名 不用rename

mv 1.txt 2.txt

mv 2.txt /tmp/

目标目录存在不能剪切,不能覆盖

[root@steven ~]# mv 12 /tmp/

mv:是否覆盖"/tmp/12"? y

mv: 无法将"12" 移动至"/tmp/12": 目录非空

cat -A 显示隐藏字符

less 分页器 几个快捷键:

j下翻

k上翻

g第一行

G最后一行

pageup

pagedown

/ 搜索

n 搜索中下翻

shift+n 搜索中上翻

q 退出

head

head -n

head -c :显示文件前n个字节 head -c 20 log2014.log

tail
tail -f 自动滚动要查看的文件

文件类型

- 普通文件
d 目录文件
b 块设备文件 随机分配 无顺序的 随机读写
c 字符设备文件 有顺序的 顺序读写
s 套接字文件
l 软链接文件
p 管道文件

硬链接文件没有符号表示

套接字文件 socket:运行两个进程进行通信,例如mysql,php,客户端和服务器端通信



权限

9位权限后面是+或.跟selinux和acl有关系



这个大小只是目录本身的大小,Linux不会自动帮你du -sh,需要你自己去du -sh统计整个目录以及子文件和子文件夹的大小



一个inode对应一个文件,ext4=inode+block

目录存文件名

inode存
文件大小
文件时间
属性

所以硬链接可以多个文件用同一个inode,文件名不一样,inode一样

目录不能做硬链接,因为目录包含了子目录和父目录

统计一个目录的硬链接数

ls -la |grep "^d" |wc -l
cd /
ll -d /root/

文件最后更改时间,当然你碰一下touch他,他的更改时间就会改变



chown

改属主 chown hua 2.txt

改属组 chown :hua 2.txt

属主属组一起改 chown hua:hua test

递归修改目录和目录下的文件 chown -R hua:hua test/

chmod

7=rwx

r=4

w=2

x=1

chomd 420 2.txt

chomd u+r g+r o+r 2.txt

chmod -R 777 study/

chmod a=all u=user g=group o=other
chmod all+r

chmod +x 2.txt  ==chmod a+x 2.txt


umask 0022 777-022 755 目录必须有x权限来打开目录 最大777

umask 0022 666-022 644 普通文件最大666

root uid<199 umask 0022

非root uid>199 umask 0002

改umask

umask 001

666-001=666 因为x权限本来就没有

f
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: