BeanstalkClient学习
针对BeanstalkClient-1.4.6.jar
生产者
示例代码:
package com.lky.test; import java.io.UnsupportedEncodingException; import org.junit.Ignore;
import org.junit.Test; import com.surftools.BeanstalkClientImpl.ClientImpl; /**
* @Title: produceTest.java
* @Package com.lky.test
* @Description: beanstalkClient produce使用学习
* @author lky
* @date 2015年10月20日 上午10:12:49
* @version V1.0
*/ public class produceTest { @Test
@Ignore
public void produce1() throws UnsupportedEncodingException{
ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
client.useTube("phone"); client.put(3, 0 ,20, new String("中兴").getBytes("utf-8"));
client.put(1, 0, 20, new String("小米").getBytes("utf-8"));
client.put(2, 0, 20, new String("苹果").getBytes("utf-8"));
client.close();
} @Test
public void produce2() throws UnsupportedEncodingException{
ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
client.useTube("log"); client.put(2, 0, 20, new String("123456").getBytes("utf-8"));
client.put(5, 0, 20, new String("4541212").getBytes("utf-8"));
client.put(3, 0, 20, new String("1212121212").getBytes("utf-8"));
client.close();
}
}
消费者
示例代码:
package com.lky.test; import java.io.UnsupportedEncodingException;
import java.util.Random;
import org.junit.Before;
import org.junit.Ignore;
import org.junit.Test; import com.surftools.BeanstalkClient.Job;
import com.surftools.BeanstalkClientImpl.ClientImpl; /**
* @Title: consumerTest.java
* @Package com.lky.test
* @Description: beanstatlked 消费者学习 (job交互,tube交互)
* @author lky
* @date 2015年10月20日 上午10:15:19
* @version V1.0
*/
public class consumerTest { @Before
@Ignore
public void loadUp(){
ClientImpl client = new ClientImpl("10.21.25.196", 11300, true);
client.useTube("log");
client.kick(3);//将处于bury状态下的job重新放入ready队列中
client.close();
} @Test
public void consumer1() throws UnsupportedEncodingException {
ClientImpl client = new ClientImpl("10.21.25.196", 11300, true);
client.watch("log");
client.ignore("default"); Job job=null;
while((job=client.reserve(20))!=null){
System.out.println(job.getJobId()+"---------->"+new String(job.getData(),"utf-8"));
// client.bury(job.getJobId(), new Random(10).nextInt(11));
// client.delete(job.getJobId());
client.release(job.getJobId(), new Random(100).nextInt(11), new Random(100).nextInt(11));
// client.touch(job.getJobId());
}
client.close();
}
}
状态监测
示例代码:
package com.lky.test; import java.util.List;
import java.util.Map;
import java.util.Map.Entry; import org.junit.After;
import org.junit.Before;
import org.junit.Ignore;
import org.junit.Test; import com.surftools.BeanstalkClientImpl.ClientImpl; /**
* @Title: stateTest.java
* @Package com.lky.test
* @Description: beanstalked队列中 处于各种状态下job的统计
* @author lky
* @date 2015年10月20日 上午10:16:59
* @version V1.0
*/
public class stateTest { @Before
public void testBefore(){
System.out.println("-------------------分隔符------------------");
} @After
public void testAfter(){
System.out.println("-------------------分隔符------------------");
} @Test
public void testStatusLog(){
ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
client.useTube("log");
Map<String, String> info=client.statsTube("log");
for(Entry<String, String>entry:info.entrySet()){
System.out.println(entry.getKey()+"---------->"+entry.getValue());
}
client.close();
} @Test
public void testStatusPhone(){
ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
client.useTube("phone");
Map<String, String> info=client.statsTube("phone");
for(Entry<String, String>entry:info.entrySet()){
System.out.println(entry.getKey()+"---------->"+entry.getValue());
}
client.close();
} @Test
@Ignore
public void testStatusDefault(){
ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
client.useTube("default");
Map<String, String> info=client.statsTube("default");
for(Entry<String, String>entry:info.entrySet()){
System.out.println(entry.getKey()+"---------->"+entry.getValue());
}
client.close();
} @Test
@Ignore
public void testStatus(){
ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
Map<String, String> info=client.stats();
for(Entry<String, String>entry:info.entrySet()){
System.out.println(entry.getKey()+"---------->"+entry.getValue());
}
client.close();
} @Test
@Ignore
public void testStatusListTube(){
ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
List<String> info=client.listTubes();
for(String key:info){
System.out.println(key);
}
client.close();
} @Test
@Ignore
public void testStatusListTubeWatch(){
ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
client.watch("log");
client.watch("phone");
client.ignore("default");
List<String> info=client.listTubesWatched();
for(String key:info){
System.out.println(key);
}
client.close();
} }
BeanstalkClient学习的更多相关文章
- 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代
2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...
- Angular2学习笔记(1)
Angular2学习笔记(1) 1. 写在前面 之前基于Electron写过一个Markdown编辑器.就其功能而言,主要功能已经实现,一些小的不影响使用的功能由于时间关系还没有完成:但就代码而言,之 ...
- ABP入门系列(1)——学习Abp框架之实操演练
作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...
- 消息队列——RabbitMQ学习笔记
消息队列--RabbitMQ学习笔记 1. 写在前面 昨天简单学习了一个消息队列项目--RabbitMQ,今天趁热打铁,将学到的东西记录下来. 学习的资料主要是官网给出的6个基本的消息发送/接收模型, ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- Unity3d学习 制作地形
这周学习了如何在unity中制作地形,就是在一个Terrain的对象上盖几座小山,在山底种几棵树,那就讲一下如何完成上述内容. 1.在新键得项目的游戏的Hierarchy目录中新键一个Terrain对 ...
- 《Django By Example》第四章 中文 翻译 (个人学习,渣翻)
书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:祝大家新年快乐,这次带来<D ...
- 菜鸟Python学习笔记第一天:关于一些函数库的使用
2017年1月3日 星期二 大一学习一门新的计算机语言真的很难,有时候连函数拼写出错查错都能查半天,没办法,谁让我英语太渣. 关于计算机语言的学习我想还是从C语言学习开始为好,Python有很多语言的 ...
- 多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类)
前言:刚学习了一段机器学习,最近需要重构一个java项目,又赶过来看java.大多是线程代码,没办法,那时候总觉得多线程是个很难的部分很少用到,所以一直没下决定去啃,那些年留下的坑,总是得自己跳进去填 ...
随机推荐
- 【转】关于Ubuntu的sources.list 的总结
一.作用 文件/etc/apt/sources.list是一个普通可编辑的文本文件,保存了ubuntu软件更新的源服务器的地址.和sources.list功能一样的是/etc/apt/sources. ...
- Gamit解算脚本
这是一个解算单天的shell脚本,对于初学者很有帮助. 首先就是需要在项目(四个字符)建立rinex brdc igs 还有以年纪日命名的目录,然后提前准备好station.info和lfile.文件 ...
- Js实现简单的联动,无数据库版本
<html> <head> <title></title> <script language="javascript" typ ...
- asp.net微信开发第十篇----使用百度编辑器编辑图文消息,上传图片、微信视频
经过几天的资料收集,终于完成了该编辑器的图片上传,视频插入功能,视频插入功能主要借用了该编辑器的插入iframe功能,如原始插件图: 修改后的插件图如下(其中我隐藏掉了一些不需要使用的插件功能): 配 ...
- Topshelf
Topshelf允许开发者创建一个简单的控制台程序,将其安装为一个window服务. 这样做的原因很简单:方便调试. 使用命令行工具可以很方面的安装Topshelf创建的服务. server.exe ...
- C#Css/Js静态文件压缩--Yui.Compressor.Net
一.Asp.Net 自带静态文件压缩工具包 Microsoft.AspNet.Web.Optimization http://www.nuget.org/packages/Microsoft.AspN ...
- Entity Framework 新增实体,新增抽象实体
抽象实体不能new 抽象类:人,实体类:学生 人 p_人= new 学生(); 添加数据,学生和人都添加 抽象类可以提供一个抽象的方法,但是并没有实现,类似接口,但又不同于接口.子类继承父类时必须 ...
- 使用WebFrom来模拟一些MVC的MODEL与View的数据交互功能
MVC中有一点非常闪瞎人眼的功能就是,可以根据Model与View视图来直接将页面也数据模型进行绑定,那么我们在想客户端发送页面时不需要进行各种控件赋值,不需要操心怎么渲染,当客户提交表单给服务器时也 ...
- 你好,C++(27)在一个函数内部调用它自己本身 5.1.5 函数的递归调用
5.1.5 函数的递归调用 在函数调用中,通常我们都是在一个函数中调用另外一个函数,以此来完成其中的某部分功能.例如,我们在main()主函数中调用PowerSum()函数来计算两个数的平方和,而在P ...
- 数据库和Doctrine(转载自http://www.111cn.net/phper/332/85987.htm)
对于任何应用程序来说最为普遍最具挑战性的任务,就是从数据库中 读取和持久化数据信息.尽管symfony完整的框架没有默认集成ORM,但是symfony标准版,集成了很多程序,还自带集成了Doctrin ...