linux上的链接
linux上的软链接与硬连接
前言
按照计划我应当更新绕过NX的一些攻击方式,但是我觉得既然讲了绑定,那就顺便来讲讲有关于链接的话题吧。
linux内部文件管理
在现代操作系统中,文件的意义是使信息独立于进程长期存在。而为了方便文件被多个进程相互独立的调用,linux系统设置了一组通用的api来对文件或其他被看作文件的东西进行操作。也就是说linux把所有除了进程以外的东西全部当成文件。
文件的操作是通过所谓的字节流来进行。而上文提到的通用的api就是来管理与操作这些字节流的,最常见自然是对文件或者屏幕(终端的用户输入)进行管理的api。并且,为了方便进行管理这些文件,linux使用了文件夹这一系统。
在linus写linux的最初版本时文件夹还不是一项必须要实现的功能,例如大名鼎鼎的unix系统就不能实现这个功能。
如果有细心的朋友在根目录下ls -a
,就会发现有很多文件夹
/ 根目录
├── bin 存放用户二进制文件
├── boot 存放内核引导配置文件
├── dev 存放设备文件
├── etc 存放系统配置文件
├── home 用户主目录
├── lib 动态共享库
├── lost+found 文件系统恢复时的恢复文件
├── media 可卸载存储介质挂载点
├── mnt 文件系统临时挂载点
├── opt 附加的应用程序包
├── proc 系统内存的映射目录,提供内核与进程信息
├── root root 用户主目录
├── sbin 存放系统二进制文件
├── srv 存放服务相关数据
├── sys sys 虚拟文件系统挂载点
├── tmp 存放临时文件
├── usr 存放用户应用程序
└── var 存放邮件、系统日志等变化文件
其中的home文件夹就是我们平常所使用的最多的文件夹。
笔者认为Linux在系统文件的隐藏,这一方面做的比windows高得多。虽然windows的文件夹目录更为直观,但是同时也产生了用户很容误删这些关键的系统文件的问题。
当然windows其它方面的易用性与生态会把linux秒成渣。
但这又有什么用呢,服务器是linux的,你还不是老老实实得需要用linux做pwn题
需要注意的是因为万物皆为文件的设计,所以linux中的文件夹并非与windows一样,是一个高于普通文件的顶层设计的产物,而是一种特殊的文件。
使用命令 mkdir
创建目录时,若期望创建的目录的名称与现有的文件名(或目录名)重复,则会创建失败。
Linux 将设备当做文件进行处理下面这段终端记录展示了如何打开设备文件 /dev/input/event5 并读取文件内容。文件 event5 表示一种输入设备,其可能是鼠标或键盘等。查看文件 /proc/bus/input/devices 可知 event5 对应设备的类型。设备文件 /dev/input/event5 使用 read() 以字符流的方式被读取。结构体 input_event 被定义在内核头文件 linux/input.h 中。
int fd;
struct input_event ie;
fd = open("/dev/input/event5", O_RDONLY);
read(fd, &ie, sizeof(struct input_event));
printf("type = %d code = %d value = %d\n",
ie.type, ie.code, ie.value);
close(fd);
从这里可以看出设备可以作为文件来进行读写。
硬链接与软链接
虽然文件这一数据结构的作用是存放数据,但是显然,它也存放了一些与这些数据相关的另一些数据,例如创建时间,文件名等信息。
插一些题文无关的内容,文件并不以文件名来作为系统中的唯一标识,而将文件的 inode 号作为文件的唯一标识。就和windwos系统中不以进程名而已句柄来分辨进程其实是一个道理。
一般来说将我们将这两种数据称作
- 用户数据
- 元数据
需要注意的是,进程对于文件其实是非独占的。换言之,多个进程可以使用同一个文件。文件的共享是一个难题。可以想象,如果说没有限制的使用同一个文件会导致读取方面产生多大的问题。
为解决文件的共享使用,Linux 系统引入了两种链接:硬链接 (hard link) 与 软链接(又称符号链接,即 soft link 或 symbolic link)。
链接的作用有
- 解决了文件的共享使用
- 隐藏文件路径
- 增加权限安全
- 节省存储空间
- ...
上文也提到了linux系统下有文件夹这一个架构,那么如果我们需要在不同的文件下同时保留一个文件,我们当然可以简单的直接拷贝一份,但是这样浪费了大量的空间,而且在程序真正需要去改变文件的数据时会导致多个文件的数据不同步,丢失了我们复制一份的初衷。
我们需要一种结构,在改变它的数据时同时会改变原始的数据,而且占用空间小。
最优的解决方案就是:
- 只有一个真实存在的文件
- 在其他文件夹下存放的数据其实只是这个文件的别名。
这就是 硬链接 ,硬链接就是一个文件的不同的文件名。可以为一个inode号创建不同的文件名,而这些文件名可以和现实中存在文件一样被程序读写。私以为它和c++的指针特别像
当然我们也可以创建和windows中快捷方式一样的东西,这就是 软链接 。软链接是现实中存在的文件,它也有着所谓的元数据与用户数据。但是它的数据块有着些许不同,它存放的是另一个文件的地址。
连接的创建
硬链接
硬链接可以用以下指令来创建
link oldfile newfile
ln oldfile newfile
此外需要注意,不要向目录创建硬链接
但是有以下注意事项
- 文件有相同的 inode 及 data block;
- 只能对已存在的文件进行创建;
- 不能交叉文件系统进行硬链接的创建;
- 不能对目录进行创建,只可对文件创建;
- 删除一个硬链接文件并不影响其他有相同 inode 号的文件。
软链接
硬链接可以用以下指令来创建
link -s oldfile newfile
ln -s oldfile newfile
此外
- 软链接有自己的文件属性及权限等;
- 可对不存在的文件或目录创建软链接;
- 软链接可交叉文件系统;
- 软链接可对文件或目录创建;
- 创建软链接时,链接计数 i_nlink 不会增加;
- 删除软链接并不影响被指向的文件,但若被指向的原文件被删除,则相关软连接被称为死链接(即 dangling link,若被指向路径文件被重新创建,死链接可恢复为正常的软链接)
删除
rm
,没啥好说的。
后记
文章拖了好久了,以后还是要多加努力。