博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用线程池模拟处理耗时任务,通过websocket提高用户体验
阅读量:6274 次
发布时间:2019-06-22

本文共 2703 字,大约阅读时间需要 9 分钟。

前言

在文章开始之前,询问一下大家平时工作中后端处理批量任务(耗时任务)的时候,前端是如何告知用户任务的执行情况的?

楼主对这个问题想了下,决定使用websokect将这一过程展现给用户。

于是就有了这篇文章,跟大家一起学习。

WebSocket简单介绍

WebSocket是HTML5开始提供的一种浏览器与服务器间进行全双工通讯的网络技术。 WebSocket通信协议于2011年被IETF定为标准 RFC 6455,WebSocketAPI被W3C定为标准。

在WebSocket API中,浏览器和服务器只需要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。

  ----------以上文字摘自于Wiki对WebSocket的介绍。 

 

简单来说,WebSocket就是浏览器与服务器之间进行通讯的一种技术。

 

关于WebSocket出现的背景及原理,大家可看中的介绍。

实例讲解

本文讲解的实例使用java语言编写,web服务器使用jetty8。

先看下对应的Servlet和WebSocket代码:

Servlet:

@WebServlet(name = "main", urlPatterns = "/main.do")public class MainServlet extends WebSocketServlet {
public WebSocket doWebSocketConnect(HttpServletRequest httpServletRequest, String s) { return new TaskWebSocket(); } }

WebSocket使用Task对象模拟耗时任务,用线程池进行处理:

public class TaskWebSocket implements WebSocket.OnTextMessage {
private Connection conn; private ExecutorService executorService; private CompletionService completionService; private Random random = new Random(); public TaskWebSocket() { executorService = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors()); completionService = new ExecutorCompletionService
(executorService); } public void onMessage(String s) { try { conn.sendMessage("开始执行任务"); int taskNum = 4; for(int i = 0; i < taskNum; i ++) { Task task = new Task(random.nextInt(20), conn, String.valueOf(i + 1)); completionService.submit(task); } for(int i = 0; i < taskNum; i ++) { String result = completionService.take().get(); conn.sendMessage(result); } conn.sendMessage("任务执行完毕"); conn.close(); } catch (Exception e) { e.printStackTrace(); System.err.println("error"); } } public void onOpen(Connection connection) { System.out.println("on Open"); this.conn = connection; } public void onClose(int i, String s) { System.out.println("on Close"); } }class Task implements Callable
{ private int sleepSec; private WebSocket.Connection conn; private String name; public Task(int sleepSec, WebSocket.Connection conn, String name) { this.sleepSec = sleepSec; this.conn = conn; this.name = name; } public String call() throws Exception { conn.sendMessage("任务(" + name + ")开始执行, 该任务大概会执行" + sleepSec + "秒"); Thread.sleep(sleepSec * 1000); return "任务" + name + "执行完成"; }}

 效果图:

前端js的代码就不贴了,用的是原生的websocket。

代码下载地址: 

参考资料

转载于:https://www.cnblogs.com/fangjian0423/p/jetty-websocket-demo.html

你可能感兴趣的文章
Python爬虫学习系列教程
查看>>
【数据库优化专题】MySQL视图优化(二)
查看>>
【转载】每个程序员都应该学习使用Python或Ruby
查看>>
PHP高级编程之守护进程,实现优雅重启
查看>>
PHP字符编码转换类3
查看>>
rsync同步服务配置手记
查看>>
Android下创建一个sqlite数据库
查看>>
数组<=>xml 相互转换
查看>>
MFC单文档应用程序显示图像
查看>>
poj 2777(线段树的节点更新策略)
查看>>
Swift-EasingAnimation
查看>>
[翻译] BKZoomView
查看>>
C++类设计的一些心得
查看>>
tableVIew删除时的delete按钮被挡住时重写的方法
查看>>
读cookie中文字符乱码问题
查看>>
招募译者翻译并发数据结构
查看>>
普通表转换为分区表
查看>>
Java 容器 & 泛型:三、HashSet,TreeSet 和 LinkedHashSet比较
查看>>
性能优化总结(六):预加载、聚合SQL应用实例
查看>>
http缓存知识
查看>>