前言

最近不是redis 6.0 出了吗,官网介绍最新稳定版本是 6.0.3 。于是,我就准备在自己的破小服务器上安装一下。于是,出现了后续的糟心事 (linux 下的文件正常删除不了)。

下载了最新版本,在源码包里边 make 之后,出现了好几个错误,上网查了下,有人说最新版本有问题,建议使用 5.0.8 。我嘞个去,我想也没想就相信了。(其实,也有可能跟我的系统没安装 tcl 有关系,这就是后话了)

然后,我就下载了 5.0.8 版本的redis,重新安装。

发现问题

从官网下载了 5.0.8 的源码包之后,就从我本地(win系统)通过 scp 命令上传到服务器。如下,

由于源码包下载到了桌面位置,因此本地路径的地址就写的绝对路径 “C:\ ...” ,上传到远程服务器的 /root 目录下。谁成想到了服务器上的文件名是这个样子。如下,

文件名竟然把本地文件的路径也带上了。这就让人很头疼了,我想着,就把它重新命名一下吧。

这么长的文件名,我肯定复制粘贴啊。但是粘贴之后发现 linux 下把前边当成一个路径来解析了,按照的是 linux 下文件夹的路径格式(windows的文件分隔符为反斜杠"\",linux下为"/"),如下,

很明显,在linux下默认是没有根路径为 "/c" 这样的路径的。因此,就报错没有找到该目录。

这就让人很 dan 疼了,重命名不行,那就尝试下删除吧,大不了我重新上传文件就是了。

但是,结果也并不如我所愿, 执行删除命令之后,文件还在,

原因,我猜测也是和重命名一样,linux 把文件名解析为路径了。然后看到网上说,给文件名加引号可以避免这种情况,我就操作了一番,并刻意地手打原文件的名字。(原为反斜杠)

然而并没有什么用,怎样都绕不过它把这个文件名当成路径来解析。。。

解决问题

后来,还是群里的小伙伴给我的解决方案,真是 tql 。遂记录如下,

解决链接:https://www.askcto.com/searchInfo?qId=7056cab522d84d0eb9c1a36eba66b324

思路就是,通过文件索引节点号来删除,绕过文件名。先通过 ls -i,显示所有文件索引节点号(如下,目标文件的索引节点号为 477536),然后通过索引节点号来删除文件。

文件索引节点号

那么,有的童鞋就会问了,什么是文件索引节点号呢?

在这之前需要了解一下 linux 中文件的存储形式,以及文件索引节点。

在 linux 下,文件在磁盘上的存储是以“块”为单位的,“块”是文件的最小存储单元。每个块又包含多个扇区,每个扇区大小为 512 字节。通常 8 个扇区组成一个“块”。

由于文件的数据都存储在“块”中,因此我们还需要找到一块区域来保存文件的元信息,包括文件的权限,拥有者,大小,以及存储的位置。而这样的区域就叫做文件索引节点(inode)

元信息可以理解为是用来保存文件相关信息的信息。可以拿 Java 中的元注解来类比(元注解就是用来标注注解的注解)。

每个 inode 都有一个号码,这个就叫做文件索引节点号。操作系统最终是通过文件索引节点号来识别不同的文件的,而不是通过文件名。

如下图,可以通过 stat 命令打印出一个文件(以 TankServer.zip为例)的 inode 所有元信息,还有 inode 号。

文件名和文件索引节点号之间的关系,有点类似于域名和 IP 之间的映射关系。

比如访问百度,我们只会记得它的域名为"www.baidu.com",并不会去记它的 IP 地址是多少,而且 IP 对我们来说也不好记。这就好比,我们程序员只用记文件名,而不知道它的文件索引节点号一样。

但是实际上,最终还是需要域名解析器 DNS 把域名解析为具体的 IP 地址(此处不考虑CDN),才能让其他服务器识别。这就好比,linux 系统最终只会通过文件索引节点号来识别文件。

说了这么多,其实我们只是想知道当前需要删除文件的文件索引节点号而已。既然不能通过文件名删除,我直接越过你,找到对应的文件索引节点号不就可以了(相当于,我如果知道百度的 IP 地址,可以直接通过 IP 访问)。

PS:更多关于 inode 的介绍,可以参考阮一峰老师的博客:http://www.ruanyifeng.com/blog/2011/12/inode.html

删除命令

那么知道了文件索引节点号,我们就可以通过以下的格式来删除它对应的文件。

find ./ -inum inode号 -exec rm {} \;

前半部分,find 命令是在当前目录下找到 inode 号对应的文件。后半部分 -exec 表示查找后紧跟着要执行的命令。rm 就是删除文件的命令。删除哪个文件呢,{} 作用就是把 find 的结果作为参数传给 -exec 。

最后还要注意, 使用 -exec 参数,需要用 ; 分号结尾,不然会报错如下图。 而 "\"反斜杠是为了转义分号。

结语

以上就是在 linux 中删除文件时遇到的坑。若你遇到类似的问题,或者出现了某个文件名中有特殊字符导致删除不了文件,也可以尝试一下以上的操作方式哦。

温馨提示: 删除文件时,一定要小心哦,别最后删库跑路了!

我刚才测试时,就在 inum 前少加了横杠 (正确应该为 -inum)。导致整个命令删除了其它目录文件,如下图。

幸好这是个目录文件,也幸好我没用 rm -rf 递归删除文件,要不然,这个文件夹就废了。下边继续执行下去,还要删除 npm,天知道最后会不会把系统文件也删了。

幸好我手快,及时 Ctrl + C 了(单身二十多年的手速可不是白练的~)。

若本文对你有用,欢迎关注我,给我点赞哦 ~

linux连个文件都删除不了,什么鬼!的更多相关文章

  1. 解决Linux用户模板文件被删除后显示不正常问题

    缺失用户模板文件(用户骨架文件)会导致shell提示符不完整,可以到/etc/skel/目录下复制相关文件来恢复 (1).创建测试环境,删除模板文件 [root@xuexi ~]# useradd t ...

  2. Linux下的文件与目录权限

    一.用户(User).群组(Group)和其他人(Others) linux是多用户多任务的操作系统,同一时刻可能会有多个用户登录系统,考虑到文件的安全性等问题,所以Linux下的文件都属于一个特定的 ...

  3. linux下的文件类型

    在Linux中一切设备皆文件,首先来看一下Linux下的文件都有哪些分类,也就是文件类型 文件类型:普通文件(包括shell脚本,文档,音频,视频).目录文件.设备文件(又细分为字符设备文件和块设备文 ...

  4. java使用Jsch实现远程操作linux服务器进行文件上传、下载,删除和显示目录信息

    1.java使用Jsch实现远程操作linux服务器进行文件上传.下载,删除和显示目录信息. 参考链接:https://www.cnblogs.com/longyg/archive/2012/06/2 ...

  5. Linux下通过 rm -f 删除大量文件时报错:Argument list too long

    Linux下通过 rm -f 删除大量的小文件时出现类似如下错误信息:  -bash: /bin/rm: Argument list too long 如下图所示: 问题原因 如果待删除文件中包含的小 ...

  6. 深入理解linux关闭文件和删除文件

    背景介绍 最近看了linux系统编程(linux system programming)一书,结合深入理解linux内核(understanding the linux kernel)一书,深入理解了 ...

  7. 学习Linux二(创建、删除文件和文件夹命令)

     转自:http://www.cnblogs.com/zf2011/archive/2011/05/17/2049155.html 今天学习了几个命令,是创建.删除文件和文件夹的,在linux里,文件 ...

  8. Linux下tmp文件夹的文件自动删除的问题(转)

    场景: 近日发现有一台机器tmp文件夹下放置的文件无辜丢失,而且排查发现是自动丢失,并且,只是删除10天之前的文件. 本来以为是哪位写了一个自动执行脚本, find了一下10天前的文件删除了. 结果, ...

  9. Linux操作系统启动故障排错之"/etc/fstab"文件被删除恢复案例

    Linux操作系统启动故障排错之"/etc/fstab"文件被删除恢复案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.模拟故障 [root@yinzhe ...

随机推荐

  1. Linked List-1

    链表一直是面试的重点问题,恰好最近看到了Stanford的一篇材料,涵盖了链表的基础知识以及派生的各种问题. 第一篇主要是关于链表的基础知识. 一.基本结构 1.数组回顾 链表和数组都是用来存储一堆数 ...

  2. POJ - 3278 Catch That Cow 简单搜索

    Farmer John has been informed of the location of a fugitive cow and wants to catch her immediately. ...

  3. 2019 ICPC 银川网络赛 D. Take Your Seat (疯子坐飞机问题)

    Duha decided to have a trip to Singapore by plane. The airplane had nn seats numbered from 11 to nn, ...

  4. AWVS 安全渗透扫描

    1.打开软件,点击 New Scan 2.在 website url 中输入被扫描的网址,点击 next 3.在 scanning profile 中选择测试的漏洞类型,默认选择 default(默认 ...

  5. libevent(八)激活事件

    激活事件添加流程 事件发生后,需要把对应的event加入到激活事件队列中. 整个流程如下: 对于定时器事件,在timeout_process过程中,会将事件从最小堆中删除. 激活事件处理流程 在eve ...

  6. 网络流最小割 H - Internship I - Friendship

    我觉得这两个最小割都还比较难. 第一个题目大意是给你一个网络,这个网络是由城市和中转站组成,终点是0,给你每一条边的流量, 问,从城市到终点最大流流完之后,是否可以增加一条路上的一条边的容量,使得最大 ...

  7. P4016 负载平衡问题 网络流重温

    P4016 负载平衡问题 这个题目现在第二次做,感觉没有这么简单,可能是我太久没有写这种题目了,基本上都忘记了,所以我连这个是费用流都没有看出来. 有点小伤心,知道是费用流之后,我居然还拆点了. 这个 ...

  8. linux的用户管理、组管理

    用户管理:centos系统是一个多用户系统 用户分为三类: 超级用户(root) 用户id为 0 伪用户 用户id为1-499,虽然存在,但是不能用户登录 普通用户 用户id为500-60000 用户 ...

  9. Spring杂谈 | Spring中的AutowireCandidateResolver

    接口定义 用于推断一个特定的beanDefinition是否能作为指定依赖的候选者的策略接口 public interface AutowireCandidateResolver { // 默认情况下 ...

  10. Spring Cloud feign GET请求无法用实体传参的解决方法

    代码如下: @FeignClient(name = "eureka-client", fallbackFactory = FallBack.class, decode404 = t ...