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

从服务端与客户端成功握手并产生一个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. C#注释语句

    C#注释语句 注释就是在程序中标记.说明某个程序段的作用.注释语句不会被执行. 一.单行注释 // 这是一行注释 二.多行注释 /*    这是多行注释    第一行    第二行    ...... ...

  2. MySQL事务隔离级别 解决并发问题

    MySQL事务隔离级别 1. 脏读: 骗钱的手段, 两个窗口或线程分别调用数据库转账表,转账后未提交,对方查看到账后,rollback,实际钱没转. 演示方法: mysql默认的事务隔离级别为repe ...

  3. java对一个int数组进行排序、去重

    思路: 1.使用 HashSet 进行去重 2.将 HashSet 变为 TreeSet 3.使用 TreeSet 进行排序 4.将 Set 变为 Integer 数组 5.将 Integer 数组变 ...

  4. Spring框架基础2

    Spring框架基础2 测试Spring的AOP思想和注解的使用 导包(在前面的基础上添加) SpringAOP名词解释 AOP编程思想:横向重复代码,纵向抽取:就是说多个地方重复的代码可以抽取出来公 ...

  5. spring-bean(全生命周期)

    作用:在初始化和销毁bean时候,做一些处理工作是调用生命周期方法 格式: <bean id=”该生命周期的名称” class=”提供方法的类的全路径” init-methood=”init” ...

  6. 使用Jmeter性能测试,读取csv文件时的乱码问题

    读取csv参数乱码问题 发送请求时参数通过CSV文件读取,发送请求后显示错误,把获取的参数通过在线urlencode转码器转码后发现是乱码.打开csv设值,编码格式选择的是UTF-8,打开参数文件后发 ...

  7. SpringBoot注入Mapper提示Could not autowire. No beans of 'xxxMapper' type found错误

    通过用Mabatis的逆向工程生成的Entity和Mapper.在Service层注入的时候一直提示Could not autowire. No beans of 'xxxMapper' type f ...

  8. 虚拟机VMware安装Kali Linux

    本文讲解如何在虚拟机上安装Kali Linux,希望对大家有所帮助. 准备:一台电脑,VMware(VMware安装教程) 一.下载系统镜像文件 1.首先下载系统镜像,进入kali官网,在Downlo ...

  9. 汇编:输出寄存器AX中的内容

    DATAS segment Temp db '0000H','$' DATAS ends CODES segment START: mov AX,DATAS mov DS,AX ;正式代码开始 mov ...

  10. 用 js 写一个获取随机颜色的程序

    function getColor(){ var color="#"; for(var i=0;i<6;i++){ color+=(Math.random()*16 | 0) ...