- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这是 this 的更受限制的版本问题:
我有一个嵌入式 ARM 设备,它运行带有 Linux 3.10.0 内核的自定义镜像。
唯一的物理接口(interface)(没有、USB、没有以太网)是连接到串行接口(interface)之一的默认 Linux shell。
我的问题是:是否有任何内置或外部工具可以通过此连接打开 IP 隧道?
我看到一些一般性问题:
socat stdio file:/dev/ttyS0,b115200
socat file:/dev/ttyS4,b115200 stdio
ttyS0
是
COM1
,
ttyS4
在这种情况下是
COM5
.
socat /dev/ttyS0,b115200,crtscts=1,raw,echo=0 tcp-connect:localhost:80
socat -T2 file:/dev/ttyS4,b115200,crtscts=1,raw,echo=0 tcp-l:7777,reuseaddr
-T2
2秒后终止连接。否则,curl 也不会终止并等待更多数据。
curl localhost:7777/index.html
socat
客户端和服务器终止。
EOF
再次终止
socat
的字符在完成请求/响应之前。
fork
到服务器:
socat /dev/ttyS0,b115200,crtscts=1,raw,echo=0 tcp-connect:localhost:80,fork
curl
返回
400 Bad Request
.所以看起来好像
socat
服务器为每一行或每一 block 发起一个请求,因为它不理解 HTTP。
socat
的 Windows 版本上没有实现。 .
socat
不提供真正理解 HTTP 并且能够通过串行连接正确序列化它的连接类型。
最佳答案
在普通的 linux 上,你可以使用 socat
.
该程序允许您连接多种流类型(文件、套接字、tcp、udp...)。在您的情况下,它将是 tcp 文件或更准确地说是端口 xx 到/dev/ttyUSB1 的 tcp 套接字。您应该在两侧启动 socat 以建立隧道。
编辑 1:
对不起,我也对 socat 感到失望。我找不到让我的 TCP 监听器对多个连续连接保持事件状态但一次只处理一个连接的解决方案。
我的解决方案是一个使用 4 个线程的简单 C# 程序:
1. 等待标准输入上的输入,例如退出命令
2. TCP监听器
3. 用于事件连接的 TCP 工作线程
4.如果TCP打开,则为COM打开另一个线程
线程 3 从 TCP 读取并写入 COM,线程 4 从 COM 读取并写入 TCP。如果线程收到 TCP 关闭事件,它会停止关闭 COMx 的线程 4,并自行退出。现在线程 2 可以接受一个新的连接。如果线程 1 在标准输入上读取 exit,它会向所有线程传递一条消息以停止和关闭。
也许您可以在没有 socat 的嵌入式系统上使用 pthread 用 C 语言实现这样一个简短的程序。
EOF问题:
我试图用谷歌搜索一个程序,它可以转义特殊字符或将数据流从 ASCII 重新编码为 ANSI 或 base64 或其他......
Server <=> reencode <=> socat <--serial--> socat <=> reencode <=> client
关于linux - Linux 串行默认 shell 上的 IP 隧道,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27837627/
是否有任何解决方案/补丁可以使 nginx 与上游的 socks 一起工作? 像这样: server { location / { proxy_pass socks5://ip:port
我的连接隧道有问题。因此,我正在使用两个安装了oracle xe(端口1521)的ubuntu服务器虚拟机,我们将它们称为uvm1和uvm2。我的目标是为两个服务器创建两个隧道,并将端口映射到主机,并
我正在使用 sshd 通过托管 Debian 的远程计算机隧道传输我所有的互联网流量。但是我的互联网连接变得很慢(大约 5 到 10 kbps!)。默认配置有什么问题会导致此问题吗? 提前致谢 最佳答
有没有办法在 OpenStreetMap 上显示所有隧道 + 道路?我正在为旅行制作自行车导航系统。在隧道中,我们丢失了 GPS 位置,因为隧道中没有 GPS 数据。我想知道我的位置进入隧道和离开隧道
我目前正在尝试在 Java 客户端(包括 Netty)和服务器之间实现一个 Http 隧道,所以我想知道是否有任何服务器也基于 Netty 来支持这个隧道,或者我应该构建服务器端我自己? 最佳答案 我
我希望从远程主机通过 SSH 建立一个端口。我希望将此实现为 oclif 插入;我希望用户体验如下所示: laptop$ give-jupyter http://localhost:4040/ lap
我正在寻找一种允许我使用 SSH 隧道连接到 R 中的 MySQL 服务器(而不是文件)的方法;我假设它需要 RCurl 和 RODBC 的组合,但我似乎无法让它正常工作。 我遇到了this post
基本上我想以编程方式通过代理服务器创建 SSL 隧道。我正在使用 openssl 创建 ssl 隧道,我可以创建它,但不确定如何通过代理服务器创建隧道。 最佳答案 快速谷歌搜索给我这个 pytunne
我想设置一个简单的 ssh 隧道,从本地机器到互联网上的机器。 我在用着 ssh -D 8080 -f -C -q -N -p 12122 @ 设置工作正常(我认为)导致 ssh 返回要求我提供的凭据
昨天,我接受了一家公司的 UI 开发面试。重点是面试官问了一个重要问题what is HTTP tunneling . 我从未遇到过有关 javascript、HTML 和 jquery 等 UI 内
对不起,长篇大论,我试图说得一清二楚。 * 一点背景 * 作为项目的一部分,我们需要能够使用远程桌面 (RDP) 从具有有效 IP 地址的服务器访问某些计算机(以下称为客户端)。这些客户端位于 NAT
我尝试了命令 killall ngrok,但我得到'killall' 未被识别为内部或外部命令、可操作程序或批处理文件。 killall 不应该和 ngrok 一起出现吗?我在互联网上找不到任何关于该
我需要连接到特定的 API,但该 API 只接受来 self 的配对服务器的请求。然后将这些信息包含在我们的网站中。 所以基本上我需要连接到服务器,使请求接收到答案并将其传输到我的主机,以便我可以使用
使用虚拟主机而不是部署的 Docker 容器,创建 ssh 隧道以便从我的本地机器访问分隔的机器对我来说是一个正常的工作过程。例如,将我的 psql 客户端连接到我只能从堡垒箱访问的 Postgres
我有一个从 Cloud Foundry 数据库转储数据的脚本,它的工作方式如下: cf ssh -L 33001:db.host:3306 --skip-remote-execution App &
我对以下系统架构有疑问: 假设我们有三台机器: SERVER A SERVER B EXTERNAL A SERVER A 正在提供一些流媒体服务,它在一个未知的网络后面,所以它在指定的端口上打开一个
我想从家庭计算机访问位于防火墙后面的工作计算机。 由于工作防火墙阻止意外的传入连接,我必须打开从工作计算机到家庭计算机的反向 SSH 隧道,如下所示: ssh -R 12345:localhost:2
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a software
我遇到了 SSH 隧道问题,我知道这可能是我的本地端口的权限问题,很可能是 127.0.0.1:3308。但是,我已经以管理员身份运行了我的程序(sudo python3 myprogram.py),
我使用此链接在 centos linux 中创建 ip 隧道 http://www.techonia.com/create-tunnel-interface-linux . 然后我想删除现有的隧道,我
我是一名优秀的程序员,十分优秀!