当前位置: 首页 > article >正文

2,Linux文件基本属性(基于Ubuntu示例进行讲解)

创建文件

  • 创建文件touch命令
  • 创建文件夹mkdir命令
  • 写入文件内容echo命令
# 创建文件夹,文件夹名称为demo_001
mkdir demo_001

# 创建文件,文件名称为demo_file_001.py
touch demo_file_001.py

# 写入内容到文件中,例如写入print("hello world")到demo_file_001.py文件中
echo 'print("hello world")' > demo_file_001.py

查看文件属性

查看文件属性,文件类型,文件主人的权限、文件所属组成员的权限、其他人的权限

# 写法1
ls -l

# 写法2(简写)
ll

至于这边的内容怎么看,网上都是例子,就不详细解释了(直接搜索Linux中ll内容含义即可)。

更改文件权限

  • chgrp更改文件所属组,将文件所属组修改为其他组
# 命令执行时,如果说没权限,则在命令行前面加上sudo尝试,仅限个人Linux系统哈



# chgrp命令实现修改文件所属组,将demo_file_001.py文件的所属组修改为ubuntu组

chgrp ubuntu demo_file_001.py




# 如果是目录文件,则使用-R参数将该目录下的所有文件全部都修改到对应组中

mkdir demo    # 创建目录文件夹

touch demo/demo_file_002.py    # 在demo文件夹下创建demo_file_002.py文件

chgrp -R ubuntu demo    
# 此时demo目录和目录下的所有文件(包括demo_file_002.py)全部都修改所属组为ubuntu
  • chown:更改文件所有者(owner),也可以修改文件所属组
# 基础语法
chown [-R] 文件所有者 文件名    # 修改“文件名”的主人为“文件所有者”
chown [-R] 文件所有者:所属组 文件名    # 修改“文件名”的主人为“文件所有者”,同时组修改为“所属组”


# 执行命令
touch backend.log    # 创建backend.log文件
chown ubuntu backend.log    # 将backend.log文件的主人修改为ubuntu
chown ubuntu:ubuntu backend.log    # 将backend.log文件的主人修改为ubuntu、所属组修改为ubuntu

# 查看,通过ls -l命令查看文件的所属组和所有者
ls -l
  • chmod:更改文件权限属性,文件所有者的权限、文件所属组内成员的权限、其他人的权限【均指操作当前文件时,拥有的权限】
权限对应字母对应权重
r4
w2
执行x1
'''
    linux最基础的权限就9个:
        1,文件所有者(对该文件)的读、写、执行的权限;
        2,文件所属组内成员(对该文件)的读、写、执行的权限;
        3,其他人(对该文件)的读、写、执行的权限
'''

## 语法
chmod [-R] xyz 文件或目录

[-R]:进行递归操作,权限将在“文件或目录下全部更改”
xyz:分别是文件所有者、文件所属组成员、其他成员的权限权重相加(顺序固定)


## 修改权限


chmod 777 demo_file_002.py    
# 修改demo_file_002.py文件的权限为都可以读、写、执行


chmod 700 demo_file_002.py    
# 修改demo_file_002.py文件的权限为只有文件所有人可以读、写、执行,所属组内成员 和 其他人都不可以读、写、执行



## 举例
761:
文件所有者的权重为7=4+2+1=r+w+x,所以文件所有者的权限是可以读、写、执行;
文件所属组内成员的权限为6=4+2=r+w,所以文件所属组内成员的权限是可以读、写,不能执行该文件;
其他人的权限为1=x,所以其他人的权限是可以执行该文件,不可以读、写。


身份user用户group组others其他
对应字母ugo
# 通过对应身份的字母设置权限

chmod u=rwx,g=rx,o=x demo_file_002.py

1,设置用户U的权限为rwx,即可以读、写、执行;
2,设置所属组内成员的权限为rx,即可以读、执行,不可以写;
3,设置其他权限为x,即可以执行,不可以读、写。


http://www.kler.cn/a/510210.html

相关文章:

  • JavaScript--流程控制
  • Vue前端框架概述
  • MongoDB 学习指南:深入探索非关系型数据库
  • springboot基于微信小程序的传统美食文化宣传平台小程序
  • Nginx三种不同类型的虚拟主机(基于域名、IP 和端口)
  • Nmap之企业漏洞扫描(Enterprise Vulnerability Scanning for Nmap)
  • 802.1协议讲解
  • leetcode刷题记录(六十八)——2. 两数相加
  • OpenAI第一个真正意义上的AI Agent:ChatGPT Tasks,使用指南1.0
  • latin1_swedish_ci(latin1 不支持存储中文、日文、韩文等多字节字符)
  • Shell控监Kafka积压
  • 210. 课程表 II【 力扣(LeetCode) 】
  • 【git】如何删除本地分支和远程分支?
  • Gateway与WebFlux
  • docker容器中运行了一个Ubuntu系统,如何把主机的一个文件拷贝到这个Ubuntu系统中
  • python json.dump 插入到json文件中,中文乱码问题
  • MCU中的LSB、MSB和大端模式、小端模式
  • Spring Boot+Vue
  • node.js项目依赖关系分析工具 Depazer 的使用
  • C# winodw TableLayoutPanel 料盒生产状态UI自动生成
  • 差分(前缀和的逆运算)
  • Oracle系列---【Oracle中密码的策略如何设置】
  • 学校C语言实验——文件
  • 新星杯-ESP32智能硬件开发--ESP32系统
  • 常在道中
  • awk命令进阶