如何解决 fs.renameSync() 跨区移动文件的问题

简介: 问题上一篇文章,我们介绍了 fs.renameSync 方法的两种报错类型,也分别介绍了解决方法。其实在解决 fs.renameSync 跨区移动文件时,也有别的解决方法,下面我们就来一起看一看。解决今天介绍解决 fs.renameSync 跨区移动文件报错的问题,一种有两种方法,接下来分别介绍。

目录

  • 问题
  • 解决
  • 方法一、createReadStream 和 createWriteStream
  • 方法二、mv
  • 结尾

问题

上一篇文章,我们介绍了 fs.renameSync 方法的两种报错类型,也分别介绍了解决方法。其实在解决 fs.renameSync 跨区移动文件时,也有别的解决方法,下面我们就来一起看一看。

解决

今天介绍解决 fs.renameSync 跨区移动文件报错的问题,一种有两种方法,接下来分别介绍。

方法一、createReadStream 和 createWriteStream

可以先使用 fs 库的 createReadStream 方法打开并读取源文件内容,同时创建读取流,然后使用 fs 库的 createWriteStream 方法创建目标文件同时打开写入流。之后利用管道方法 pipe,建立二者的关系。最后,监听读取流的结束事件,当事件触发时删除源文件。

下面是整个过程的代码实例,请参考:

varfs=require('fs');
varis=fs.createReadStream('/a/b/source/file');
varos=fs.createWriteStream('/c/d/destination/file');
is.pipe(os);
is.on('end',function() {
fs.unlinkSync('source_file');
 });

方法二、mv

现在,我们来介绍第二种方法。这次不使用 fs 系统库,而是使用了第三库 mv。

使用之前,首先需要安装,命令如下:

npm i mv

然后是引入库,代码如下:

var mv = require('mv');

mv 方法可以只有两个参数,第一个参数是源文件的地址,第二个参数是目标文件的地址。其实,这是 mv 方法的默认使用方式,原理上是首先使用系统的 fs.rename 方法,如果有问题,就会回退上面介绍的第一种方法。具体的使用实例代码如下:

mv('/a/b/source/file', '/c/d/destination/file', function(err) {
// done. it tried fs.rename first, and then falls back to// piping the source file to the dest file and then unlinking// the source file.});

当然,我们也可以显示的启动 mv 方法的第三个参数,主动设置一些策略,比如下面的方法,就是首先创建所有需要的目录,再进行上面的逻辑。代码参考如下:

mv('/a/b/source/file', '/c/d/destination/file', {mkdirp: true}, function(err) {
// done. it first created all the necessary directories, and then// tried fs.rename, then falls back to using ncp to copy the dir// to dest and then rimraf to remove the source dir});

结尾

好了,两种解决跨区域移动文件的方法就介绍完了。感兴趣的小伙伴,不妨自己动手试试。常言道:实践出真知,古人诚不欺我!



作者简介:大家好,我是 liuzhen007,是一位音视频技术爱好者,同时也是CSDN博客专家、华为云享专家(共创编辑)、InfoQ 签约作者,欢迎关注我分享更多干货!

目录
相关文章
|
Linux
生产环境Linux服务器磁盘分区、无损扩容根分区以及挂载磁盘到目录实战
生产环境Linux服务器磁盘分区、无损扩容根分区以及挂载磁盘到目录实战
479 0
|
3月前
|
存储 机器学习/深度学习 缓存
Hadoop-07-HDFS集群 基础知识 分布式文件系统 读写原理 读流程与写流程 基本语法上传下载拷贝移动文件
Hadoop-07-HDFS集群 基础知识 分布式文件系统 读写原理 读流程与写流程 基本语法上传下载拷贝移动文件
65 1
|
3月前
|
存储 Unix 数据挖掘
服务器数据恢复—SAN LUN映射出错导致文件系统共享冲突的数据恢复案例
服务器数据恢复环境: SAN光纤网络环境,存储由一组6块硬盘组建的RAID6阵列构成,划分为若干LUN,MAP到跑不同业务的SUN SOLARIS操作系统服务器上。 服务器故障&分析: 因为业务需要,用户在该光纤存储环境中新增一台SUN SOLARIS操作系统服务器。将存储中的某个LUN映射到新增的服务器上,但是映射的这个卷之前已经MAP到SOLARIS生产系统上的某个LUN上了。因为未及时察觉这个问题,新增服务器已经对该LUN进行部分初始化操作。 在SOLARIS操作系统层面磁盘报错,重启后卷无法挂载。联系SUN工程师检测后,执行了fsck操作。操作完成后虽然文件系统可以挂上,但是发现大量
|
4月前
|
存储 Unix 数据挖掘
服务器数据恢复—SAN环境下LUN Mapping出错导致文件系统共享冲突的数据恢复案例
服务器数据恢复环境: SAN环境下一台存储设备中有一组由6块硬盘组建的RAID6磁盘阵列,划分若干LUN,MAP到不同业务的SOLARIS操作系统服务器上。 服务器故障: 用户新增了一台服务器,将存储中的某个LUN映射到新增加的这台服务器上。这个映射的LUN其实之前已经MAP到其他SOLARIS操作系统的服务器上了。由于没有及时发现问题,新增加的这台服务器已经对此LUN做了初始化操作,磁盘报错,重启后发现卷无法挂载。
|
5月前
|
存储 Unix 数据挖掘
服务器数据恢复—SAN环境下LUN Mapping出错导致文件系统一致性出错的数据恢复案例
服务器存储数据恢复环境: 一台存储中有一组由6块硬盘组成的RAID6,划分为若干LUN,MAP到不同业务的SOLARIS操作系统服务器上。 服务器存储故障: 由于业务变化需要增加一台服务器,在存储在线的状态下将该存储中的某个LUN映射到这台新增加的服务器上并开始初始化,不料映射的这个LUN已经MAP到其他SOLARIS服务器上了。由于该LUN已经进行了部分的初始化,磁盘报错,重启后发现卷无法挂载。
|
8月前
打不开磁盘xxx.vmdk或它所依赖的某个快照磁盘
打不开磁盘xxx.vmdk或它所依赖的某个快照磁盘
293 0
|
8月前
|
存储 分布式计算 Hadoop
HDFS如何处理大文件和小文件的存储和访问?
HDFS如何处理大文件和小文件的存储和访问?
184 0
经验分享:u盘文件或者目录损坏无法读取、无法正常打开,如何解决?
u盘突然无法正常打开,显示目录损坏。。。 找寻了网上众多方法。以下是解决方案 win+R 打开后输入cmd之后输入:chkdsk +你要修复的u盘+/F
经验分享:u盘文件或者目录损坏无法读取、无法正常打开,如何解决?
FAT文件系统几点释疑
下面几点疑问其实就是我的疑问,不敢说我的理解是正确的,但最起码比以前的理解更接近真相
579 0