服务端口监听--报文接收--报文解码--业务处理--报文编码--写回客户端

从服务端与客户端成功握手并产生一个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服务器端消息队列实战的更多相关文章

  1. JAVA记录-消息队列介绍

    1.JMS概述 JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送消 ...

  2. LINUX消息队列实战之一

    前言 能说能抄能论皆不算,能写能打才是真功夫. 唠叨 反正我也是一个孤独的程序猿,多说一些奇奇怪怪的唠叨也无妨,第一次写消息队列,书本的东西和实战很不同,根据实战总结的一些注意事项会和大家分享,也敲打 ...

  3. java JMS消息队列

    http://blog.csdn.net/shirdrn/article/details/6362792 http://haohaoxuexi.iteye.com/blog/1893038 http: ...

  4. java学习-消息队列rabbitmq的组成

    rabbitMQ组成部分 rabbitmq有以下组成部分,分别为: 1. Server(broker)接受客户端连接,实现AMQP消息队列和路由功能的进程 2.虚拟主机virtual host虚拟主机 ...

  5. java之消息队列ActiveMQ实践

    原创论文:https://www.cnblogs.com/goujh/p/8510239.html 消息队列的应用场景: 消息队列应用场景 异步处理,应用解耦,流量削锋和消息通讯四个场景 异步处理: ...

  6. Java面试—消息队列

    消息队列面试题 题目来自于中华石杉,解决方案根据自己的思路来总结而得. 题目主要如下: 1. 为什么要引入消息队列? 消息队列的引入可以解决3个核心问题: 解耦 异步 削峰 解耦 在一个项目中,如果一 ...

  7. Java基础——消息队列

    1.消息队列的适用场景:商品秒杀.系统解耦.日志记录等 2.使用Queue实现消息对列 双端队列(Deque)是 Queue 的子类也是 Queue 的补充类,头部和尾部都支持元素插入和获取阻塞队列指 ...

  8. [Java] 分布式消息队列(MQ)

    概述 场景 服务解耦 削峰填谷 异步化缓冲:最终一致性/柔性事务 MQ应用思考点 生产端可靠性投递 消费端幂等:消息只能消费一次 高可用.低延迟.可靠性 消息堆积能力 可扩展性 业界主流MQ Acti ...

  9. 【LiteOS】LiteOS消息队列-实战

    目录 前言 链接 参考 笔录草稿 创建测试任务 部分源码 前言 链接 LiteOS源码链接 常见问题 华为开发者社区 华为LiteOS官方教程 我的gitee-LiteOS-mcu 参考 上面链接 笔 ...

随机推荐

  1. Siamese Network

    摘抄自caffe github的issue697 Siamese nets are supervised models for metric learning [1]. [1] S. Chopra, ...

  2. C语言学生成绩管理系统(简易版)

    #include<stdio.h> #include<stdlib.h> #include<string.h> int readstudents(struct st ...

  3. OCCI的迭代修改

    传统的在执行多行DML(INSERT.UPDATE.DELETE)时,我们是多次调用executeUpdate():注意!当我们调用一次此函数时,则执行一次网络往返,当数据量大时则效率非常低.不过 O ...

  4. C#进阶学习笔记(个人整理)

    学习笔记 第一章: 一.回顾数组 1.变量 : 只能存储一个数据 2.数组 :存储固定大小的相同类型的数据 3.对象 : 存储多个相同/不同类型的数据 4.集合 : 特殊的容器,存储N个相同/不同类型 ...

  5. php扩展开发-INI配置

    php.ini文件是用来保存各项扩展配置的文件,每个扩展都或多或少需要有一个定制化的配置,ini文件是一个很好的保存配置的方式,我们来看下怎么在自己的扩展里,使用到ini的配置功能 //创建ini的配 ...

  6. python之微信自动发送消息

    代码如下: from __future__ import unicode_literals from threading import Timer from wxpy import * import ...

  7. linux 共享内存

    共享内存是最高效的IPC机制,因为它不涉及进程之间的任何数据传输.这种高效带来的问题是,我们必须用其他手段来同步进程对共享内存的访问,否则会产生竞态条件.所以,共享内存通常和其他进程间通信方式一起使用 ...

  8. 统计输入任意的字符中中英文字母,空格和其他字符的个数 python

    这里用到了三个函数: #判断是否为数字:str.isdigit()#是否为字母:str.isalpha()#是否为空格:str.isspace() def tongji(str): alpha = 0 ...

  9. python-4函数式编程

    1-高阶函数 变量可以指向函数.   def add(x, y, f): 例如f参数为函数 编写高阶函数,就是让函数的参数能够接收别的函数. Python内建了map()和reduce()高阶函数. ...

  10. 笔记-python-lib-lxml

    笔记-python-lib-lxml 1.      lxml简介 lxml是一个实现解析网页文件的库,python中自带有解析库,但没有lxml方便好用. The lxml XML toolkit ...