如何从命令行访问Unix域套接字?

亚当·马坦|

使用Python读取Unix Domain套接字文件类似于普通的TCP套接字:

>>> import socket
>>> import sys
>>>
>>> server_address = '/tmp/tbsocket1'  # Analogous to TCP (address, port) pair
>>> sock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)
>>> sock.connect(server_address)
>>> sock.recv(512)
'*** uWSGI Python tracebacker output ***\n\n'

由于UDS不是普通文件,因此cat不适用于它们:

$ sudo cat /tmp/tbsocket1
cat: /tmp/tbsocket1: No such device or address

都不做curl

$ sudo curl /tmp/tbsocket1
curl: (3) <url> malformed

如何使用curl等标准命令行工具读写Unix域套接字?

PS:巧合的是,最近有人建议使用卷发补丁

凯夫

您可以ncatnmap项目中使用命令

ncat -U /tmp/tbsocket1

为了便于访问,您可以执行以下操作:

# forward incoming 8080/tcp to unix socket
ncat -vlk 8080 -c 'ncat -U /tmp/tbsocket1'
# make a http request via curl
curl http://localhost:8080

您也可以使用socat

# forward incoming 8080/tcp to unix socket
socat -d -d TCP-LISTEN:8080,fork UNIX:/tmp/tbsocket1

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章