Spike-使用PHP实现的内网穿透工具
当前页面是本站的「Google AMP」版。查看和发表评论请点击:完整版 »
简介
- 之前由于要与一个同事远程协作开发一款
app
需要用到内网穿透服务,在网上找到了frp
与ngrok
; 后来我在想能不能用php
也写出来一个这样的服务软件? 大家都知道php
多进程多线程不够友好,在window
上还不支持; 写服务确实很吃力; 不过幸运的是有ReactPHP
的存在,关于ReactPHP
不做赘述有兴趣的同学可以自行百度。 - 基于
ReactPHP
的IO
多路复用,使得Spike
并没有比Frp
性能差太多; 下面是我简单做的一个benchmark
,基于apache ab
检验http
隧道的服务性能; 客户端与服务端都搭在本地,代理同事电脑上的http
服务。不是特别符合应用场景,大家简单看一下。 - 从下面的信息可以看出
Spike
性能似乎是稍微好点的,不过这个地方有点不公平,我在做spike
的测试时只开启了服务端的日志,客户端的日志是关闭的; 而FRP
的两端日志都是开启的;我不知道怎么关 frp 的日志; - 在这里简单提一点由于
Spike
的日志 IO 是同步的所以日志的读写会耗掉部分性能,提升日志等级减少日志写入可以提升不少的性能; - 这个项目是我比较上心的一个作品,算是证明了一点,
php
除了可以做网站也可以做服务,并且也没有太差。项目地址:https://github.com/slince/spike欢迎star
,欢迎fork
。
Spike:
Concurrency Level: 10
Time taken for tests: 37.727 seconds
Complete requests: 100
Failed requests: 0
Total transferred: 2569900 bytes
HTML transferred: 2514600 bytes
Requests per second: 2.65 [#/sec] (mean)
Time per request: 3772.747 [ms] (mean)
Time per request: 377.275 [ms] (mean, across all concurrent requests)
Transfer rate: 66.52 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 0 0.4 0 3
Processing: 533 3602 591.9 3714 4096
Waiting: 516 3587 592.3 3701 4076
Total: 534 3602 591.9 3715 4097
Percentage of the requests served within a certain time (ms)
50% 3715
66% 3791
75% 3822
80% 3844
90% 3970
95% 4015
98% 4053
99% 4097
100% 4097 (longest request)
Frp:
Concurrency Level: 10
Time taken for tests: 38.230 seconds
Complete requests: 100
Failed requests: 0
Total transferred: 2569900 bytes
HTML transferred: 2514600 bytes
Requests per second: 2.62 [#/sec] (mean)
Time per request: 3823.045 [ms] (mean)
Time per request: 382.304 [ms] (mean, across all concurrent requests)
Transfer rate: 65.65 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 0 0.2 0 1
Processing: 379 3650 644.4 3809 4140
Waiting: 360 3633 645.5 3789 4124
Total: 380 3650 644.4 3809 4140
Percentage of the requests served within a certain time (ms)
50% 3809
66% 3847
75% 3909
80% 3923
90% 4026
95% 4053
98% 4129
99% 4140
100% 4140 (longest request)