之前写过一篇使用 rclone
挂载 Google Drive
的记录,这次来补上挂载 onedrive
的坑。挂载方法其实大同小异,网上也有许多文章进行介绍。
不过有些介绍实在是太简略了,甚至只是简单的复制了官方的示例,导致依旧看的一头雾水,所以我对 rclone
挂载 onedrive
的流程进行了整理和记录,希望能对大家有所帮助,能一次解决问题。
1. 创建 OneDrive API
为了实际使用中更稳定的体验,避免因为共享 API 达到使用限制而引发错误,绝对推荐创建自己的 API。
若要创建自己的 API,务必确保你的账号拥有 API 权限!
1.1 获取 client_id
首先访问 Microsoft Azure 应用注册,登录账号后点击应用注册
应用注册
点击左上角的新注册
新注册
如图所示进行配置,名称可以随便写,账户类型选择第三项
注册应用程序
点击注册后可以看到你的应用的相关信息,复制好 应用程序 (客户端) ID ,这个就是 client_id
获取 client_id
1.2 获取 client_secret
依次点击证书和密码,新客户端密码,在截止期限中将时间选择为最长(即两年)
创建新客户端密码
然后就可以看见值和机密 ID,我们只需要记录下 值 就可以,这个就是 client_secret 。
获取 client_secret
1.3 添加 API 权限
依次点击 API 权限,添加权限,Microsoft Graph,在右边栏搜索并添加权限。
Files.Read
,Files.ReadWrite
,Files.Read.All
,Files.ReadWrite.All
,offline_access
,User.Read
这几项
添加权限
添加完成后应该是这样
API 权限展示
1.4 添加身份验证
依次点击身份验证,添加平台,Web
添加身份验证, 在重定向 URI 中输入
http://localhost
设置重定向
至此,OneDrive API 创建完成
2. 添加 rclone 配置
注:由于 OneDrive 的授权 key 可能会很长导致 rclone 远程配置中无法接受 key,目前 rclone 没有解决这个问题,因此可能挂载过程中会出现问题,如果出现了下文描述的问题,请参考第三部分来解决。
2.1 安装 rclone
由于 vps 中没有桌面环境,无法独立完成配置,所以 vps 和本地电脑都要安装 rclone。
vps 中执行
curl https://rclone.org/install.sh | sudo bash
即可成功安装
本地电脑请点此下载 rclone 并解压
2.2 在 rclone 中配置 OneDrive
首先在 vps 中执行
rclone config
初始状态下什么配置都没有,点击 n 创建一个新配置
添加配置
接着会让你填写一个名称,这个随意填,例如 od
然后会要求选择要挂载的网盘,找到 Microsoft OneDrive
并输入其前面的序号31
接下来会要求输入 client_id
和 client_secret
,将第一步中获取的值依次输入。
地区按照你的账号选择,比如我的就是普通的全球账户,就选择 1
填写信息
接下来会让你选择你是否有桌面环境,因为 vps 环境下没有桌面环境,因此选择 N 。
输入后会看到一段提示,将红框内这段命令复制到本地的电脑执行。
填写信息 2
现在在本地打开命令行,进入到 rclone 所在的文件夹内,粘贴上面的命令并执行
不出意外的话,会弹出浏览器窗口让你登录并授权,按要求操作即可。
操作完成后,会看到成功的提示
成功授权
此时回到本地的命令行查看,会发现出现了一段授权 code,复制这段 code 并粘贴回 vps。
注:如果成功看到下一步操作,请忽略第三节并继续配置,如果出现以下错误,不要担心,请按照第三节的方法操作。
如果遇到类似下图的错误:
Couldn't decode response - try again (make sure you are using a matching version of rclone on both sides: invalid character 'e' looking for beginning of value
rclone 的 bug
则按照第三节的处理。
接下来会选择使用哪种类型的账户,我使用的是 OneDrive,故选择 1
选择账户类型
选择 drive
选择 drive
结束!请看第四节挂载。
3. 挂载失败的解决方法
其实解决这个问题我们要使用的就是最简单粗暴的方式,没错:在本地配置好,把配置文件复制过去!
打开本地命令行并进入 rclone 目录下,按照类似于第二节的方式重新配置,只不过这次选择是否有桌面环境时选择 Y ,这样子登录账户授权后就会直接成功,不会出现之前的问题了。
在本地成功添加配置后,在本地 rclone 目录下和远程 vps 分别执行
rclone config file
这个获取到的是 rclone 配置文件的目录。现在,直接把本地配置完成的配置文件复制到 vps 上去!
放心,这个配置文件在 vps 上也是能直接用的,复制完成后,在 vps 上执行
rclone config
嗯,能看到你在本地添加的 OneDrive 配置就是没问题了。
4. 挂载到 vps
首先新建一个文件夹用于挂载:
mkdir -p /home/onedrive
开始挂载:
rclone mount od: /home/onedrive --allow-other --vfs-cache-mode writes --allow-non-empty --no-modtime &
其中 od
是 rclone 配置时输入的配置名称
,/home/onedrive
是挂载目录,&
是指后台运行。
此时可能会报错:
Fatal error: mount not ready
这是因为缺少依赖,我们选择安装
centos 系使用:
yum install -y fuse3
debian 系使用:
apt install -y fuse3
再次执行挂载命令,如果没有报错,就是挂载成功了。
检查挂载:
df -h
应该看到(我这里是用挂载名 song,挂载目录 /music 进行的测试截图):
挂载成功
接下来可以进行一些测试,如果能正常读写文件,证明挂载没有问题。