加入收藏 | 设为首页 | 会员中心 | 我要投稿 百科站长网 (https://www.baikewang.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

LINUX之根目录介绍、普通目录创建、删除、复制、移动、权限管理命令记录

发布时间:2022-09-23 16:07:12 所属栏目:Linux 来源:
导读:  (一)Linux 系统目录结构

  登录系统后,在当前命令窗口下输入命令:ls /

  /bin:bin是Binary的缩写, 这个目录存放着最经常使用的命令。

  /boot:这里存放的是启动Linux时使用的一些核心文
  (一)Linux 系统目录结构
 
  登录系统后,在当前命令窗口下输入命令:ls /
 
  /bin:bin是Binary的缩写, 这个目录存放着最经常使用的命令。
 
  /boot:这里存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件。
 
  /dev :dev是Device(设备)的缩写, 该目录下存放的是Linux的外部设备,在Linux中访问设备的方式和访问文件的方式是相同的。
 
  /etc:这个目录用来存放所有的系统管理所需要的配置文件和子目录。
 
  /home:用户的主目录,在Linux中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。
 
  /lib:这个目录里存放着系统最基本的动态连接共享库,其作用类似于Windows里的DLL文件。几乎所有的应用程序都需要用到这些共享库。
 
  /lost+found:这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。
 
  /media:linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。
 
  /mnt:系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在/mnt/上,然后进入该目录就可以查看光驱里的内容了。
 
  /opt:这是给主机额外安装软件所摆放的目录。比如你安装一个ORACLE数据库则就可以放到这个目录下。默认是空的。
 
  /proc:这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。
 
  这个目录的内容不在硬盘上而是在内存里,我们也可以直接修改里面的某些文件,比如可以通过下面的命令来屏蔽主机的ping命令,
 
  使别人无法ping你的机器:echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all
 
  /root:该目录为系统管理员,也称作超级权限者的用户主目录。
 
  /sbin:s就是Super User的意思,这里存放的是系统管理员使用的系统管理程序。
 
  /selinux:这个目录是Redhat/CentOS所特有的目录,Selinux是一个安全机制,类似于windows的防火墙,但是这套机制比较复杂,这个目录就是存放selinux相关的文件的。
 
  /srv:该目录存放一些服务启动之后需要提取的数据。
 
  /sys:这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统 sysfs 。
 
  sysfs文件系统集成了下面3种文件系统的信息:针对进程信息的proc文件系统、针对设备的devfs文件系统以及针对伪终端的devpts文件系统。
 
  该文件系统是内核设备树的一个直观反映。当一个内核对象被创建的时候,对应的文件和目录也在内核对象子系统中被创建。
 
  /tmp:
 
  这个目录是用来存放一些临时文件的。
 
  /usr:
 
  这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于windows下的program files目录。
 
  /usr/bin:
 
  系统用户使用的应用程序。
 
  /usr/sbin:
 
  超级用户使用的比较高级的管理程序和系统守护程序。
 
  /usr/src:
 
  内核源代码默认的放置目录。
 
  /var:
 
  这个目录中存放着在不断扩充着的东西,我们习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件。
 
  /run:
 
  是一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删掉或清除。如果你的系统上有 /var/run 目录,应该让它指向 run。
 
  在 Linux 系统中,有几个目录是比较重要的,平时需要注意不要误删除或者随意更改内部文件。
 
  /etc: 上边也提到了,这个是系统中的配置文件,如果你更改了该目录下的某个文件可能会导致系统不能启动。
 
  /bin, /sbin, /usr/bin, /usr/sbin: 这是系统预设的执行文件的放置目录,比如 ls 就是在/bin/ls 目录下的。
 
  值得提出的是,/bin, /usr/bin 是给系统用户使用的指令(除root外的通用户),而/sbin, /usr/sbin 则是给root使用的指令。
 
  /var: 这是一个非常重要的目录,系统上跑了很多程序,那么每个程序都会有相应的日志产生,而这些日志就被记录到这个目录下,具体在/var/log 目录下,另外mail的预设放置也是在这里。
 
  (二)Linux 文件基本属性
 
  在Linux中我们可以使用ll或者ls –l命令来显示一个文件的属性以及文件所属的用户和组,如:# ls -l
 
  当为[ d ]则是目录
 
  当为[ - ]则是文件;
 
  若是[ l ]则表示为链接文档(link file);
 
  若是[ b ]则表示为装置文件里面的可供储存的接口设备(可随机存取装置);
 
  若是[ c ]则表示为装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)。
 
  接下来的字符中,以三个为一组,且均为『rwx』 的三个参数的组合。其中,[ r ]代表可读(read)、[ w ]代表可写(write)、[ x ]代表可执行(execute)。
 
  要注意的是,这三个权限的位置不会改变,如果没有权限,就会出现减号[ - ]。
 
  更改文件属性:
 
  1、chgrp:更改文件属组:chgrp [-R] 属组名 文件名
 
  -R:递归更改文件属组,就是在更改某个目录文件的属组时,如果加上-R的参数,那么该目录下的所有文件的属组都会更改。
 
  2、chown:更改文件属主,也可以同时更改文件属组
 
  语法:
 
  chown [–R] 属主名 文件名
 
  chown [-R] 属主名:属组名 文件名
 
  [zxh@localhost opt]$ ll
  总用量 0
  drwxr-xr-x. 2 root root 6 5月   3 01:21 module
  drwxr-xr-x. 2 root root 6 5月   3 01:21 software
  [zxh@localhost opt]$ sudo chown zxh:zxh module/ software/
  [zxh@localhost opt]$ ll
  总用量 0
  drwxr-xr-x. 2 zxh zxh 6 5月   3 01:21 module
  drwxr-xr-x. 2 zxh zxh 6 5月   3 01:21 software
  3、chmod:更改文件9个属性
 
  Linux文件属性有两种设置方法,一种是数字,一种是符号。
 
  Linux文件的基本权限就有九个Linux 文件基本属性,分别是owner/group/others三种身份各有自己的read/write/execute权限。
 
  文件的 权限字符为:『-rwxrwxrwx』, 这九个权限是三个三个一组的!其中,我们可以使用数字来代表各个权限,各权限的分数对照表如下:
 
  r:4:读权限:可以查看文件的内容,可以列出文件中的内容
 
  w:2 ;写权限:可以修改文件的内容,可以在目录中创建文件,删除文件
 
  x:1;执行权限,可以执行文件,可与进入目录
 
  每种身份(owner/group/others)各自的三个权限(r/w/x)分数是需要累加的,例如当权限为: [-rwxrwx---] 分数则是:
 
  owner = rwx = 4+2+1 = 7
 
  group = rwx = 4+2+1 = 7
 
  others= --- = 0+0+0 = 0
 
  该文件的权限数字就是770,变更权限的指令chmod的语法是这样的:
 
  chmod [-R] xyz 文件或目录
 
  选项与参数:
 
  xyz : 就是刚刚提到的数字类型的权限属性,为 rwx 属性数值的相加,写为。
 
  -R : 进行递归(recursive)的持续变更,亦即连同次目录下的所有文件都会变更
 
  举例来说,如果要将.bashrc这个文件所有的权限都设定启用,那么命令如下:
 
  [root@www ~]# ls -ll .bashrc
  -rw-r--r-- 1 root root 395 Jul 4 11:45 .bashrc
  [root@www ~]# chmod 777 .bashrc
  [root@www ~]# ls -al .bashrc
  -rwxrwxrwx 1 root root 395 Jul 4 11:45 .bashrc
  如果要将权限变成 -rwxr-xr-- 呢?那么权限的分数就成为 [4+2+1][4+0+1][4+0+0]=754。
 
  符号类型改变文件权限:
 
  基本上就九个权限分别是:(1)user; (2)group; (3)others ;由u, g, o来代表三种身份的权限!
 
  此外, a 则代表 all 亦即全部的身份!那么读写的权限就可以写成r, w, x!也就是可以使用底下的方式来看:
 
  chmod u g o a
 
  +(加入) -(除去) =(设定)
 
  r w x
 
  如果我们需要将文件权限设置为 -rwxr-xr-- ,可以使用 chmod u=rwx,g=rx,o=r 文件名 来设定:
 
  # touch test1 // 创建 test1 文件
  # ls -al test1 // 查看 test1 默认权限
  -rw-r--r-- 1 root root 0 Nov 15 10:32 test1
  # chmod u=rwx,g=rx,o=r test1 // 修改 test1 权限
  # ls -al test1
  -rwxr-xr-- 1 root root 0 Nov 15 10:32 test1 
  如果是要将权限去掉而不改变其他已存在的权限,例如拿掉全部人的可执行权限,则:
 
  # chmod a-x test1
  # ls -al test1
  -rw-r--r-- 1 root root 0 Nov 15 10:32 test1
  (三)Linux 文件与目录管理
 
  Linux的目录结构为树状结构,最顶级的目录为根目录 /。
 
  绝对路径:
 
  路径的写法,由根目录 / 写起,例如: /usr/share/doc 这个目录。
 
  相对路径:
 
  路径的写法,不是由 / 写起,例如由 /usr/share/doc 要到 /usr/share/man 底下时,可以写成: cd ../man
 
  处理目录的常用命令:
 
  ls: 列出目录
 
  cd:切换目录
 
  pwd:显示目前的目录
 
  mkdir:创建一个新的目录
 
  rmdir:删除一个空的目录
 
  cp: 复制文件或目录
 
  rm: 移除文件或目录
 
  mv: 移动文件与目录,或修改文件与目录的名称
 
  你可以使用 man [命令] 来查看各个命令的使用文档,如 :man cp。
 
  ls (列出目录)
 
  在Linux系统当中, ls 命令可能是最常被运行的。
 
  语法:
 
  [root@www ~]# ls [-aAdfFhilnrRSt] 目录名称
  [root@www ~]# ls [--color={never,auto,always}] 目录名称
  [root@www ~]# ls [--full-time] 目录名称
  [root@www ~]# ls -a1 ~
  选项与参数:
 
  -a :全部的文件,连同隐藏档( 开头为 . 的文件) 一起列出来(常用)
 
  -d :仅列出目录本身,而不是列出目录内的文件数据(常用)
 
  -l :长数据串列出,包含文件的属性与权限等等数据;(常用)
 
  将家目录下的所有文件列出来(含属性与隐藏档)
 
  cd (切换目录)
 
  cd是Change Directory的缩写,这是用来变换工作目录的命令。
 
  语法:
 
  cd [相对路径或绝对路径]
 
  #使用 mkdir 命令创建 runoob 目录
  [root@www ~]# mkdir runoob
  #使用绝对路径切换到 runoob 目录
  [root@www ~]# cd /root/runoob/
  #使用相对路径切换到 runoob 目录
  [root@www ~]# cd ./runoob/
  # 表示回到自己的家目录,亦即是 /root 这个目录
  [root@www runoob]# cd ~
 
  # 表示去到目前的上一级目录,亦即是 /root 的上一级目录的意思;
  [root@www ~]# cd ..
  mkdir (创建新目录:make directory)
 
  语法:
 
  mkdir [-mp] 目录名称
 
  选项与参数:
 
  -m :配置文件的权限,不需要看默认权限 (umask) 的脸色~
 
  -p :帮助你直接将所需要的目录(包含上一级目录)递归创建
 
  实例:
 
  [root@www ~]# cd /tmp
  [root@www tmp]# mkdir test    <==创建一名为 test 的新目录
  [root@www tmp]# mkdir test1/test2/test3/test4
  mkdir: cannot create directory `test1/test2/test3/test4':
  No such file or directory       <==报错: 没办法直接创建此目录
  [root@www tmp]# mkdir -p test1/test2/test3/test4
  加了这个 -p 的选项,可以自行帮你创建多层目录!
 
  实例:创建权限为 rwx--x--x 的目录。
 
  [root@www tmp]# mkdir -m 711 test2
  [root@www tmp]# ls -l
  drwxr-xr-x 3 root root 4096 Jul 18 12:50 test
  drwxr-xr-x 3 root root 4096 Jul 18 12:53 test1
  drwx--x--x 2 root root 4096 Jul 18 12:54 test2
  上面的权限部分,如果没有加上 -m 来强制配置属性,系统会使用默认属性。如果我们使用 -m ,如上例我们给予 -m 711 来给予新的目录 drwx--x--x 的权限。
 
  rmdir (删除空的目录)
 
  语法:
 
  rmdir [-p] 目录名称
 
  选项与参数:
 
  -p :连同上一级『空的』目录也一起删除
 
  [root@www tmp]# ls -l <==看看有多少目录存在?
  drwxr-xr-x 3 root root 4096 Jul 18 12:50 test
  drwxr-xr-x 3 root root 4096 Jul 18 12:53 test1
  drwx--x--x 2 root root 4096 Jul 18 12:54 test2
  [root@www tmp]# rmdir test <==可直接删除掉,没问题
  [root@www tmp]# rmdir test1 <==因为尚有内容,所以无法删除!
  rmdir: `test1': Directory not empty
  [root@www tmp]# rmdir -p test1/test2/test3/test4
  [root@www tmp]# ls -l <==您看看,底下的输出中test与test1不见了!
  drwx--x--x 2 root root 4096 Jul 18 12:54 test2
  利用 -p 这个选项,立刻就可以将 test1/test2/test3/test4 一次删除。
 
  不过要注意的是,这个 rmdir 仅能删除空的目录,你可以使用 rm 命令来删除非空目录。
 
  cp (复制文件或目录)
 
  语法:
 
  [root@www ~]# cp [-adfilprsu] 来源档(source) 目标档(destination)
 
  [root@www ~]# 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
 
  [root@www ~]# cp ~/.bashrc /tmp/bashrc
  [root@www ~]# cp -i ~/.bashrc /tmp/bashrc
  cp: overwrite `/tmp/bashrc'? n
 

(编辑:百科站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!