Java服务器端消息队列实战
服务端口监听--报文接收--报文解码--业务处理--报文编码--写回客户端
从服务端与客户端成功握手并产生一个socket后,为了提高吞吐能力,接下来的事情就可以交给多线程去处理。
为了对接入的请求做合理的限制、控制,引入消息队列缓冲技术。
队列,主动推送消息和被动拉取消息两种方式实现,并且可以在两种实现上增加自定义的策略,例如:流量控制等。
接下来将使用Java语言实现队列与多线程整合技术的实现。
这里直接使用LinkedBlockingQueue队列,自带队列阻塞功能,免去线程安全控制。
package hope.queue.blockdemo; import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.LinkedBlockingQueue;
/**
* 消息队列缓冲定义
* @author hp
*
*/
public class PushBlockQueue extends LinkedBlockingQueue<Object>{ private static final long serialVersionUID = -8224792866430647454L;
private static ExecutorService es = Executors.newFixedThreadPool(10);//线程池
private static PushBlockQueue pbq = new PushBlockQueue();//单例
private boolean flag = false; private PushBlockQueue(){} public static PushBlockQueue getInstance(){
return pbq;
} /**
* 队列监听启动
*/
public void start(){
if(!this.flag){
this.flag = true;
}else{
throw new IllegalArgumentException("队列已处于启动状态,不允许重复启动.");
}
new Thread(new Runnable(){
@Override
public void run() {
while(flag){
try {
Object obj = take();//使用阻塞模式获取队列消息
//将获取消息交由线程池处理
es.execute(new PushBlockQueueHandler(obj));
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}).start(); } /**
* 停止队列监听
*/
public void stop(){
this.flag = false;
}
}
定义队列处理器,这个处理器实现Runnable接口,是为了与线程池做衔接。
package hope.queue.blockdemo;
/**
* 队列消息处理实现
* @author hp
*
*/
public class PushBlockQueueHandler implements Runnable { private Object obj;
public PushBlockQueueHandler(Object obj){
this.obj = obj;
} @Override
public void run() {
doBusiness();
} /**
* 业务处理时限
*/
public void doBusiness(){
System.out.println(" 处理请求 "+obj );
} }
测试实例
package hope.queue.blockdemo;
public class AppTest {
/**
* @param args
* @throws Exception
*/
public static void main(String[] args) throws Exception {
PushBlockQueue.getInstance().start();
for(;;){
Thread.sleep(1000);
PushBlockQueue.getInstance().put("0123456");
}
}
}
输出结果
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
处理请求 0123456
这种模式可以应用到很多场景,希望对大家工作上有所帮助。
Java服务器端消息队列实战的更多相关文章
- JAVA记录-消息队列介绍
1.JMS概述 JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送消 ...
- LINUX消息队列实战之一
前言 能说能抄能论皆不算,能写能打才是真功夫. 唠叨 反正我也是一个孤独的程序猿,多说一些奇奇怪怪的唠叨也无妨,第一次写消息队列,书本的东西和实战很不同,根据实战总结的一些注意事项会和大家分享,也敲打 ...
- java JMS消息队列
http://blog.csdn.net/shirdrn/article/details/6362792 http://haohaoxuexi.iteye.com/blog/1893038 http: ...
- java学习-消息队列rabbitmq的组成
rabbitMQ组成部分 rabbitmq有以下组成部分,分别为: 1. Server(broker)接受客户端连接,实现AMQP消息队列和路由功能的进程 2.虚拟主机virtual host虚拟主机 ...
- java之消息队列ActiveMQ实践
原创论文:https://www.cnblogs.com/goujh/p/8510239.html 消息队列的应用场景: 消息队列应用场景 异步处理,应用解耦,流量削锋和消息通讯四个场景 异步处理: ...
- Java面试—消息队列
消息队列面试题 题目来自于中华石杉,解决方案根据自己的思路来总结而得. 题目主要如下: 1. 为什么要引入消息队列? 消息队列的引入可以解决3个核心问题: 解耦 异步 削峰 解耦 在一个项目中,如果一 ...
- Java基础——消息队列
1.消息队列的适用场景:商品秒杀.系统解耦.日志记录等 2.使用Queue实现消息对列 双端队列(Deque)是 Queue 的子类也是 Queue 的补充类,头部和尾部都支持元素插入和获取阻塞队列指 ...
- [Java] 分布式消息队列(MQ)
概述 场景 服务解耦 削峰填谷 异步化缓冲:最终一致性/柔性事务 MQ应用思考点 生产端可靠性投递 消费端幂等:消息只能消费一次 高可用.低延迟.可靠性 消息堆积能力 可扩展性 业界主流MQ Acti ...
- 【LiteOS】LiteOS消息队列-实战
目录 前言 链接 参考 笔录草稿 创建测试任务 部分源码 前言 链接 LiteOS源码链接 常见问题 华为开发者社区 华为LiteOS官方教程 我的gitee-LiteOS-mcu 参考 上面链接 笔 ...
随机推荐
- JS中的执行环境和作用域
window 是最大最外围的执行环境,然后每个函数都有自己的执行环境.JS代码是从上到下执行的,单纯的用语言描述可能会有点绕,而且不大直观.我们看着代码来 console.log('global be ...
- JDBC完美连接方法
jdbc:mysql://localhost:3306:test这句里面分如下解析:jdbc:mysql:// 是指JDBC连接方式:localhost: 是指你的本机地址:3306 SQL数据库的端 ...
- AMD、CMD和CommonJS规范(转)
CommonJS规范 CommonJS是在浏览器环境之外构建JavaScript生态系统为目标产生的项目,比如服务器和桌面环境中.CommonJS规范是为了解决JavaScript的作用域问题而定义 ...
- 触发ionic弹窗区域外的方法
最近项目需要在页面弹窗的时候需要点击弹窗区域外的地方,其实也就是点击页面HTML就可以关闭弹窗, 首先在controller通过js获取到html的dom节点,然后绑定点击事件,话不多说上代码: ...
- 判断StringBuilder 是否为空
if("".equals(stringbuilder.toString())) do..
- webpack4 单独抽离打包 css 的新实现
webpack4 单独抽离打包 css 的新实现 前言 之前我们使用的打包 css 无非两种方式:① 将 css 代码打包进 入口 js 文件中:② 使用第三方插件(extract-text-webp ...
- Spark Streaming 交互 Kafka的两种方式
一.Spark Streaming连Kafka(重点) 方式一:Receiver方式连:走磁盘 使用High Level API(高阶API)实现Offset自动管理,灵活性差,处理数据时,如果某一时 ...
- U盘装机记录
U盘装机记录 1. 将U盘制作为启动盘(安装PE文件到U盘). (1)准备材料 8G以上U盘一个 一个可信的启动盘制作工具(这里是用的老毛桃) (2)将U盘插入电脑,单击老毛桃客户端(出现如下图所示的 ...
- manjaro安装teamviewer后无法打开
点桌面快捷方式一闪而过 命令行运行提示 $ teamviewer /opt/teamviewer/tv_bin/script/tvw_exec:行7: /opt/teamviewer/logfiles ...
- 477. Total Hamming Distance
class Solution { public: int totalHammingDistance(vector<int>& nums) { ; ; i < ; i++) { ...