前言关于redis我们前面已经讨论过了缓存、分布式锁、分布式唯一标识、LBS服务的用法,这里我们来谈谈利用redis来实现一个消息服务。典型的消息服务是一个生产者和消费者模式的服务。一般是有生产者产生消息,将消息发送到队列中。而消息的消费者则监听消息,对消息进行处理。有很多非常优秀的消息队列服务的产品。例如RabbitMQ、RocketMQ、Kafka等。这些产品都具备非常高级的功能。可靠性、扩展性都非常的好。但是redis自身也能够很简单的实现消息队列的生产者和消费者模式。本文简单介绍一下在Java下是如何实现的。相关命令介绍参考redis官网redis和pubsub模式相关的命令如下。PU
我有一个对对象集合进行操作的任务队列(为了举例,假设这些对象是地址簿中的条目)。一个示例任务可能是“将Joe的电话号码更新为888-555-1212”。队列中可能同时有多个“更新Joe的电话号码...”任务,但电话号码不同。在这种情况下,必须应用更新以确保最后的状态是正确的(不,为了争论,不可能在任务上加上时间戳,在地址簿条目上加上时间戳,然后扔掉过时的任务)。将Jane的更新与Joe的更新乱序应用是安全的。我想对队列进行多线程处理,但需要按人同步访问。有没有适合这种东西的方便的库?还是我只能使用Executor并在Runnable的run()方法中对“name”进行自己的同步?
我创建了一个使用spring4的websockets机制的简单应用程序。我在我的应用程序中使用了一个activemq代理。在我的简单测试中,我为名为“Alejando”的用户创建了10条消息(user/alejandro/queue/greetings)当我使用“Alejando”登录并订阅该队列时:stompClient.subscribe('/user/alejandro/queue/greetings',function(greeting){showGreeting(JSON.parse(greeting.body).content);});我确实收到了为alejandro查询的
我有以下Java主类,我正在尝试使用IntelliJIDEA中的Gradle插件编译和运行它:packagecom.mikidep.bookshop;importjava.io.IOException;importjava.util.Scanner;publicclassMain{publicstaticvoidmain(String[]args)throwsIOException{Scannerin=newScanner(System.in);System.out.print("Inseriscitestoqui:");System.out.println(in.nextLine()
我有一种方法可以在while循环中监听UDP数据包。我想在数据包到达时使用不同类中的另一种方法解析数据包,并在应用程序的另一部分对每个数据包进行许多不同的解析和分析。我认为让PacketParser方法在循环外处理Queue会更好。是否可以在数据包进入时将数据包添加到Queue中,然后让应用程序的另一部分在项目进入队列时监听项目并执行其他操作,因为原始while循环保持监听数据包并将它们添加到队列中?我想让另一个函数监视队列并处理数据包,Java中是否有一些东西可以监视Queue或Stack?有更好的方法吗?publicvoidread(StringmulticastIpAddress
对于我当前的开发,我有许多创建Tasks的线程(Producers)和许多使用这些Tasks的线程(消费者)每个Producer都由一个唯一的名称标识;Tasks由以下部分组成:其生产者的名称一个名字数据我的问题涉及(生产者)和(消费者)使用的数据结构。并发队列?天真地,我们可以想象Producer用Tasks填充一个并发队列,然后(consumers)读取/消费Tasks存储在并发队列中。我认为这个解决方案更适合扩展,但有一个案例是有问题的:如果Producers非常快速地创建两个名称相同但数据不同的Tasks(任务T1和T2同名但T1有数据D1,T2有数据D2),理论上有可能按照T
我有一系列并发任务要运行。如果其中任何一个失败,我想打断它们并等待终止。但假设它们都没有失败,我想等待它们全部完成。ExecutorCompletionService似乎几乎是我在这里想要的,但似乎没有办法判断我的所有任务是否已完成,除非单独计算任务数量。(请注意,ExecutorCompletionService的Javadoc中的两个示例都跟踪任务的计数“n”,并使用它来确定服务是否完成。)我是不是忽略了什么,还是我真的必须自己编写这段代码? 最佳答案 是的,如果您使用的是ExecutorCompletionService,则确
我设置了一个Wicket+Hibernate+SpringWeb应用程序,它涉及收集一些数据(生成并返回一些文件)、将其存储在数据库中、创建一些图像并将所有这些显示在网页上。这一切都适用于短期运行,但有时收集数据(涉及一些远程数字运算)会花费太长时间(20分钟以上)并超时。我尝试使用两种方法解决此问题,但它们都显示出一些问题。第一种方法是使用AjaxLazyLoadPanels并在getLazyLoadComponent中执行所有操作。这对于短时间运行效果很好,但对于20分钟以上的运行,LazyLoadComponents将由于超时而无法加载(这里很矛盾)。第二种方法涉及创建一个添加了
如果多个消费者从同一个队列中删除元素,是否有任何阻塞队列的实现可以保证公平的take()操作。我检查了LinkedBlockingQueue、LinkedTransferQueue,看起来它们都是不公平的。ArrayBlockingQueue提供了公平的操作,但它是有界的。 最佳答案 我们可以使用无界队列(如ConcurrentLinked队列)和公平信号量来实现无界公平阻塞队列。下面的类并没有实现BlockingQueue接口(interface)中的所有方法,只是实现了其中的一些用于演示目的。main()方法仅作为测试编写。pu
是否可以通过编程方式查询任务队列API以查看当前有多少任务正在执行/待处理?我在API中看不到任何执行此操作的方法,因此我求助于在数据存储区中创建对象来表示排队的任务。运行时,任务会从数据存储中删除相应的条目。如您所想,这很容易不同步。实际上,如果能够简单地计算给定队列名称的队列中的任务数量,我会非常高兴。 最佳答案 遗憾的是,没有可用于获取有关任务队列的信息的API。但是,我相信团队在未来会考虑到这一点(一个用于获取我们当前在仪表板上看到的统计信息的编程接口(interface),例如任务计数)。