使用 sshfs 工具将远程 Linux 主机的文件夹挂载到本地

在 Ubuntu 上,你可以使用 sshfs 工具将远程 Linux 主机的文件夹挂载到本地,从而通过命令行访问远程文件系统。以下是详细的步骤:

1. 安装 sshfs

首先,确保你已经安装了 sshfs。如果没有安装,可以使用以下命令进行安装:

sh 复制代码
sudo apt update
sudo apt install sshfs

2. 创建挂载点

在本地创建一个目录作为挂载点。例如,创建一个名为 remote_folder 的目录:

sh 复制代码
mkdir ~/remote_folder

3. 挂载远程文件夹

使用 sshfs 命令将远程主机的文件夹挂载到本地创建的目录。假设远程主机的 IP 地址是 192.168.1.100,远程文件夹路径是 /path/to/remote/folder,远程主机的用户名是 user,你可以使用以下命令进行挂载:

sh 复制代码
sshfs user@192.168.1.100:/path/to/remote/folder ~/remote_folder

4. 验证挂载

挂载成功后,你可以通过访问 ~/remote_folder 来访问远程主机的文件夹。例如:

sh 复制代码
ls ~/remote_folder

5. 卸载远程文件夹

当你不再需要访问远程文件夹时,可以使用 fusermount 命令卸载它:

sh 复制代码
fusermount -u ~/remote_folder

6. (可选)设置无密码访问

为了方便使用,你可以设置无密码 SSH 访问。这需要在本地生成 SSH 密钥并将其添加到远程主机的 ~/.ssh/authorized_keys 文件中。

生成 SSH 密钥

在本地主机上生成 SSH 密钥(如果还没有生成):

sh 复制代码
ssh-keygen -t rsa

按回车键接受默认文件位置和空密码。

将公钥添加到远程主机

将生成的公钥添加到远程主机的 ~/.ssh/authorized_keys 文件中:

sh 复制代码
ssh-copy-id user@192.168.1.100

7. (可选)自动挂载

如果你希望在系统启动时自动挂载远程文件夹,可以编辑 /etc/fstab 文件。添加以下行:

sh 复制代码
user@192.168.1.100:/path/to/remote/folder  /home/your_username/remote_folder  fuse.sshfs  defaults,_netdev,IdentityFile=/home/your_username/.ssh/id_rsa  0  0

确保将 user192.168.1.100/path/to/remote/folder/home/your_username/remote_folder 替换为实际的值。

完整的命令序列

以下是完整的命令序列,供参考:

sh 复制代码
# 安装 sshfs
sudo apt update
sudo apt install sshfs

# 创建挂载点
mkdir ~/remote_folder

# 挂载远程文件夹
sshfs user@192.168.1.100:/path/to/remote/folder ~/remote_folder

# 验证挂载
ls ~/remote_folder

# 卸载远程文件夹
fusermount -u ~/remote_folder

# (可选)生成 SSH 密钥
ssh-keygen -t rsa

# (可选)将公钥添加到远程主机
ssh-copy-id user@192.168.1.100

# (可选)编辑 /etc/fstab 文件
sudo nano /etc/fstab

你遇到的问题是因为远程主机 172.21.42.10 只支持 ssh-rsassh-dss 这两种主机密钥类型,而你的本地 SSH 客户端可能默认使用了其他类型的密钥(例如 ed25519ecdsa)。为了解决这个问题,你可以通过配置 SSH 客户端来允许使用 ssh-rsassh-dss 密钥类型。

解决方法

1. 修改 SSH 客户端配置

你可以通过编辑 SSH 客户端的配置文件来允许使用 ssh-rsassh-dss 密钥类型。编辑 ~/.ssh/config 文件(如果不存在则创建):

sh 复制代码
nano ~/.ssh/config

在文件中添加以下内容:

sh 复制代码
Host 172.21.42.10
    HostKeyAlgorithms +ssh-rsa,ssh-dss
    PubkeyAcceptedKeyTypes +ssh-rsa,ssh-dss

保存并关闭文件。

2. 重新尝试 ssh-copy-id

再次尝试将公钥复制到远程主机:

sh 复制代码
ssh-copy-id naura@172.21.42.10

完整的命令序列

以下是完整的命令序列,供参考:

sh 复制代码
# 编辑 SSH 客户端配置文件
nano ~/.ssh/config

# 添加以下内容
Host 172.21.42.10
    HostKeyAlgorithms +ssh-rsa,ssh-dss
    PubkeyAcceptedKeyTypes +ssh-rsa,ssh-dss

# 保存并关闭文件

# 重新尝试将公钥复制到远程主机
ssh-copy-id naura@172.21.42.10

验证

如果一切顺利,你应该能够成功将公钥复制到远程主机。你可以通过以下命令验证是否可以无密码登录:

sh 复制代码
ssh naura@172.21.42.10

如果能够成功登录且不需要输入密码,说明配置已经生效。

其他注意事项

  • 安全性 :允许使用 ssh-rsassh-dss 密钥类型可能会降低安全性,因为这些密钥类型被认为不如 ed25519ecdsa 安全。如果你对安全性有较高要求,建议在确保远程主机支持更安全的密钥类型后,再进行配置。
  • 远程主机配置 :如果远程主机的 SSH 服务器配置不允许使用 ssh-rsassh-dss,你可能需要联系远程主机的管理员进行配置。

希望这些步骤能帮助你解决问题。如果有任何问题,欢迎随时提问。

相关推荐
用户805533698037 小时前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
用户034095297918 小时前
linux fcitx 5 雾凇拼音 设置在中文输入法下仍然输入英文标点
linux
Web3探索者2 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo2 天前
Linux系统中网线与USB网络共享冲突
linux
Sokach10153 天前
Linux Shell 脚本从零到能用:一个新手的一天学习总结
linux
AlfredZhao4 天前
Docker 容器时区不对,`timedatectl` 不存在怎么办?
linux·timezone
zzzzzz3105 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode5 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
A小辣椒7 天前
TShark:Wireshark CLI 功能
linux
A小辣椒7 天前
TShark:基础知识
linux