Skip to content

阿里中间件搬砖头比赛异步请求版

License

Notifications You must be signed in to change notification settings

ppshinebl/laser

 
 

Repository files navigation

Laser(镭射)

项目简介

阿里搬砖头比赛说好是Client端线程级的同步阻塞请求,结果一帮人用了协程来完成这件事。其实吧,我想说就算用协程来完成,其实本质也和异步差不多(就网络通讯层),不过却激发了我的好奇心,因为比赛的结果是1G极限,只用了3秒!

3秒...如果我们将题目往对我有利的思考方向改变下,不再是Client端线程级的同步阻塞,只要求Server端请求应答同步即可。即:Server端在没收到一个请求之前,不能提前将下一个应答发出!如果我将题目修改为这样,我也不见得非常有信心能将时间控制在3秒以内!

所以这里立了个小项目来验证不同的实现方式下,对网络传输、CPU使用的开销。项目起名为镭射,取汇集小请求将能量集中爆发之意。

项目难点

镭射项目必须找到一个好的代码组织结构,以便通过切换参数就能变更具体的实现方式。这要求有比较好的软件工程底,提前划分好interface进行隔离。

项目结果

顺利跑进了5秒,但距离3秒差距还是太大,这里是总结文档

阿里中间件性能挑战赛java跑进5s“作弊”版

About

阿里中间件搬砖头比赛异步请求版

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 98.3%
  • Shell 1.7%