热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

掌握LinuxShell核心概念与基础技能

掌握LinuxShell核心概念与基础技能,本文详细介绍了文件系统和安全管理中的`chmod`命令。`chmod`命令支持两种模式:符号模式和绝对模式。符号模式使用`ugo`表示用户类别,`rwx`表示权限类型;而绝对模式则通过八进制数值来精确设置不同用户的权限。此外,文章还探讨了其他重要的Shell命令和技巧,帮助读者全面理解和应用Linux环境下的文件管理和安全控制。

一、文件系统和安全

chmod命令

chmod命令有两种模式,一种是符号模式,用ugo执行用户,用rwx执行权限;另一种是绝对模式,用八进制不同位置的不同值来代表不同用户的不同权限。

  • 符号模式

chmod命令的格式为 chmod [who] operator [permission] filename

其中[who]的取值可以为

1 u:文件属主的权限
2 g:用户所在组的权限
3 o:其他用户权限
4 a:所有用户权限
5 如果省略[who]参数,会同时为u和g设置权限,即同时为属主和用户所在组设置权限

operator取值为

1 +:增加权限
2 -:取消权限
3 =:设定权限

permission

1 r:读
2 w:写
3 x:执行
4 另外还有s,t,l,u,g,o不常用

命令举例,

1 chmod +x temp //为属主和所用所在组增加执行权限
2 chmod a-w temp //收回所有用户的写权限(当然属主自己执行的话已然会有w权限)

绝对模式

绝对模式下,chmod命令的格式为 chmod [mode] file

[mode]是一个八进制数,八进制数与用户对应关系如下,

 1 0 4 0 0 文件属主可读
 2 0 2 0 0 文件属主可写
 3 0 1 0 0 文件属主可执行
 4 
 5 0 0 4 0 属组用户可读
 6 0 0 2 0 属组用户可写
 7 0 0 1 0 属组用户可执行
 8 
 9 0 0 0 4 其他用户可读
10 0 0 0 2 其他用户可写
11 0 0 0 1 其他用户可执行

将相同类型用户所拥有的权值相加就是这类用户最终的权限,

例如

令属主可读写并能执行,则权值为4+2+1=7

属组可读不可写可执行,则权值为4+0+1=5

其他用户可读不可写不可执行,则权值为4+0+0=4

最终我们设置权限的命令就是 chmod 754 filename

用下面方式表达更直观,

1 文件属主:r w x:4 + 2 + 1
2 属组用户:r w x:4 + 2 + 1
3 其他用户:r w x:4 + 2 + 1

硬连接和软连接

文件节点

在linux底层,并不是按照文件名来唯一标识一个文件,而是通过文件节点(inode)来标识的。

硬连接

Hard Link就是建立多个不同文件名,但是文件节点相同的文件(即在底层属于同一个地址空间),用命令 ln f1 f2

软连接

也叫符号链接(Symbolic link)就是建立元文件的一个文本文件,保存着原文件的位置信息,访问软连接文件也等同于访问原文件,类似windows的快捷方式。

软连接与硬连接的区别在于删除文件,如果删除一个文件,对它的硬连接文件不会有影响(相当于硬连接文件取代了原文件),但是其软连接文件不再是有效文件。

下面举例说明,

随便新建一个文件  echo agfgfgfdg3fsfsdf > f1

新建硬连接    ln f1 f2

新建软连接    ln -s f1 f3

如果修改f3    echo 23423423 >> f3

会发现f1和f2都被修改了

1 cat f3
2 agfgfgfdg3fsfsdf
3 23423423
1 cat f2
2 cat f3
3 agfgfgfdg3fsfsdf
4 23423423
1 cat f1
2 agfgfgfdg3fsfsdf
3 23423423

如果删除f1, 会发现其硬连接f2已然可访问,但是软连接f3已经无效了,

1 cat f3
2 cat: f3: No such file or directory

Linux Shell基础知识


推荐阅读
  • 本文详细介绍了如何正确设置Shadowsocks公共代理,包括调整超时设置、检查系统限制、防止滥用及遵守DMCA法规等关键步骤。 ... [详细]
  • 本文将从基础概念入手,详细探讨SpringMVC框架中DispatcherServlet如何通过HandlerMapping进行请求分发,以及其背后的源码实现细节。 ... [详细]
  • Windows操作系统提供了Encrypting File System (EFS)作为内置的数据加密工具,特别适用于对NTFS分区上的文件和文件夹进行加密处理。本文将详细介绍如何使用EFS加密文件夹,以及加密过程中的注意事项。 ... [详细]
  • Jupyter Notebook多语言环境搭建指南
    本文详细介绍了如何在Linux环境下为Jupyter Notebook配置Python、Python3、R及Go四种编程语言的环境,包括必要的软件安装和配置步骤。 ... [详细]
  • 如何在PHP中安装Xdebug扩展
    本文介绍了如何从PECL下载并编译安装Xdebug扩展,以及如何配置PHP和PHPStorm以启用调试功能。 ... [详细]
  • 本文详细介绍了如何搭建一个高可用的MongoDB集群,包括环境准备、用户配置、目录创建、MongoDB安装、配置文件设置、集群组件部署等步骤。特别关注分片、读写分离及负载均衡的实现。 ... [详细]
  • importjava.io.*;importjava.util.*;publicclass五子棋游戏{staticintm1;staticintn1;staticfinalintS ... [详细]
  • 本文详细探讨了BCTF竞赛中窃密木马题目的解题策略,重点分析了该题目在漏洞挖掘与利用方面的技巧。 ... [详细]
  • 调试利器SSH隧道
    在开发微信公众号或小程序的时候,由于微信平台规则的限制,部分接口需要通过线上域名才能正常访问。但我们一般都会在本地开发,因为这能快速的看到 ... [详细]
  • 本文介绍了如何通过C#语言调用动态链接库(DLL)中的函数来实现IC卡的基本操作,包括初始化设备、设置密码模式、获取设备状态等,并详细展示了将TextBox中的数据写入IC卡的具体实现方法。 ... [详细]
  • 从理想主义者的内心深处萌发的技术信仰,推动了云原生技术在全球范围内的快速发展。本文将带你深入了解阿里巴巴在开源领域的贡献与成就。 ... [详细]
  • 回顾两年前春节期间的一个个人项目,该项目原本计划参加竞赛,但最终作为练习项目完成。独自完成了从编码到UI设计的全部工作,尽管代码量不大,但仍有一定的参考价值。本文将详细介绍该项目的背景、功能及技术实现。 ... [详细]
  • 本文探讨了在一个物理隔离的环境中构建数据交换平台所面临的挑战,包括但不限于数据加密、传输监控及确保文件交换的安全性和可靠性。同时,作者结合自身项目经验,分享了项目规划、实施过程中的关键决策及其背后的思考。 ... [详细]
  • 本文详细介绍了在Linux操作系统上安装和部署MySQL数据库的过程,包括必要的环境准备、安装步骤、配置优化及安全设置等内容。 ... [详细]
  • 高级缩放示例.就像谷歌地图一样.它仅缩放图块,但不缩放整个图像.因此,缩放的瓷砖占据了恒定的记忆,并且不会为大型缩放图像调整大小的图像.对于简化的缩放示例lookhere.在Win ... [详细]
author-avatar
书友67299131
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有