侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

linux学习日记四 文件与目录管理

linux  /  管理员 发布于 7年前   159

====基本命令====

# pwd [-P] :显示当前的工作目录

-P:选项表示显示实际的工作目录,而非连接文件本身的目录名

# mkdir [-mp] 目录名:新建目录

-m:设置文件的权限,直接设置,不需要看默认权限(umask)

-p:递归创建目录

# rmdir [-p] 目录名称:删除空的目录

-p:连同上层空目录也一起删除

# echo $PATH 可以显示可执行文件路径,如果在当前目录下,必须输入./xx才能执行,默认当前路径.不在PATH中。

# ls [-adhlSt] 目录:列出目录里的文件

-a:所有文件,包含隐藏文件

-d:仅仅列出目录的信息,不列出里面的文件

-h:文件大写以K,M,G显示

-l:一行一行显示详细信息

-S:按文件大小排序,而不是默认的文件名排序

-t:依文件修改时间排序

–full-time:文件修改的完整时间

====文件的复制====

# cp [-apdriu] source1 source2 … directory

-a:相当于-pdr

-p:连同文件属性一起复制,而非使用默认属性(备份常用)

-d:若源文件为link file,则复制link file而非文件本身

-r:递归复制,用于目录复制行为(常用)

-i:若目标文件存在,在覆盖时候询问操作的进行(常用)

-u:若目标文件比源文件旧才更新目标文件

注意:cp dir1/* dir2/ 和 cp -r dir1/ dir2/的区别,前一个复制dir1下的所有文件到dir2,后一个复制dir1目录到dir2(-r 连带目录下的文件也递归复制)

====文件的删除====

# rm [-fir] 文件或者目录

-f:force,忽略不存在的文件,不出现警告信息,也不询问用户是否删除

-i:互动模式,询问用户是否删除

-r:递归删除,谨慎小心!!

====文件的移动====

# mv [-fiu] source1 source2 … directory

-f:force,不询问,直接覆盖

-i:目标文件已经存在,询问是否覆盖

-u:如果目标文件已存在,且source比较新,才覆盖

====获取path和filename====

# dirname /etc/sysconfig/network 得到/etc/sysconfig

# basename /etc/sysconfig/network 得到 network

====文件内容查询====

cat:从第一行开始显示

tac:最后一行开始显示

nl:显示的时候,输出行号

more:一页页显示,只能向后翻页

less:一页页显示,可以向前向后翻页,man页面就是调用的less

head -n 100:只显示头100行,head -n -100:前面的所有行,不包括最后的100行

tail -n 100 -f /var/log:只显示结尾100行(-f可以持续显示内容,很有用),tail -n +100:显示后面所有行,但不包括最前面的100行

od:以二进制方式读取文件内容

====文件的三个比较重要的时间属性====

mtime:modification time,文件的创建或者修改时间

ctime:文件的状态status改变的时间,比如权限或者属性更改

atime:access time,文件被访问被读取的时间

可使用命令:ls -l –time=atime/ctime/mtime 显示。默认是mtime

利用touch命令可以修改以上三个时间,可以用来创建一个空的文件

====默认权限与隐藏权限====

chattr设置隐藏属性,lsattr查看隐藏属性

# umask -S :查看默认权限

对文件和目录的默认权限是不用的:

对文件而言:-rw-rw-rw

对目录而言:drwxrwxrwx

而umask的数值指的是在此基础上剪掉的权限部分。

# umask 002 可设置

# chattr [+-=][ai] 文件或者目录

+:增加,如果原本存在,不动,-也是一样,=直接赋值

a:这个文件只能增加数据,也不能删除也不能修改数据,只有root可以设置这个东东

i:这个就厉害了,可以让一个文件不被删除、改名、设置连接也无法写入或添加数据,只有root可以设置。

# lsattr [-adR] 文件或目录,可以查看隐藏属性

====文件特殊权限:SUID,SGID,SBIT====

当s出现在owner的x上时候,代表SUID,其含义是:

* SUID权限仅对二进制程序(binary program)有效;

* 执行者对于该程序需要具备x的可执行权限;

* 本权限仅在执行程序过程中(run-time)有效;

* 执行者将具有该程序owner的权限。

当s出现在group的x上时候,代表SGID,其含义是:

对文件来讲 –>

* SGID对二进制程序有用;

* 程序执行者对该程序来说,需具备x的权限;

* 执行者在执行过程中会获得该程序用户组的支持。

对目录来讲–>

* 用户如果对此目录具有r与x的权限,该用户可以进入该目录;

* 用户在此目录下的有效用户组(effective group)变为该目录的group;

* 若用户在此目录下具有w权限,则用户创建的新文件的group与此目录的group一样。

SBIT(Sticky Bit)只对目录有效,作用是:

* 当用户对于此目录有w,x权限的时候;

* 用户在该目录下创建文件或者目录,仅有自己和root才能删除

4为SUID,2为SGID,1为SBIT

chmod 4755 filename,你懂得。如果是S和T表示连x的权限都没有了,那s和t的设置就没有啥用了,摆设而已,空的。

====命令与文件的查询====

# which command:查找命令的位置,根据$PATH去查找的。

文件名的查找:

先用whereis 和 locate查找,速度快,因为直接查询数据库,而找不到后再用find,直接搜索硬盘

# whereis [-bmsu] 文件或目录名

-b:只找二进制文件

-m:只找说明文件manual路径下的文件

-s:只找source源文件

-u:查找不在上述三个选项中的其他特殊文件

# locate [-ir] keyword

-i:忽略大小写

-r:正则式查找

最后一个find命令,太强大了,不想写了,自己去查吧。

find /var -mtime +4:大于等于5天前的文件名

find /var -mtime -4:小于等于4天内的文件名

find /var -mtime 4:4~5天那一天

find /home -user yidao

find / -nouser

find / -name password:名字为password的文件

find /var -type s:socket文件

find / -perm +7000

find / -perm +7000 -exec ls -l {} \;

find /etc -name ‘*httpd*’ :通配符形式也行


  • 上一条:
    linux ssh安全加固方法
    下一条:
    linux学习日记三 文件权限与目录配置
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在Linux系统中使用Iptables实现流量转发功能流程步骤(0个评论)
    • vim学习笔记-入门级需要了解的一些快捷键(0个评论)
    • 在centos7系统中实现分区并格式化挂载一块硬盘到/data目录流程步骤(0个评论)
    • 在Linux系统种查看某一个进程所占用的内存命令(0个评论)
    • Linux中grep命令中的10种高级用法浅析(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-11
    • 2017-07
    • 2017-10
    • 2017-11
    • 2018-01
    • 2018-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-03
    • 2022-04
    • 2022-08
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-06
    • 2023-07
    • 2023-10
    • 2023-12
    • 2024-01
    • 2024-04
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客