
diogob/postgres-websockets该Docker镜像提供了WebSocket与数据库的连接桥梁,通过数据库原生的LISTEN/NOTIFY机制,实现数据库事件与WebSocket客户端之间的实时通信。用户无需开发复杂的中间件代码,即可快速构建数据库事件的实时推送服务,适用于需要数据库变更实时通知的场景。
bashdocker run -d \ --name db-ws-bridge \ -e DB_HOST=your-db-host \ -e DB_PORT=5432 \ -e DB_USER=db-user \ -e DB_PASSWORD=db-password \ -e DB_NAME=db-name \ -e LISTEN_CHANNELS=order_updates,stock_changes \ -e WS_PORT=8080 \ -p 8080:8080 \ [镜像名称]
yamlversion: '3.8' services: db-ws-bridge: image: [镜像名称] container_name: db-ws-bridge restart: always environment: - DB_HOST=postgres - DB_PORT=5432 - DB_USER=postgres - DB_PASSWORD=postgres_password - DB_NAME=app_db - LISTEN_CHANNELS=user_activity,system_events - WS_PORT=8080 - LOG_LEVEL=info ports: - "8080:8080" depends_on: - postgres postgres: image: postgres:14 container_name: postgres-db restart: always environment: - POSTGRES_USER=postgres - POSTGRES_PASSWORD=postgres_password - POSTGRES_DB=app_db ports: - "5432:5432" volumes: - postgres_data:/var/lib/postgresql/data volumes: postgres_data:
| 环境变量 | 描述 | 必需 | 默认值 | 示例 |
|---|---|---|---|---|
| DB_HOST | 数据库主机地址 | 是 | - | postgres、192.168.1.100 |
| DB_PORT | 数据库端口 | 否 | 5432 | 5432 |
| DB_USER | 数据库用户名 | 是 | - | postgres |
| DB_PASSWORD | 数据库密码 | 是 | - | secure_password |
| DB_NAME | 数据库名称 | 是 | - | app_db |
| LISTEN_CHANNELS | 监听的数据库通知频道(逗号分隔) | 是 | - | order_updates,stock_changes |
| WS_PORT | WebSocket服务端口 | 否 | 8080 | 8080 |
| LOG_LEVEL | 日志级别(debug/info/warn/error) | 否 | info | debug |
| RECONNECT_DELAY | 数据库重连间隔(秒) | 否 | 5 | 10 |
WebSocket客户端可通过ws://<host>:<WS_PORT>/连接服务,连接成功后将收到数据库NOTIFY事件的JSON格式消息:
javascript// 浏览器端WebSocket连接示例 const ws = new WebSocket('ws://localhost:8080/'); ws.onopen = () => { console.log('WebSocket连接已建立'); }; ws.onmessage = (event) => { const data = JSON.parse(event.data); console.log('收到数据库事件:', data); // 处理事件数据... }; ws.onclose = () => { console.log('WebSocket连接已关闭'); };

manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务