是一台单核服务器,java的服务器端有一个接收ajax的长连接,就使用了一个while来监听
是否有需要发送给客户端的数据。
只要一开始连接,服务器CPU占有率就是100%,在自己的机子上调试(4核),CPU占有率就是25%。
那问题就是,这样的话单核服务器岂不是不敢用阻塞while了吗?
不说万级的长连接,就连3,5个长连接可能就会导致服务器死掉。
这个是怎么处理呢?
是一台单核服务器,java的服务器端有一个接收ajax的长连接,就使用了一个while来监听
是否有需要发送给客户端的数据。
只要一开始连接,服务器CPU占有率就是100%,在自己的机子上调试(4核),CPU占有率就是25%。
那问题就是,这样的话单核服务器岂不是不敢用阻塞while了吗?
不说万级的长连接,就连3,5个长连接可能就会导致服务器死掉。
这个是怎么处理呢?
无语了。估计你的while是无限占用CPU资源吧。由于你的机器是4核的,而你的程序是单线程的,往死里跑最多跑满一个核心,也就是25%。
为何不换个思路?