sublime Text 仅是代码编辑器,不能直接运行 websocket 服务;实际是用它编写基于 python 的 Socket.IO 后端(推荐 python-socketio 库),通过 fastapi/flask 框架启动服务,自动处理握手、命名空间等协议细节,并需区分 Socket.IO 与原生 WebSocket。

sublime text 本身是代码编辑器,不能直接运行或实现 WebSocket 服务;所谓“Sublime 编写 Websocket 实时通信服务”,实际是指用 Sublime Text 编辑、开发基于 Python(或其他语言)的 WebSocket 后端服务,并适配 Socket.IO 协议——注意:Socket.IO 不等于原生 WebSocket,它基于 http 长轮询 + WebSocket 的多协议自适应机制,需配套服务端库支持。
明确技术选型:Python + python-socketio
若用 Python 开发适配 Socket.IO 的后端,推荐使用 python-socketio 库(官方维护,兼容 Flask/FastAPI/ASGI 等)。它封装了底层传输细节,自动处理握手、心跳、命名空间、房间等 Socket.IO 特性,比直接用 websockets 或 asyncio.websocket 更贴合前端 socket.io-client 的行为。
安装方式(在终端执行,非 Sublime 内):
用 Sublime 编写并运行一个最小 Socket.IO 服务
在 Sublime 中新建文件,保存为 app.py,内容如下(基于 FastAPI + python-socketio):
import socketio from fastapi import FastAPI from fastapi.middleware.cors import CORSMiddleware sio = socketio.AsyncServer(async_mode='asgi', cors_allowed_origins="*") app = FastAPI() app.add_middleware( CORSMiddleware, allow_origins=["*"], allow_methods=["*"], allow_headers=["*"], ) app.mount("/", socketio.ASGIApp(sio)) @sio.event async def connect(sid, environ): print("Client connected:", sid) @sio.event async def chat_message(sid, data): await sio.emit("chat_message", {"reply": f"Echo: {data}", "from": sid}) @sio.event async def disconnect(sid): print("Client disconnected:", sid)
保存后,在终端运行:uvicorn app:app --reload。服务启动在 http://127.0.0.1:8000,已支持 Socket.IO 连接(前端可用 io("http://127.0.0.1:8000") 接入)。
关键适配点:别混淆 WebSocket 和 Socket.IO
很多开发者误以为启用 WebSocket 就等于支持 Socket.IO——这是常见误区。Socket.IO 客户端默认先发起 HTTP GET 请求(/socket.io/?EIO=4&transport=polling),协商成功后才升级为 WebSocket。因此后端必须:
- 提供
/socket.io/路由响应(python-socketio 自动注册) - 正确返回 EIO、sid、transport 等握手字段
- 维持 session 关联(通过 sid 区分客户端)
- 不直接监听
wss://地址——Socket.IO 客户端不会直连 ws://,而是走 /socket.io/ 协议栈
调试与验证建议
在 Sublime 中开发时,配合以下方式快速验证:
- 前端用官方 socket.io-client v4+(CDN 或 npm),确保版本与后端
python-socketio兼容(v5.x 对应 EIO=4) - 浏览器控制台输入
const s = io(); s.on("connect", () => console.log("ok")); - 查看终端日志是否打印 connect/disconnect;用
s.emit("chat_message", "hi")测试双向通信 - 用 wireshark 或浏览器 Network 面板观察请求路径和状态码,确认是否走过 polling → websocket 升级流程
基本上就这些。Sublime 只负责高效编码,真正的运行、调试、协议适配靠的是选对库、理解 Socket.IO 分层逻辑,而不是编辑器本身。