标签:打开 alice pad 修改 例子 怎么 链接 三方 文件名
一个有趣的逻辑,把一个文件保存在两个地方,但只有一份, 或者说用两个不同的文件名保存一个文件,这种思想有些反人类,但这就是linux下的硬链接。
下面是见证奇迹的时刻,老陌认真的做了这个例子,一来是巩固一下之前学习的知识,二来体验一下硬链接。
故事是这样的……
某天一个帅哥(kevin),一个美女(alice)来找老陌,他们要共同编写一本小说,想让老陌在服务器上创建两个账号,他们谁有空闲时间就登录服务器进行编写。由于是共同合作编写,所以他们不想每写一点就通过email传来传去,之后拼接整理,很麻烦。 能不能有一种方法两个人在各自的目录里编写,但对方打开自己的文件之后却是更新的。
挺晕,因为老陌头一次接触,所以换个说法:
kevin在自己的家目录里创建了story目录,里面有一个小说叫九阳神帝。 这一天kevin心血来潮写下了一段,之后没词了,保存之后出去渡假了。
alice也在自己的家目录里创建了story目录,因为和kevin共同编写,所以alice的story目录里的小说也叫九阳神帝。在kevin渡假其间alice打开九阳神帝,发现开头已经写好了,于是继续写。
这一天alice打小怪兽去了,正好kevin回来,打开九阳神帝发现alice已经写好多了。于是kevin继续写……
现在老陌懂了,在不同目录里的两个文件,好像同一个文件一样,其中一人修改,另一端也发生变化。当然,这个思维很无聊,不要上纲上线,就是为了说明硬连接的问题。
在alice和kevin的不断请求下,老陌答应了。
老陌分析了一下需求,首先要添加两个用户,这还不简单,打开控制中心……
NO! No! 这样逼格太低了,怎么也得让老陌在帅哥,美女面前炫耀一翻。
#创建用户
sudo useradd -m -s /bin/bash kevin
sudo useradd -m -s /bin/bash alice
#设置密码
sudo passwd kevin
sudo passwd alice
因为两个不同的用户要共同访问同一个文件,根据前面学习的知识,应该在组或其它人的权限上下手。由于他们二人共同合作,不想让第三方人来破坏,所以老陌选择用共同组的方式来管理文件。
##创建组
sudo groupadd story
##把alice, kevin添加到组中
sudo usermod -a -G story kevin
sudo usermod -a -G story alice
kevin,alice各自登录构建自己的目录结构。
#切换用户
su - kevin
#创建目录
mkdir story
#修改story目录的组所有者为:story组,并设置组所有者的权限为:rwx
chgrp story story
chmod g=rwx story
#创建小说,修改小说的组所有者为story,并设置组所有者的权限为:rw-
touch story/九阳神帝
chgrp story story/九阳神帝
chmod g=rw- story/九阳神帝
#切换用户
su - alice
#创建目录
mkdir story
#修改story目录的组所有者为:story组,并设置组所有者的权限为:rwx
chgrp story story
chmod g=rwx story
目前alice并没有创建九阳神帝这个文件,因为需要把kevin的九阳神帝文件硬连接到alice的story目录中,硬连接之后表示这两个文件是同一个文件。
ln story/九阳神帝 /home/alice/story/九阳神帝
ln命令是创建链接的命令,比如快捷方式(软链接)就是通过这个命令创建的。类似于cp命令,把一个文件复制到另一个地方,但ln是在另一个地方创建的链接,而不是文件的副本。
这一天kevin心血来潮写下了一段,之后没词了,保存之后出去渡假了。
一阵剧痛,老陌醒来发现这是一个陌生的地方……
看看自己的双手满是鲜血,衣服和之前也不一样,莫非穿越了?
在kevin渡假其间alice打开九阳神帝,发现开头已经写好了,于是继续写……
见证奇迹的时刻来了:
alice登录之后发现九阳神帝中已经有写好的内容了。
当kevin创建/home/kevin/story/九阳神帝时,就包括了一个dentry,inode,data,当用ln命令创建一个硬连接后,该文件还是只有一个inode和data,但有两个dentry与之相连。
结构如下:
可以看出一个文件两个文件名。 此时用ls -l查看一下:
linux@ccloves:~$ ls -l /home/alice/story/九阳神帝
-rw-rw-r-- 2 kevin story 152 7月 17 08:35 /home/alice/story/九阳神帝
我们发现链接数是2,如果修改文件权限呢?看看另一端是不是发生变化:
首先查看两个文件的权限相同,之后给其他人一个w权限,再查看发现另一端也变化了,因为他们是同一个inode。
如果删除该文件是什么效果呢?
alice@ccloves:~/story$ rm 九阳神帝
alice@ccloves:~/story$ ls /home/kevin/story/
九阳神帝
alice删除了自己的九阳神帝,但我们发现kevin目录中的九阳神帝还存在。再查看一下链接点:
-rw-rw-rw- 1 kevin story 152 7月 17 08:35 九阳神帝
发现刚才是2,现在变成1了,可以看出rm删除文件时,并不是把数据清空,而是脱链,当inode连接数是0了,表示这个文件被删除了。
软链接就是一个快捷方式,有windows经验的人都能理解。软链接本身是一个文件,但这个文件不存放数据,存放一个链接,指向其它文件。
创建的方法和硬链接类似:
发现就是多了一个选项 -s 表示这是软链接。
通过 ls-l 我们发现软链接的文件类型是l,这说明软链接不是一个常规文件,而是一个符号链接文件。符号链接文件有自己的dentry,有自己的inode,但data域中存放的是另一个文件名,从而实现了链接。当linux访问符号链接文件时会自动解析目标文件。
软链接有几个硬连接不会出现的问题:
我们发现linux在尝试多层后,认为这是递归链接,警告退出。
硬链接 | 软链接 |
---|---|
目录之间不能用硬链接 | 软链接可以关联到目录 |
硬链接没有原始和复制的概念 | 软链接有引用和被引用的概念,删除目标则成为空链接 |
硬链接必须在同一个分区内 | 软链接可以在不同的分区进行链接 |
chroot的目录间可共享硬链接 | 软链接不能引用chroot目录外的文件 |
对于chroot这点老陌不懂,没有见过,先记下,等以后学到chroot再研究。
标签:打开 alice pad 修改 例子 怎么 链接 三方 文件名
原文地址:https://www.cnblogs.com/myccloves/p/9322739.html