树莓派通过scp将文件传到ubuntu失败

在树莓派上通过scp指令将文件传到Ubuntu上出现以下现象:

 

ssh: connect to host 192.168.100.254 port 22: Connection refused 

  •  先试以下看能不能Ping通。
  • 如果可以ping通并且Ubuntu上可以通过scp将文件传到树莓派上说明树莓派的SSH配置没有问题,可能是Ubuntu没有安装sshd,或者防火墙没有关闭                     

    1. 确定安装sshd:

 sudo apt-get install openssh-server  

    2. 开启sshd:

service sshd start  

    3. 关闭防火墙:

sudo ufw disable   

    4.查看是否有sshd进程:

sudo ps -e |grep ssh

  • 重新尝试scp传文件,如果出现以下现象:

  1. 检查一下Ubuntu 用户名@IP地址 有没有写对

  2. 登录ubuntu,将/etc/ssh/sshd_config文件中的以下文件进行修改:

PermitRootLogin no  改为 PermitRootLogin yes

PasswordAuthentication no 改为 PasswordAuthentication yes

 

  3.重启sshd服务

 systemctl restart ssh.service

### 使用 SSH 和 SCP 协议向树莓派上传或下载文件 #### 一、SSH 基础 Secure Shell (SSH) 是一种网络通信协议,主要用于安全地访问远程计算机。它提供了加密的数据传输通道,确保数据的安全性和隐私性[^1]。 要连接到树莓派并执行操作,可以使用以下命令来建立 SSH 连接: ```bash ssh username@raspberry-pi-ip-address ``` 其中 `username` 是你在树莓派上的用户名(通常为 `pi`),而 `raspberry-pi-ip-address` 则是树莓派的 IP 地址。例如: ```bash ssh pi@192.168.141.103 ``` #### 二、SCP 文件传输基础 Secure Copy Protocol (SCP) 是基于 SSH 的文件传输工具,允许用户在本地机器和远程主机之间高效地复制文件[^2]。 ##### 下载文件(从树莓派到本地) 如果需要将树莓派中的某个文件下载到本地电脑,可使用如下命令: ```bash scp pi@raspberry-pi-ip-address:/path/to/file /local/path/ ``` 例如,假设你想将树莓派 `/home/pi/assert.c` 文件下载到当前工作目录下,则运行: ```bash scp pi@192.168.141.103:/home/pi/assert.c ./ ``` ##### 上传文件(从本地到树莓派) 反之,若想将本地文件上传至树莓派,只需调整源路径与目标路径的位置即可。例如,将本地桌面的一个 Python 脚本 `test.py` 发送到树莓派用户的家目录中: ```bash scp /Users/mac/Desktop/test.py pi@192.168.120.204:/home/pi/ ``` #### 三、高级选项配置 为了满足更复杂的场景需求,SCP 提供了一些额外的功能参数[^3]: - **递归模式**:当需要拷贝整个目录而非单个文件时,需加上 `-r` 参数。 ```bash scp -r local_directory_path user@remote_host:destination_path ``` - **限速功能**:可以通过设置带宽上限避免占用过多网络资源,单位为 KB/s。 ```bash scp -l limit_in_kb_per_second source_file destination_user@host:path ``` - **自定义端口号**:某些情况下,默认端口可能被更改;此时可通过 `-P` 来指明新的端口编号。 ```bash scp -P port_number file_name remote_username@hostname:/target/directory/ ``` #### 四、实际案例演示 以下是综合运用上述知识点的具体例子——将名为 `assert.c` 的 C 源码文件树莓派迁移到虚拟机环境下的实践过程: ```bash scp -r pi@192.168.141.103:/home/lm/assert.c . ``` 此命令实现了从地址为 `192.168.141.103` 的树莓派设备读取位于其内部存储位置 `/home/lm/` 中的 `assert.c` 文档,并保存于当前终端所在的文件夹之中。 --- ### 注意事项 - 确保两台设备间能够正常通讯,即确认双方处于同一局域网或者已妥善设置了 NAT 配置等外部条件。 - 如果遇到权限不足等问题,请尝试附加 sudo 特权再试一次,不过这往往意味着存在其他潜在风险应谨慎对待。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值