2024年9月

Docker内部网络连接错误的一种检查手段 nmap container

最近被一个容器无法内应用无法连接的问题折磨住了,我想看看内部的host.docker.internal到底怎么回事,于是想到建立一个nmap container进去检查
Dockerfile:

# 使用官方的 Ubuntu 镜像作为基础镜像
FROM ubuntu:latest

# 更新包列表并安装 nmap
RUN apt-get update && apt-get install -y nmap

# 创建一个目录来存储 nmap 结果
RUN mkdir /nmap_results

# 运行 nmap 并将结果保存到文件中,同时打印到控制台
CMD ["sh", "-c", "nmap host.docker.internal > /nmap_results/nmap_results.log && cat /nmap_results/nmap_results.log"]

docker-compose.yml:

version: '3.4'

services:
  nmap_service:
    image: nmap_image:latest
    build:
      context: .
      dockerfile: Dockerfile
    volumes:
      - ./nmap_results:/nmap_results

nmap结果发现不存在host.docker.internal,可能是docker更新的原因。之前是可用的,但现在变成了 172.17.0.1
另附服务器无法pull image时,使用其他机器本地image的方法

# 机器一
docker save [imgID] > imagefile
#机器二
docker load < imagefile
docker tag [new_imgID] [随便什么名字]:[随便什么版本]

最后改掉Dockerfile中的FROM就好了
写文章时我才想起来,可以直接docker内起ubuntu虚拟机,exec进去操作,忘了。

ApiFox / Postman 使用WebSocket连接SignalR需要注意的小问题

省流:忘加0x1e
最近刚接触SignalR,发现用ApiFox怎么都没法测试,可以正常连接,但是发消息没有任何反应。我一度怀疑是自己的环境出了问题。
image.png
后来直接使用大佬的代码(带前端)进行测试,发现是正常的。说明这只是操作上的问题。又去搜postman调试SignalR。才找到了这个简单的隐蔽的问题。
SignalR的交流以0x1e作为结束符。之前没有注意到这一点,走了一些弯路。
{"protocol":"json","version":1}
这段代码末尾加了个0x1e。可以直接整段复制用于SignalR连接。
image.png
TakeAway message:
如果想要上传消息,格式是:

{
  "type": 1,
  "target": "方法名",
  "arguments": ["方法参数1", "方法参数2..."]
}

SignalR type 数字含义:(From Copilot)

  1. Invocation (1):
    • 表示客户端或服务器调用一个方法。
    • 例如,客户端调用服务器上的一个Hub方法。
  2. StreamItem (2):
    • 表示流中的一项数据。
    • 用于流式传输数据时,每个数据项都会使用这个消息类型。
  3. Completion (3):
    • 表示一个调用或流的完成。
    • 包含调用的结果或错误信息。
  4. StreamInvocation (4):
    • 表示客户端请求从服务器流式传输数据。
    • 服务器会返回多个StreamItem消息。
  5. CancelInvocation (5):
    • 表示取消一个流式传输的请求。
    • 客户端可以发送这个消息来取消一个正在进行的流。
  6. Ping (6):
    • 表示一个心跳消息,用于保持连接活跃。
    • 没有负载,只是为了确保连接没有超时。
  7. Close (7):
    • 表示连接关闭。
    • 包含可选的错误信息。