WebSocketd是WebSocket的守护进程,负责处理WebSocket连接,并启动服务器应用程序来处理WebSockets,在应用程序和Web浏览器之间传递消息。
WebSocketd是一款非常特别的WebSocket服务器,它的最大特点是后台脚本不限语言,其标准输入stdin
就是WebSocket的输入,标准输出stdout
就是WebSocket的输出。
WebSocketd本质上是命令行的WebSocket代理,只要在命令行可以执行的程序,都可以通过它与浏览器进行WebSocket通信。
WebSocketd可作为后台服务运行,帮助处理WebSocket连接,加载应用程序处理WebSocket,在程序和浏览器之间传递消息,无需任意依赖包且进程独立。
使用Bash编写服务器脚本并与浏览器WebSocket交互
使用Bash编写脚本
$ vim test.sh
#!/bin/bash
echo 1
sleep 1
echo 2
sleep 1
echo 3
启动WebSocketd指定脚本作为服务,websocketd
命令会启动一个WebSocket服务器并指定端口。每当客户端连接到服务器,就会执行对应的脚本,并将脚本的输出推送给客户端。
$ websocketd --port=8080 bash ./test.sh
客户端JavaScript接口中可通过onmessage
方法获取服务器推送过来的数据。
$ vim test.js
var ws = new WebSocket("ws://localhost:8080");
ws.onmessage = function(event){
console.log(event.data);
};
可将命令行输出发送给浏览器,比如执行ls
命令将当前目录内容发送给浏览器,以实时监控服务器。
$ websocketd --port=8080 ls
使用Python编写服务器脚本与浏览器WebSocket进行交互
$ mkdir websocket && cd websocket
$ vim test.py
import time
print(1)
time.sleep(1)
print(2)
time.sleep(1)
print(3)
time.sleep(1)
$ websocketd --port=9000 python ./test.py
$ vim test.html
<script>
const url = "";
let ws = new WebSocket("ws://localhost:9000");
ws.onmessage = (event)=>console.log(event.data);
</script>
使用Node.js的HTTP-Server开启HTTP服务器
$ http-server -p 8000 ./
使用浏览器访问 http://127.0.0.1:8000/test.html
$ websocketd --staticdir=.
staticdir
表示允许WebSocketd作为静态文件提供,也就是说在当前项目指定通知执行的语言脚本同名的Web页面作为静态文件。
$ websocketd --devconsole
devconsole
标志会使内置的控制台WebSocketd与WebSocket端点进行手工交互。
devconsole
与staticdir
不能不同使用,内置开发控制台旨在提供临时用户界面,用于构建真实的用户界面。
为WebSocket配置Nginx代理服务器
$ vim test.conf
server {
listen 443 ssl http2;
server_name www.test.com;
ssl_certificate /etc/test/full_chain.pem;
ssl_certificate_key /etc/test/private.key;
location /wssd
{
proxy_pass http://lnmp-php:8888;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_set_header X-Real-IP $remote_addr;
proxy_read_timeout 600;
}
}