- 一、系统目录结构
- 二、文件基本属性
- 1、查看文件
- ls(列出文件或目录)
- 2、文件基本属性
- 3、更改文件属性
- chgrp(修改所属用户与组)
- chown(更改文件属主)
- chmod(修改用户的权限)
- 三、文件与目录管理
- 1、处理目录的常用命令
- cd (切换目录)
- pwd (显示目前所在的目录)
- mkdir (创建新目录)
- rmdir (删除空的目录)
- cp (复制文件或目录)
- rm (移除文件或目录)
- mv (移动文件与目录,或修改名称)
- 2、Linux 文件内容查看
登录系统后,在当前命令窗口下输入命令:
ls /
你会看到如下图所示:
树状目录结构:
/bin
bin 是 Binaries (二进制文件) 的缩写, 这个目录存放着最经常使用的命令。
/boot
这里存放的是启动 Linux 时使用的一些核心文件,包括一些连接文件以及镜像文件。
/dev
dev 是 Device(设备) 的缩写, 该目录下存放的是 Linux 的外部设备,在 Linux 中访问设备的方式和访问文件的方式是相同的。
/etc
etc 是 Etcetera(等等) 的缩写,这个目录用来存放所有的系统管理所需要的配置文件和子目录。
/home
用户的主目录,在 Linux 中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的,如上图中的 alice、bob 和 eve。
/lib
lib 是 Library(库) 的缩写这个目录里存放着系统最基本的动态连接共享库,其作用类似于 Windows 里的 DLL 文件。几乎所有的应用程序都需要用到这些共享库。
/lost+found
这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。
/media
linux 系统会自动识别一些设备,例如U盘、光驱等等,当识别后,Linux 会把识别的设备挂载到这个目录下。
/mnt
系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在 /mnt/ 上,然后进入该目录就可以查看光驱里的内容了。
/opt
opt 是 optional(可选) 的缩写,这是给主机额外安装软件所摆放的目录。比如你安装一个ORACLE数据库则就可以放到这个目录下。默认是空的。
/proc
proc 是 Processes(进程) 的缩写,/proc 是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。
这个目录的内容不在硬盘上而是在内存里,我们也可以直接修改里面的某些文件,比如可以通过下面的命令来屏蔽主机的ping命令,使别人无法ping你的机器:
echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all
/root
该目录为系统管理员,也称作超级权限者的用户主目录。
/sbin
s 就是 Super User 的意思,是 Superuser Binaries (超级用户的二进制文件) 的缩写,这里存放的是系统管理员使用的系统管理程序。
/selinux
这个目录是 Redhat/CentOS 所特有的目录,Selinux 是一个安全机制,类似于 windows 的防火墙,但是这套机制比较复杂,这个目录就是存放selinux相关的文件的。
/srv
该目录存放一些服务启动之后需要提取的数据。
/sys
这是 Linux2.6 内核的一个很大的变化。该目录下安装了 2.6 内核中新出现的一个文件系统 sysfs 。
sysfs 文件系统集成了下面3种文件系统的信息:针对进程信息的 proc 文件系统、针对设备的 devfs 文件系统以及针对伪终端的 devpts 文件系统。
该文件系统是内核设备树的一个直观反映。
当一个内核对象被创建的时候,对应的文件和目录也在内核对象子系统中被创建。
/tmp
tmp 是 temporary(临时) 的缩写这个目录是用来存放一些临时文件的。
/usr
usr 是 unix shared resources(共享资源) 的缩写,这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于 windows 下的 program files 目录。
/usr/bin
系统用户使用的应用程序。
/usr/src
超级用户使用的比较高级的管理程序和系统守护程序。
/var
var 是 variable(变量) 的缩写,这个目录中存放着在不断扩充着的东西,我们习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件。
/run
是一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删掉或清除。如果你的系统上有 /var/run 目录,应该让它指向 run。
二、文件基本属性 1、查看文件 ls(列出文件或目录)在linux中,我们使用ls
(list files)列出文件或目录
ls [-aAdfFhilnrRSt] 目录名称
选项与参数
-a
:全部的文件,连同隐藏文件( 开头为 . 的文件) 一起列出来(常用)-l
:长数据串列出,包含文件的属性与权限等等数据;(常用)
将目录下的所有文件列出来(含属性与隐藏档)
ls -al ~
2、文件基本属性
在 Linux 中我们可以使用 ll
或者 ls –l
命令来显示一个文件的属性以及文件所属的用户和组,如:
(1) file type
的类别有
- 若为
d
则是目录 - 若为
-
则是文件; - 若是
l
则表示为链接文档(link file); - 若是
b
则表示为装置文件里面的可供储存的接口设备(可随机存取装置); - 若是
c
则表示为装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)。
(2) 权限列表
- 第 1-3 位为属主(该文件的所有者)拥有该文件的权限。
- 第4-6位为属组(所有者的同组用户)拥有该文件的权限。
- 第7-9位为其他用户拥有该文件的权限。
修改所属用户与组。
chgrp [-R] 属组名 文件名
参数选项
-R
:递归更改文件属组,就是在更改某个目录文件的属组时,如果加上-R的参数,那么该目录下的所有文件的属组都会更改。
chown
(change owner):更改文件属主,也可以同时更改文件属组
chown [–R] 属主名 文件名
chown [-R] 属主名:属组名 文件名
示例:
进入 /root 目录(~)将install.log的拥有者改为bin这个账号:
[root@www ~] cd ~
[root@www ~] chown bin install.log
[root@www ~] ls -l
-rw-r--r-- 1 bin users 68495 Jun 25 08:53 install.log
将install.log的拥有者与群组改回为root:
[root@www ~] chown root:root install.log
[root@www ~] ls -l
-rw-r--r-- 1 root root 68495 Jun 25 08:53 install.log
chmod(修改用户的权限)
chmod
(change mode) : 修改用户的权限(9个属性)。
Linux文件属性有两种设置方法,一种是数字,一种是符号。
(1)数字
我们可以使用数字来代表各个权限,各权限的分数对照表如下:
r
:4w
:2x
: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 -al .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
(2)符号
我们使用u
, g
, o
和a
来分别代表用户
、组
、其他
和全部
的身份,读写的权限可以写成 r
, w
, x
,也就是可以使用下表的方式来看:
示例:
[root@www ~] touch test1 // 创建 test1 文件
[root@www ~] ls -al test1 // 查看 test1 默认权限
-rw-r--r-- 1 root root 0 Nov 15 10:32 test1
[root@www ~] chmod u=rwx,g=rx,o=r test1 // 修改 test1 权限
[root@www ~] ls -al test1
-rwxr-xr-- 1 root root 0 Nov 15 10:32 test1
如果是要将权限去掉而不改变其他已存在的权限呢?例如要拿掉全部人的可执行权限,则:
[root@www ~] chmod a-x test1
[root@www ~] ls -al test1
-rw-r--r-- 1 root root 0 Nov 15 10:32 test1
三、文件与目录管理
-
绝对路径:
路径的写法,由根目录/
写起,例如:/usr/share/doc
这个目录。 -
相对路径:
路径的写法,不是由/
写起,例如由/usr/share/doc
要到/usr/share/man
底下时,可以写成:cd ../man
这就是相对路径的写法
cd
是Change Directory的缩写,这是用来变换工作目录的命令。
cd [相对路径或绝对路径]
示例:
# 表示回到自己的家目录,亦即是 /root 这个目录
[root@www runoob] cd ~
# 表示去到目前的上一级目录,亦即是 /root 的上一级目录的意思;
[root@www ~] cd ..
pwd (显示目前所在的目录)
pwd
是 Print Working Directory 的缩写,也就是显示目前所在目录的命令。
pwd [-P]
选项与参数:
-P
:显示出确实的路径,而非使用连结 (link) 路径。
如果想要创建新的目录的话,那么就使用mkdir (make directory)吧。
mkdir [-mp] 目录名称
选项与参数:
-m
:配置文件的权限喔!直接配置,不需要看默认权限 (umask) 的脸色~-p
:帮助你直接将所需要的目录(包含上一级目录)递归创建起来!
示例1:-m
创建权限为 rwx–x–x 的目录
[root@www tmp] mkdir -m 711 test2
[root@www tmp] ls -l
drwx--x--x 2 root root 4096 Jul 18 12:54 test2
示例2:-p
创建多级目录(直接使用mkdir
只能创建单个目录)
[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
rmdir (删除空的目录)
rmdir [-p] 目录名称
选项与参数:
-p
:从该目录起,一次删除多级空目录
注意:rmdir 仅能删除空的目录,你可以使用 rm 命令来删除非空目录。
cp (复制文件或目录)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
[root@www ~] cp ~/.bashrc /tmp/bashrc
[root@www ~] cp -i ~/.bashrc /tmp/bashrc
cp: overwrite `/tmp/bashrc'? n <==n不覆盖,y为覆盖
rm (移除文件或目录)
rm [-fir] 文件或目录
选项与参数:
-f
:就是 force 的意思,忽略不存在的文件,不会出现警告信息;-i
:互动模式,在删除前会询问使用者是否动作(加上就会主动询问喔,避免删除到错误的档名!)-r
:递归删除啊!最常用在目录的删除了!这是非常危险的选项!!!
mv [-fiu] source destination
mv [options] source1 source2 source3 .... directory
选项与参数:
-f
:force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖;-i
:若目标文件 (destination) 已经存在时,就会询问是否覆盖!-u
:若目标文件已经存在,且 source 比较新,才会升级 (update)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)