首页 > 系统相关 >Study mission - Linux related

Study mission - Linux related

时间:2023-06-17 17:14:30浏览次数:61  
标签:文件 Shell Study mission related 用户 Linux 权限 目录

学习任务:Linux related

1. linux文件系统结构,各个常用系统目录的含义

  • /bin
    bin 是 Binaries (二进制文件) 的缩写, 这个目录存放着最经常使用的命令。

  • /boot
    这里存放的是启动 Linux 时使用的一些核心文件,包括一些连接文件以及镜像文件。

  • /dev
    dev 是 Device(设备) 的缩写, 该目录下存放的是 Linux 的外部设备,在 Linux 中访问设备的方式和访问文件的方式是相同的

  • /etc
    etc 是 Etcetera(等等) 的缩写,这个目录用来存放所有的系统管理所需要的配置文件和子目录。

  • /home
    用户的主目录,在 Linux 中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。

  • /lib
    lib 是 Library(库) 的缩写这个目录里存放着系统最基本的动态连接共享库,其作用类似于 Windows 里的 DLL 文件。几乎所有的应用程序都需要用到这些共享库。

  • /media
    linux 系统会自动识别一些设备,例如U盘、光驱等等,当识别后,Linux 会把识别的设备挂载到这个目录下。
    比如我的 /media/danielvon 文件夹下有 /Apps (Windows下的D盘)、/DanielVon (E盘)、/PC (C盘)、/RESTORE、/RimroseVon (F盘)

  • /mnt
    系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在 /mnt/ 上,然后进入该目录就可以查看光驱里的内容了。

  • /opt
    opt 是 optional(可选) 的缩写,这是给主机额外安装软件所摆放的目录。比如你安装一个 ORACLE 数据库则就可以放到这个目录下。默认是空的。

  • /porc
    proc 是 Processes(进程) 的缩写,/proc 是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。
    这个目录的内容不在硬盘上而是在 内存 里,我们也可以直接修改里面的某些文件,比如可以通过下面的命令来屏蔽主机的ping命令,使别人无法ping你的机器:

  echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all
  • /lost+found
    这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。(3.12,我打开我的Ubuntu居然找到了这个文件夹,此前找寻未果)

  • /root
    该目录为系统管理员,也称作超级权限者的用户主目录。进这个文件夹需要输两次密码,第一次是打开需要密码,第二次是访问文件需要密码。
    我的 /root 下有 模板snap 两个文件夹。snap 文件夹里边是应用商店下载的应用。

  • /run
    是一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删掉或清除。如果你的系统上有 /var/run 目录,应该让它指向 run。

  • /sbin
    s 就是 Super User 的意思,是 Superuser Binaries (超级用户的二进制文件) 的缩写,这里存放的是系统管理员使用的系统管理程序。

  • /srv
    该目录存放一些服务启动之后需要提取的数据。(不用服务器就是空)

  • /tmp
    tmp 是 temporary(临时) 的缩写这个目录是用来存放一些临时文件的。

  • /usr
    usr 是 unix shared resources(共享资源) 的缩写(我一直以为是user的缩写) ,这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于 windows 下的 program files 目录。

    • /usr/bin
      系统用户使用的比较高级的管理程序和系统守护程序。
    • /usr/sbin
      超级用户使用的比较高级的管理程序和系统守护程序。
  • /usr/src
    内核源代码默认的放置目录。

  • /var
    var 是 variable(变量) 的缩写,这个目录中存放着在不断扩充着的东西,我们习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件。

  • /selinux
    这个目录是 Redhat/CentOS 所特有的目录,Selinux 是一个安全机制,类似于 windows 的防火墙,但是这套机制比较复杂,这个目录就是存放selinux相关的文件的。

  • /sys
    这是 Linux2.6 内核的一个很大的变化。该目录下安装了 2.6 内核中新出现的一个文件系统 sysfs 。

    sysfs 文件系统集成了下面3种文件系统的信息:针对进程信息的 proc 文件系统、针对设备的 devfs 文件系统以及针对伪终端的 devpts 文件系统。

    该文件系统是内核设备树的一个直观反映。

    当一个内核对象被创建的时候,对应的文件和目录也在内核对象子系统中被创建。

2.linux基本操作命令与文件权限管理文档

linux是一种开源的类Unix操作系统,它有着强大的功能和稳定的性能。在linux中,我们可以通过命令行来执行各种操作,如文件和目录的创建、删除、复制、移动、重命名等。同时,我们也可以通过命令来控制文件和目录的属性和权限,如所有者、用户组、读写执行等。

文件和目录的属性和权限是linux系统中非常重要的概念,它们决定了不同的用户和程序对文件和目录的访问和操作能力。

在linux中,每个文件和目录都有以下三种属性:

类型(type):表示文件是普通文件、目录、链接、设备等。

所有者(owner):表示文件属于哪个用户。

用户组(group):表示文件属于哪个用户组。

每个文件和目录也有以下三种权限:

读(read):表示可以查看文件或目录的内容。

写(write):表示可以修改文件或目录的内容。

执行(execute):表示可以运行文件或进入目录。

在linux中,我们可以使用以下两个命令来查看和修改文件或目录的属性和权限:

ls(list):列出文件或目录的信息,如类型、所有者、用户组、权限、大小、时间等。

chmod(change mode):改变文件或目录的权限。

ls命令

ls命令是最常用的命令之一,它可以列出当前目录或指定目录下的所有文件和子目录。它有很多选项和参数,常用的有以下几个:

-a:显示所有文件,包括隐藏文件(以.开头的文件)。(常用

-l:显示长格式信息,包括类型、所有者、用户组、权限、大小、时间等。(常用

-d:只显示目录本身,而不是目录下的内容。(常用

-R:递归显示子目录下的内容。

例如:

列出当前目录下的所有文件和子目录 ls -a

列出当前目录下的所有文件和子目录,并显示长格式信息 ls -al

列出当前目录本身,并显示长格式信息 ls -ald

列出当前目录及其子目录下的所有文件,并显示长格式信息 ls -alR

chmod命令

chmod命令是用来改变文件或目录的权限的命令。它有两种常用的方式来指定权限:

数字方式:使用数字0-7来表示不同的权限组合,其中0表示无权限,1表示执行权限,2表示写权限,4表示读权限。数字之间相加得到不同用户对应的权限。例如,755表示所有者有读写执行权限(4+2+1=7),用户组和其他用户有读执行权限(4+1=5)。

符号方式:使用符号 u(user)、g(group)、o(other)、a(all)来表示不同用户,使用符号 +(增加)、-(减少)、=(设置)来表示操作,使用符号 r(read)、w(write)、x(execute)来表示权限。例如,u+x 表示给所有者增加执行权限,g-w 表示给用户组减少写权限,o=rwx 表示给其他用户设置读写执行权限。

例如:

给当前目录下的file.txt文件设置所有者有读写执行权限,用户组和其他用户有读执行权限

chmod 755 file.txt

给当前目录下的file.txt文件给所有者增加执行权限,给用户组减少写权限,给其他用户设置读写执行权限

chmod u+x,g-w,o=rwx file.txt

除了ls和chmod命令外,linux还有很多其他的基本操作命令,如:

  • cd(change directory):切换当前工作目录。
# 使用绝对路径切换到 daniel 目录

  cd /root/daniel/

# 使用相对路径切换到 daniel 目录

  cd ./danielvon/

# 表示回到自己的家目录,亦即是 /root 这个目录

  cd ~

# 表示去到目前的上一级目录,亦即是 /root 的上一级目录的意思;

  cd ..
  • pwd(print working directory):显示当前工作目录的绝对路径。
# 语法:

  pwd [-P]

# 选项与参数:

  -P: 显示出确实的路径,而非使用链接 (link) 路径。
  • cp(copy):复制文件或目录。
# 语法:

  cp [-adfilprsu] 来源档(source) 目标档(destination)

  cp [options] source1 source2 source3 .... directory

# 选项与参数:

  -a:相当於 -pdr 的意思,至於 pdr 请参考下列说明;(常用)

  -d:若来源档为链接档的属性(link file),则复制链接档属性而非文件本身;

  -f:为强制(force)的意思,若目标文件已经存在且无法开启,则移除后再尝试一次;

  -i:若目标档(destination)已经存在时,在覆盖时会先询问动作的进行(常用)

  -l:进行硬式链接(hard link)的链接档创建,而非复制文件本身;

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

  -r:递归持续复制,用於目录的复制行为;(常用)

  -s:复制成为符号链接档 (symbolic link),亦即『捷径』文件;

  -u:若 destination 比 source 旧才升级 destination !

# 用 root 身份,将 root 目录下的 .bashrc 复制到 /tmp 下,并命名为 bashrc
  • mv(move):移动或重命名文件或目录。
# 语法:

  mv [-fiu] source destination

  mv [options] source1 source2 source3 .... directory

# 选项与参数:

  -f :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖;

  -i :若目标文件 (destination) 已经存在时,就会询问是否覆盖!

  -u :若目标文件已经存在,且 source 比较新,才会升级 (update)
  • rm(remove):删除文件或目录。
# 语法:

  rm [-fir] 文件或目录

# 选项与参数:

  -f :就是 force 的意思,忽略不存在的文件,不会出现警告信息;

  -i :互动模式,在删除前会询问使用者是否动作

  -r :递归删除啊!最常用在目录的删除了!这是非常危险的选项!!!


  ↓再多看一眼就会爆炸

    sudo rm -rf /   ←Linux的一生中只能用一次的命令

  ↑再靠近一点快被融化


# 如果加上 -i 的选项就会主动询问喔,避免你删除到错误的档名!
  • mkdir(make directory):创建目录。
# 选项与参数:

  -m :配置文件的权限喔!直接配置,不需要看默认权限 (umask) 的脸色~

  -p :帮助你直接将所需要的目录(包含上一级目录)递归创建起来!
  • rmdir(remove directory):删除空目录。
# 语法:

  rmdir [-p] 目录名称

# 选项与参数:

  -p :从该目录起,一次删除多级空目录
  • touch:创建空文件或修改文件的时间戳。

  • cat:查看或连接文件的内容。(由第一行开始显示文件内容)

  • more:分页显示文件的内容。

  • grep:在文件中查找匹配的字符串。

  • find:在目录中查找符合条件的文件或目录。

  • ps:显示当前进程的信息

可以使用 man [命令] 来查看各个命令的使用文档,如:man cp

3.shell bash zsh 终端 等名词含义以及之间的关系。

  • Shell
    Shell(也称为壳层)在计算机科学中指“为用户提供用户界面”的软件,通常指的是命令行界面的解析器。一般来说,这个词是指操作系统中提供访问内核所提供之服务的程序。Shell也用于泛指所有为用户提供操作界面的程序,也就是程序和用户交互的层面。因此与之相对的是内核(英语:Kernel),内核不提供和用户的交互功能。 (quote from Wikipedia)
    Shell 是一个用 C 语言编写的程序,它是用户使用 Linux 的桥梁。
    Shell 既是一种命令语言,又是一种程序设计语言。
    Shell 是指一种应用程序,这个应用程序提供了一个界面,用户通过这个界面访问操作系统内核的服务。
    比如 Windows 里的 shell 就叫 Windows PowerShell

  • Bash (Bourne Again Shell)
    由于易用和免费,Bash 在日常工作中被广泛使用。同时,Bash 也是大多数 Linux 系统默认的 Shell。
    在一般情况下,人们并不区分 Bourne Shell 和 Bourne Again Shell,所以,像 #!/bin/sh ,它同样也可以改为 #!/bin/bash

  • zsh
    目前常用的 Linux 系统和 OS X 系统的默认 Shell 都是 bash,但是真正强大的 Shell 是深藏不露的 zsh, 这货绝对是马车中的跑车,跑车中的飞行车,史称『终极 Shell』,但是由于配置过于复杂,所以初期无人问津,很多人跑过来看看 zsh 的配置指南,什么都不说转身就走了。直到有一天,国外有个穷极无聊的程序员开发出了一个能够让你快速上手的zsh项目,叫做「oh my zsh」,Github 网址是:https://github.com/robbyrussell/oh-my-zsh 。这玩意就像「X天叫你学会 C++」系列,可以让你神功速成,而且是真的。(摘自 https://zhuanlan.zhihu.com/p/19556676)

  • terminal (终端,或者特指终端模拟器)
    作用是提供一个命令的输入输出环境,在 linux 下使用组合键 ctrl+alt+T 打开的就是终端。
    当你打开一个 terminal 时,操作系统会将 terminal 和 shell 关联起来,当我们在 terminal 中输入命令后,shell 就负责解释命令。

标签:文件,Shell,Study,mission,related,用户,Linux,权限,目录
From: https://www.cnblogs.com/RimroseLim/p/17487704.html

相关文章

  • 80端口被占用怎么办(以phpstudy为例)
    netstat-anonetshhttpshowservicestate这里主要看 进程ID,根据ID去任务管理器中找对应的PID进程,该结束的结束,该停的停 ......
  • Mark Fan:A computational model study on the mechanical response mechanism of asp
    WuhanJiangxiaRoadandBridgeEngineeringCo.,LtdSchoolofCivilEngineeringandArchitecture,WuhanInstituteofTechnologyMarkFan 15927602711Introduction:Asphaltisacommonlyusedmaterialinroadconstruction,anditsmechanicalpropertiespl......
  • Linux中-bash: /dev/null: Permission denied问题解决
    云上架构2021年08月06日09:19 ·  阅读682​今天在Centos7上运行如下命令 shell复制代码######添加hdfs用户#####useraddhdfs######切换至hdfs用户#####su-hdfs报如下错误 javascript复制代码-bash:/dev/null:Permissiondenied-bash......
  • VSCode - Check Keyboard Shortcuts related to commenting
    Clickthegearicon,thenselect'KeyboardShortcuts':Search'comment': ......
  • windows php7、PHPStudy(小皮)配置oracle扩展
    一、php配置oci扩展1.访问链接下载对应oracle版本的即时客户端(OracleInstantClient)https://www.oracle.com/database/technologies/instant-client/winx64-64-downloads.html  2.解压下载文件,将下面两个文件放入php目录下   3.访问链接https://windows.php.net/down......
  • Admission controllers(准入控制器)
    含义准入控制器是一段代码,在请求认证和鉴权之后、对象被持久化之前拦截到达API服务器的请求准入控制器限制创建、删除、修改对象的请求作用准入控制器可以执行验证(validating)、或变更(Mutating)操作准入控制阶段第一阶段:运行变更准入控制器第二阶段:运行验证准入控制器命令行......
  • excel导入失败:failed to open stream: Permission denied
    用的easyswoole框架,做得导入功能,用了php的file_put_contents函数PHPWarning:file_put_contents(1551064493.xls):failedtoopenstream:PermissiondeniedinPhpstormProjects/UjiaoCloud-API-2.0/App/HttpController/Teachers/Plan/Board.phponline1971、尝试1,查看file......
  • WSL: ssh localhost Permission denied (publickey)
    Ifyou'rerunningUbuntuonWindowsSubsystemforLinux,therewillnotbeapreinstalledpublickeyorauthorizedkeyslist,soyou'llneedtogenerateyourown.Ifyoudon'talreadyhaveopenssh-serverinstalled:sudoapt-getupgradesud......
  • Vulnhub: Mission-Pumpkin v1.0: PumpkinGarden靶机
    kali:192.168.111.111靶机:192.168.111.130信息收集端口扫描nmap-A-sC-v-sV-T5-p---script=http-enum192.168.111.130在1515网站的img目录下的hidden_secret/目录中存在clue.txtbase64解密后得到scarecrow:5Qn@$y使用用户:scarecrow,密码:5Qn@$y,登录目标sshsshs......
  • Linux 下启动jmeter 报-bash: bin/jmeter: Permission denied
    问题:通过cd进入jmeter目录中,执行脚本 bin/jmeter-n-txxxxx.jmx -l../50.jtl出现以下问题解决方法:修改文件权限chmod+xbin/jmeter修改后再次执行可正常启动 ......