如何仅使用Raspberry Pi的串行线将其连接到Internet

电子说

1.2w人已加入

描述

步骤1:确定USB UART转换器RX/TX线

您需要确保转换器上的哪些引脚是RX/TX串行线。不要依赖转换器PCB上的标记,因为它们可能不正确!如果您知道哪条线是TX和RX,则可以跳过此步骤。

如果不确定哪条线是TX,可以在可疑引脚上串联一个电阻和LED,LED应当闪烁

假定/dev/ttyUSB0是转换器,

# This will make a LED attached to the TX blink once

stty -F /dev/ttyUSB0 9600 raw

dd if=/dev/zero of=/dev/ttyUSB0 bs=1000 count=1

一旦确定了TX引脚,就可以将其连接到转换器上的可疑RX引脚构成回波环路。您应该能够收到写入的内容。

screen /dev/ttyUSB0 115200

在屏幕会话中键入字符时,连接TX-RX时屏幕应回显它们。

步骤2:将计算机连接到Raspberry Pi

将USB 《-》 UART转换器连接到Raspberry Pi 。您需要连接TX,RX和GND线。 TX代表“发送器”,RX代表“接收器”。连接两个UART设备时,必须以TX和RX交叉的方式连接它们。这意味着从一个设备上的TX引脚输出到另一设备上的RX输入引脚,反之亦然。有时称为空调制解调器。

UART Convertor Raspberry PI GPIO

GND ---------------------- GND

TX output pin ------------ RXD pin 10 on GPIO header

RX input pin ------------- TXD pin 8 on GPIO header

请确保您的转换器使用3.3v逻辑电平输出! Raspberry在其GPIO上使用3.3v逻辑,较高的电压可能会损坏GPIO!如果您的转换器使用5v逻辑电平,则必须使用某些逻辑电平转换器。

步骤3:使用控制台测试连接

默认情况下,Raspbian使用内置的UART进行Linux控制台访问和内核调试。现在,我们将利用此优势来测试接线。稍后我们将禁用此功能,并仅使用UART进行联网。

可以通过/dev/ttyAMA0专用设备访问Raspi的UART。

首先,确保串行控制台位于启用。在cmdline.txt中,您应该看到类似以下内容的

dwc_otg.lpm_enable=0 console=ttyAMA0,115200 kgdboc=ttyAMA0,115200 console=tty1 root=/dev/mmcblk0p2 rootfstype=ext4 elevator=deadline rootwait

最重要的部分是 console = ttyAMA0,115200 ,这将告诉内核将UART假定为系统控制台。

手动编辑文件或使用raspi-config(高级选项)在串行端口上启用控制台。

第二,在Linux计算机上,键入:

screen /dev/ttyUSB0 115200

这将连接到Raspberry Pi控制台。您应该看到一个登录提示,并且能够登录。如果看不到任何内容,请尝试按Enter。此外,在Raspi启动时,您还应该看到内核消息。

如果没有显示器和键盘,则可以使用串行控制台连接到Raspberry Pi。只要确保已在cmdline.txt

中启用了控制台,就可以检查串行连接,然后可以继续下一步。

步骤4:安装必要的工具

您将需要使用“ pppd”工具来管理连接。它是‘ppp’软件包的一部分。

将ppp软件包安装到Linux主机和Raspberry Pi:

sudo apt-get install ppp

如果没有的话您可以从Raspberry Pi上访问Internet(一个鸡蛋问题),您可以手动下载.deb程序包,将它们放在sd卡或闪存驱动器上,然后手动安装它们。只需确保下载并安装所有依赖项即可。

sudo dpkg -i xyz.deb

步骤5:接管Raspberry Pi的UART

现在,当串行链接可靠工作时。我们可以禁用控制台功能,仅将UART用于网络。

首先,从cmdline.txt中删除所有ttyAMA0引用,如果不知道如何,请参考上一步:

dwc_otg.lpm_enable=0 console=tty1 root=/dev/mmcblk0p2 rootfstype=ext4 elevator=deadline rootwait

在下次重新启动时,您将可以根据需要使用ttyAMA0。

在我们的情况下,我们将为某些合理的行为配置UART并启动PPP Daemon建立一个

这些命令基本上可以满足我们的需要:

stty -F /dev/ttyAMA0 raw

pppd /dev/ttyAMA0 115200 10.0.5.2:10.0.5.1 noauth local debug dump defaultroute nocrtscts

IP地址10.0.5.2和10.0.5.1表示本地:正在使用的远程地址用于连接。您可以选择任何IP地址,只需确保网络范围不同于您正在使用的IP地址即可。在我们的例子中,10.0.5.2将是我们Pi的地址,10.0.5.1将是我们Linux主机的地址。

由于除了串行端口之外,我无权访问RaspberryPi ,我稍微调整了pppd参数并将它们添加到/etc/rc.local脚本中,以便它们在每次Raspberry启动时都执行,并且pppd始终保持运行,因此我可以随意连接和断开Raspberry。

我的rc.local:

echo “Starting pppd.。.”

stty -F /dev/ttyAMA0 raw

stty -F /dev/ttyAMA0 -a

pppd /dev/ttyAMA0 115200 10.0.5.2:10.0.5.1 noauth local debug dump defaultroute nocrtscts persist maxfail 0 holdoff 1

“ persist maxfail 0 holdoff 1”参数将使pppd尝试永久连接。

当您插入a监视到您的Raspberry,您应该在屏幕上看到启动脚本的输出。

步骤6:在主机上运行Pppd

启动ppp守护程序在您的计算机上:

sudo stty -F /dev/ttyUSB0 raw

sudo pppd /dev/ttyUSB0 115200 10.0.5.1:10.0.5.2 proxyarp local noauth debug nodetach dump nocrtscts passive persist maxfail 0 holdoff 1

在两个设备上都运行pppd时,它们应该握手并建立链接。输出应如下所示:

using channel 10

Using interface ppp0

Connect: ppp0 《--》 /dev/ttyUSB0

sent [LCP ConfReq id=0x5 ]

rcvd [LCP ConfReq id=0x2 ]

sent [LCP ConfAck id=0x2 ]

rcvd [LCP ConfAck id=0x5 ]

sent [LCP EchoReq id=0x0 magic=0xb4bad9a9]

sent [CCP ConfReq id=0x4 ]

sent [IPCP ConfReq id=0x4 ]

rcvd [LCP EchoReq id=0x0 magic=0x263f80e1]

sent [LCP EchoRep id=0x0 magic=0xb4bad9a9]

rcvd [LCP EchoRep id=0x0 magic=0x263f80e1]

rcvd [CCP ConfReq id=0x2 ]

sent [CCP ConfAck id=0x2 ]

rcvd [IPCP ConfReq id=0x2 ]

sent [IPCP ConfAck id=0x2 ]

rcvd [CCP ConfAck id=0x4 ]

Deflate (15) compression enabled

rcvd [IPCP ConfAck id=0x4 ]

Cannot determine ethernet address for proxy ARP

local IP address 10.0.5.1

remote IP address 10.0.5.2

Script /etc/ppp/ip-up started (pid 3826)

Script /etc/ppp/ip-up finished (pid 3826), status = 0x0

现在,从Linux主机上,您应该能够ping或ssh RaspberryPi

ping 10.0.5.2

如果ping工作正常,您可以继续执行下一步。

步骤7:设置路由和NAT

一旦我们在计算机和计算机之间建立了IP链接,在Raspberry Pi中,我们可以配置计算机以将流量从Raspi路由到Internet。

首先,启用流量转发:

sudo sysctl -w net.ipv4.ip_forward=1

下一步,启用NAT假装将Raspi的内部地址转换为计算机的地址。假设“ eth0”是计算机上用于连接外部世界的接口:

sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE

现在,您应该可以通过SSH进入Raspberry并ping到一些Internet服务器: ! - )

完成

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分