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

Linux 权限系统和软件安装(二):深入理解 Linux 权限系统

在 Linux 的世界里,权限系统犹如一位忠诚的卫士,严密守护着系统中的文件与目录,确保只有具备相应权限的用户才能进行操作。与其他一些操作系统不同,Linux 并不依据文件后缀名来标识文件的操作权限,而是构建了一套独特且强大的权限体系。对于学习 Java 全栈开发的我们而言,熟练掌握 Linux 权限系统,无论是在日常开发环境搭建,还是未来企业级项目部署与运维中,都至关重要。今天,让我们一同深入探索 Linux 的权限系统。

一、Linux 权限系统基础认知

(一)权限划分

Linux 系统中的权限主要分为三类:读(r)、写(w)、执行(x)。但这些权限对于文件和目录而言,有着不同的含义。

  1. 文件权限
    • r(可读):当一个文件具有 “r” 权限时,意味着用户能够查看该文件的内容。例如,在 Java 开发中,我们编写的 Java 源文件(.java 后缀),若开发人员对其具有 “r” 权限,就能打开文件查看代码逻辑。
    • w(可写):“w” 权限允许用户修改文件的内容。在项目开发过程中,开发人员需要对 Java 源文件、配置文件等拥有 “w” 权限,才能进行代码修改、配置调整等操作。但如果权限设置不当,非授权人员获得 “w” 权限,可能会恶意篡改代码,影响项目的正常运行。
    • x(可执行):对于可执行文件,如编译后的 Java 字节码文件(.class 后缀)或一些脚本文件(.sh 后缀),“x” 权限决定了用户能否运行该文件。在部署 Java 项目时,需要确保相关的启动脚本具有 “x” 权限,才能顺利启动项目服务。
  2. 目录权限
    • r(可读):赋予目录 “r” 权限后,用户可以查看目录中的内容,即列出目录下的所有文件和子目录。在管理 Java 项目的工作空间时,开发人员需要对项目目录具有 “r” 权限,才能查看其中的文件结构和资源。
    • w(可写):拥有目录的 “w” 权限,用户能够在该目录中创建新文件、修改现有文件的名称以及删除文件或子目录。在 Java 项目开发中,当需要添加新的类文件、删除无用的临时文件时,就需要对项目目录拥有 “w” 权限。
    • x(可执行):“x” 权限对于目录而言,决定了用户能否进入该目录。如果没有 “x” 权限,即便对目录有 “r” 权限,也无法使用cd命令进入该目录。例如,在一个包含多个项目模块的父目录中,若开发人员对某个子模块目录没有 “x” 权限,就无法深入其中进行操作。

(二)查看权限

在 Linux 系统中,使用ll -h命令可以以人性化的模式查看目录中的权限。当执行该命令后,会看到类似如下的显示:

rw-r--r--

这里的三组权限分别描述了属主(user)、所属组(group)和其他人(other)的权限

  • 属主:即文件或目录的创建者,拥有者。在 Java 项目开发中,通常由开发人员创建项目文件和目录,此时该开发人员就是属主。属主对自己创建的文件和目录往往具有较高的权限,以便进行全面的管理和操作。
  • 所属组:属主所在的用户组。在企业级 Java 开发项目中,一个项目团队可能会被划分到同一个用户组。通过所属组权限设置,可以方便地对团队成员的权限进行统一管理。例如,团队中的所有开发人员都属于 “java_dev_group” 用户组,通过设置该组对项目目录的权限,就能控制组内成员对项目资源的访问级别。
  • 其它人:既不是属主,也不是所属组成员的用户。合理设置 “其他人” 的权限,可以保障系统资源的安全性,防止未授权的外部人员随意访问和操作。

(三)修改权限

修改权限使用chmod命令,其语法为chmod [选项] 权限模式 文件/目录名称。常见选项及用法如下:

  1. 选项 -R:该选项用于递归性设置权限,只对目录有效。当对一个目录使用-R选项时,不仅会修改该目录本身的权限,还会递归地修改目录下所有子目录和文件的权限。
  2. 权限模式设置方式
    • 第 1 种模式:通过明确指定属主(u)、所属组(g)、其他人(o)的权限来设置。例如:
chmod u=rwx,g=rw-,o=--- anaconda-ks.cfg

这里表示将anaconda-ks.cfg文件的属主权限设置为可读、可写、可执行(rwx);所属组权限设置为可读、可写(rw-);其他人权限设置为无任何权限(---)。在 Java 项目中,如果一个配置文件只允许项目负责人(属主)进行全面操作,团队成员(所属组)只能查看和修改,而外部人员(其他人)不能访问,就可以采用这样的权限设置。

  • 第 2 种模式:采用 “+” 或 “-” 来修改权限。例如:
chmod u-x,g-w anaconda-ks.cfg

此命令表示去除anaconda-ks.cfg文件属主的执行权限(u-x),去除所属组的写权限(g-w)。在项目开发过程中,有时可能需要临时调整某些用户或用户组的权限,这种方式就很便捷。

  • 第 3 种模式:采用数字来修改权限。权限数字对应关系为:4 代表读(r),2 代表写(w),1 代表执行(x),0 代表无权限(--)。例如:
chmod 600 anaconda-ks.cfg

这里的 “600” 表示属主权限为可读、可写(4 + 2 = 6),所属组和其他人权限为无权限(0)。这种数字表示法简洁明了,在批量设置权限时尤为方便。

3. 给目录授权示例

chmod -R 777 dzkd/

该命令递归地将 “dzkd” 目录及其所有子目录和文件的权限设置为属主、所属组和其他人都具有可读、可写、可执行权限(rwx = 4 + 2 + 1 = 7)。但需要注意,这种设置会使目录及其内容的权限非常开放,在实际应用中应谨慎使用,特别是在涉及敏感信息的场景下。

(四)改变拥有者

在 Linux 系统中,可以使用chown命令改变文件或目录的拥有者和所属组。其语法为chown [选项] 新所有者[:新组] 文件或目录。例如:

chown iwe3 dzkd/

这条命令将 “dzkd” 目录的属主修改为 “iwe3”。在企业开发中,当项目成员变动,某个开发人员接手了另一位开发人员的工作,可能就需要将相关项目文件和目录的属主进行变更。

chown iwe3:iwe3 dzkd/

此命令不仅修改了 “dzkd” 目录的属主为 “iwe3”,还将所属组也修改为 “iwe3” 所在的组。通过合理变更属主和所属组,可以更好地管理项目资源的访问权限,确保只有相关人员能够对资源进行操作。

二、未来在企业工作的小技巧

  1. 基于项目角色的权限管理:在企业级 Java 全栈开发项目中,根据不同的项目角色,如项目经理、开发人员、测试人员、运维人员等,设置不同的用户组,并为每个用户组分配相应的文件和目录权限。例如,项目经理可能需要对项目的所有文件和目录具有读写执行权限,以便全面管理项目;开发人员对自己负责的模块文件具有读写执行权限,对其他模块文件可能只有读权限;测试人员对测试相关的文件和目录具有读写权限等。通过这种精细化的权限管理,可以提高项目的安全性和协作效率。
  2. 定期权限审计定期对项目文件和目录的权限进行审计,检查权限设置是否符合项目的安全策略和业务需求。可以编写脚本,定期扫描项目目录,检查属主、所属组和权限设置是否正确,是否存在权限过度开放或不合理的情况。例如,脚本可以检查是否有非项目组成员拥有项目文件的写权限,或者是否有敏感配置文件的权限设置过于宽松。一旦发现问题,及时进行调整,保障项目的安全性。
  3. 权限变更记录与通知当对文件或目录的权限进行变更时,要做好详细的记录,包括变更的时间、原因、操作人以及变更前后的权限对比等信息。同时,通过邮件或内部通讯工具及时通知相关人员,确保项目团队成员都了解权限的变化,避免因权限变更导致的工作失误或误解。例如,当因为项目安全升级,对某些关键配置文件的权限进行收紧时,及时通知相关开发人员和运维人员,告知他们权限变更的影响和应对方法。

通过对 Linux 权限系统的深入学习,我们在 Linux 环境下的操作能力和安全意识得到了进一步提升。在后续的学习中,我们还将继续探索 Linux 系统的更多奥秘,包括软件安装等重要内容,为成为优秀的 Java 全栈开发者奠定坚实基础。

还请持续关注,后续更新虚拟机安装及Java环境配置教程

相关文章:

Linux 权限系统和软件安装(二):深入理解 Linux 权限系统

在 Linux 的世界里,权限系统犹如一位忠诚的卫士,严密守护着系统中的文件与目录,确保只有具备相应权限的用户才能进行操作。与其他一些操作系统不同,Linux 并不依据文件后缀名来标识文件的操作权限,而是构建了一套独特且…...

二:前端发送POST请求,后端获取数据

接着一:可以通过端口访问公网IP之后 二需要实现:点击飞书多维表格中的按钮,向服务器发送HTTP请求,并执行脚本程序 向服务器发送HTTP请求: 发送请求需要明确一下几个点 请求方法: 由于是向服务器端发送值…...

单机上使用docker搭建minio集群

单机上使用docker搭建minio集群 1.集群安装1.1前提条件1.2步骤指南1.2.1安装 Docker 和 Docker Compose(如果尚未安装)1.2.2编写docker-compose文件1.2.3启动1.2.4访问 2.使用2.1 mc客户端安装2.2创建一个连接2.3简单使用下 这里在ubuntu上单机安装一个m…...

安全生产月安全知识竞赛主持稿串词

女:尊敬的各位领导、各位来宾 男:各位参赛选手、观众朋友们 合:大家好~ 女:安全是天,有了这一份天,我们的员工就会多一份幸福, 我们的企业就会多一丝光彩。 男:安全是地,有了这一片地,我们的员工就多了一…...

C++的设计模式

1. 创建型模式 单例模式 (Singleton) 意图:确保类仅有一个实例,并提供全局访问点。(常见的日志类)实现:class Singleton { private:static Singleton* instance;Singleton() {} // 私有构造函数 public:static Singl…...

C++手撕AVL树

C手撕AVL树 1、AVL树的概念2、AVL树的结构3、AVL树的插入3.1、大概过程3.2、更新平衡因子3.3、更新平衡因子代码3.4、左单旋3.5、右单旋3.6、右左双旋3.7、左右双旋 4、AVL树的删除5、AVL树的查找6、AVL树的平衡检测7、AVL树的其他函数完整代码 1、AVL树的概念 二叉搜索树虽可…...

写大论文的word版本格式整理,实现自动生成目录、参考文献序号、公式序号、图表序号

前情提要:最近开始写大论文,发现由于内容很多导致用老方法一个一个改的话超级麻烦,需要批量自动化处理,尤其是序号,在不断有增添删减的情况时序号手动调整很慢也容易出错,所以搞一个格式总结,记…...

Redission可重试、超时续约的实现原理(源码分析)

Redission遇到其他进程已经占用资源的时候会在指定时间waitTime内进行重试。实现过程如下: 执行获取锁的lua脚本时,会返回一个值, 如果获取锁成功,返回nil,也就是java里的null 如果获取锁失败,用语句“PT…...

java八股文-消息队列

一、MQ基础篇 1. 什么是消息队列? 消息队列(MQ)是分布式系统中实现异步通信的中间件,解耦生产者和消费者。 2. 使用场景有哪些? 异步处理(如注册后发送邮件)系统解耦(不同服务通过…...

3分钟idea接入deepseek

DeepSeek简介 DeepSeek 是杭州深度求索人工智能基础技术研究有限公司开发的一系列大语言模型,背后是知名量化资管巨头幻方量化3。它专注于开发先进的大语言模型和相关技术,拥有多个版本的模型,如 DeepSeek-LLM、DeepSeek-V2、DeepSeek-V3 等&…...

【DeepSeek与鸿蒙HarmonyOS:开启应用开发新次元】

引言:科技融合的新曙光 在当今数字化浪潮中,DeepSeek 和鸿蒙 HarmonyOS 宛如两颗璀璨的明星,各自在人工智能和操作系统领域熠熠生辉。DeepSeek 以其强大的大模型能力,在自然语言处理、代码生成等多个领域展现出卓越的性能&#x…...

基于光度立体视觉的三维重建方法

基于光度立体视觉的三维重建方法 一、三维重建概述二、光度立体原理简介三、Halcon:光度立体实验1.四张测试原图2.结果图3.Halcon实验代码 四、相关参考 光度立体视觉通过多角度的光源激励,获取多个不同光照方向下的表面图像,从中重建表面法向&#xff0…...

在VSCode中接入deepseek

注册就送14元2000万tokens。 https://cloud.siliconflow.cn/i/rnbA6i6U各种大模型 下面介绍我是如如接入vscode的 左边生成一个key,呆会vscode要用,不然401. 打开vscod,电脑能上网。下插件。 下好要配置 点它一下。 要配置,全…...

DeepSeek掘金——VSCode 接入DeepSeek V3大模型,附使用说明

VSCode 接入DeepSeek V3大模型,附使用说明 由于近期 DeepSeek 使用人数激增,服务器压力较大,官网已 暂停充值入口 ,且接口响应也开始不稳定,建议使用第三方部署的 DeepSeek,如 硅基流动 或者使用其他模型/插件,如 豆包免费AI插件 MarsCode、阿里免费AI插件 TONGYI Lin…...

申请SSL证书,如何完成域名验证

一、前言 给大家分享一下Lets Encrypt 证书申请时,如何完成域名验证这一步操作的方法。 二、为什么要进行域名验证 申请SSL证书时进行域名验证的主要原因是确保证书只颁发给有权控制特定域名的实体。这是为了保证互联网的安全性和信任,防止恶意方获取不…...

HTTP实验(ENSP模拟器实现)

HTTP概述 HTTP(HyperText Transfer Protocol,超文本传输协议),设计HTTP最初的目的是为了提供一种发布和接收HTML页面的方法。 HTTP定义了多种请求方法,常用的包括: GET:请求资源。 POST&…...

AI工具评论

deepseek(一系列接入R1的工具如:元宝、纳米、C知道、qq浏览器、百度AI、小艺...,应该都是R1满血版吧...) kimi 豆包 ------ chatGPT Grok3 cursor github copilot https://zhuanlan.zhihu.com/p/21161495794https://zhuan…...

comfy UI节点缺失dlib库处理

安装出现dlib错误: [!] ERROR: Failed building wheel for dlib Failed to build dlib 依赖环境:python3.12 comfyui 最新版本 pip install dlib 出现错误 直接下代码编译 编译为:dlib-19.24.99-cp312-cp312-win_amd64.whl 下载地址&am…...

STM32 HAL库I2C函数使用详解:以MPU6050传感器为例

引言 I2C(Inter - Integrated Circuit)由Philips公司开发的一种简单、双向二线制串行通信协议。它只需要两根线即可在连接于总线上的器件之间传送信息,主要用于短距离、低速的数据传输,广泛应用于各种传感器、存储器等设备的通信中…...

四步彻底卸载IDEA!!!

各位看官早安午安晚安呀 如果您觉得这篇文章对您有帮助的话 欢迎您一键三连,小编尽全力做到更好 欢迎您分享给更多人哦 大家好,我们今天来学习四步彻底卸载IDEA!!! 首先我要提醒各位 如果你想删除 IDEA 相关&#xf…...

内存分配函数malloc kmalloc vmalloc

内存分配函数malloc kmalloc vmalloc malloc实现步骤: 1)请求大小调整:首先,malloc 需要调整用户请求的大小,以适应内部数据结构(例如,可能需要存储额外的元数据)。通常,这包括对齐调整,确保分配的内存地址满足特定硬件要求(如对齐到8字节或16字节边界)。 2)空闲…...

CTF show Web 红包题第六弹

提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框,很难让人不联想到SQL注入,但提示都说了不是SQL注入,所以就不往这方面想了 ​ 先查看一下网页源码,发现一段JavaScript代码,有一个关键类ctfs…...

《Qt C++ 与 OpenCV:解锁视频播放程序设计的奥秘》

引言:探索视频播放程序设计之旅 在当今数字化时代,多媒体应用已渗透到我们生活的方方面面,从日常的视频娱乐到专业的视频监控、视频会议系统,视频播放程序作为多媒体应用的核心组成部分,扮演着至关重要的角色。无论是在个人电脑、移动设备还是智能电视等平台上,用户都期望…...

让AI看见世界:MCP协议与服务器的工作原理

让AI看见世界:MCP协议与服务器的工作原理 MCP(Model Context Protocol)是一种创新的通信协议,旨在让大型语言模型能够安全、高效地与外部资源进行交互。在AI技术快速发展的今天,MCP正成为连接AI与现实世界的重要桥梁。…...

聊一聊接口测试的意义有哪些?

目录 一、隔离性 & 早期测试 二、保障系统集成质量 三、验证业务逻辑的核心层 四、提升测试效率与覆盖度 五、系统稳定性的守护者 六、驱动团队协作与契约管理 七、性能与扩展性的前置评估 八、持续交付的核心支撑 接口测试的意义可以从四个维度展开,首…...

重启Eureka集群中的节点,对已经注册的服务有什么影响

先看答案,如果正确地操作,重启Eureka集群中的节点,对已经注册的服务影响非常小,甚至可以做到无感知。 但如果操作不当,可能会引发短暂的服务发现问题。 下面我们从Eureka的核心工作原理来详细分析这个问题。 Eureka的…...

AI病理诊断七剑下天山,医疗未来触手可及

一、病理诊断困局:刀尖上的医学艺术 1.1 金标准背后的隐痛 病理诊断被誉为"诊断的诊断",医生需通过显微镜观察组织切片,在细胞迷宫中捕捉癌变信号。某省病理质控报告显示,基层医院误诊率达12%-15%,专家会诊…...

QT3D学习笔记——圆台、圆锥

类名作用Qt3DWindow3D渲染窗口容器QEntity场景中的实体(对象或容器)QCamera控制观察视角QPointLight点光源QConeMesh圆锥几何网格QTransform控制实体的位置/旋转/缩放QPhongMaterialPhong光照材质(定义颜色、反光等)QFirstPersonC…...

手机平板能效生态设计指令EU 2023/1670标准解读

手机平板能效生态设计指令EU 2023/1670标准解读 以下是针对欧盟《手机和平板电脑生态设计法规》(EU) 2023/1670 的核心解读,综合法规核心要求、最新修正及企业合规要点: 一、法规背景与目标 生效与强制时间 发布于2023年8月31日(OJ公报&…...

Unity VR/MR开发-VR开发与传统3D开发的差异

视频讲解链接:【XR马斯维】VR/MR开发与传统3D开发的差异【UnityVR/MR开发教程--入门】_哔哩哔哩_bilibili...