针对BeanstalkClient-1.4.6.jar

  • 生产者

示例代码:

  1. package com.lky.test;
  2.  
  3. import java.io.UnsupportedEncodingException;
  4.  
  5. import org.junit.Ignore;
  6. import org.junit.Test;
  7.  
  8. import com.surftools.BeanstalkClientImpl.ClientImpl;
  9.  
  10. /**
  11. * @Title: produceTest.java
  12. * @Package com.lky.test
  13. * @Description: beanstalkClient produce使用学习
  14. * @author lky
  15. * @date 2015年10月20日 上午10:12:49
  16. * @version V1.0
  17. */
  18.  
  19. public class produceTest {
  20.  
  21. @Test
  22. @Ignore
  23. public void produce1() throws UnsupportedEncodingException{
  24. ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
  25. client.useTube("phone");
  26.  
  27. client.put(3, 0 ,20, new String("中兴").getBytes("utf-8"));
  28. client.put(1, 0, 20, new String("小米").getBytes("utf-8"));
  29. client.put(2, 0, 20, new String("苹果").getBytes("utf-8"));
  30. client.close();
  31. }
  32.  
  33. @Test
  34. public void produce2() throws UnsupportedEncodingException{
  35. ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
  36. client.useTube("log");
  37.  
  38. client.put(2, 0, 20, new String("123456").getBytes("utf-8"));
  39. client.put(5, 0, 20, new String("4541212").getBytes("utf-8"));
  40. client.put(3, 0, 20, new String("1212121212").getBytes("utf-8"));
  41. client.close();
  42. }
  43. }
  • 消费者

示例代码:

  1. package com.lky.test;
  2.  
  3. import java.io.UnsupportedEncodingException;
  4. import java.util.Random;
  5. import org.junit.Before;
  6. import org.junit.Ignore;
  7. import org.junit.Test;
  8.  
  9. import com.surftools.BeanstalkClient.Job;
  10. import com.surftools.BeanstalkClientImpl.ClientImpl;
  11.  
  12. /**
  13. * @Title: consumerTest.java
  14. * @Package com.lky.test
  15. * @Description: beanstatlked 消费者学习 (job交互,tube交互)
  16. * @author lky
  17. * @date 2015年10月20日 上午10:15:19
  18. * @version V1.0
  19. */
  20. public class consumerTest {
  21.  
  22. @Before
  23. @Ignore
  24. public void loadUp(){
  25. ClientImpl client = new ClientImpl("10.21.25.196", 11300, true);
  26. client.useTube("log");
  27. client.kick(3);//将处于bury状态下的job重新放入ready队列中
  28. client.close();
  29. }
  30.  
  31. @Test
  32. public void consumer1() throws UnsupportedEncodingException {
  33. ClientImpl client = new ClientImpl("10.21.25.196", 11300, true);
  34. client.watch("log");
  35. client.ignore("default");
  36.  
  37. Job job=null;
  38. while((job=client.reserve(20))!=null){
  39. System.out.println(job.getJobId()+"---------->"+new String(job.getData(),"utf-8"));
  40. // client.bury(job.getJobId(), new Random(10).nextInt(11));
  41. // client.delete(job.getJobId());
  42. client.release(job.getJobId(), new Random(100).nextInt(11), new Random(100).nextInt(11));
  43. // client.touch(job.getJobId());
  44. }
  45. client.close();
  46. }
  47. }
  • 状态监测

示例代码:

  1. package com.lky.test;
  2.  
  3. import java.util.List;
  4. import java.util.Map;
  5. import java.util.Map.Entry;
  6.  
  7. import org.junit.After;
  8. import org.junit.Before;
  9. import org.junit.Ignore;
  10. import org.junit.Test;
  11.  
  12. import com.surftools.BeanstalkClientImpl.ClientImpl;
  13.  
  14. /**
  15. * @Title: stateTest.java
  16. * @Package com.lky.test
  17. * @Description: beanstalked队列中 处于各种状态下job的统计
  18. * @author lky
  19. * @date 2015年10月20日 上午10:16:59
  20. * @version V1.0
  21. */
  22. public class stateTest {
  23.  
  24. @Before
  25. public void testBefore(){
  26. System.out.println("-------------------分隔符------------------");
  27. }
  28.  
  29. @After
  30. public void testAfter(){
  31. System.out.println("-------------------分隔符------------------");
  32. }
  33.  
  34. @Test
  35. public void testStatusLog(){
  36. ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
  37. client.useTube("log");
  38. Map<String, String> info=client.statsTube("log");
  39. for(Entry<String, String>entry:info.entrySet()){
  40. System.out.println(entry.getKey()+"---------->"+entry.getValue());
  41. }
  42. client.close();
  43. }
  44.  
  45. @Test
  46. public void testStatusPhone(){
  47. ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
  48. client.useTube("phone");
  49. Map<String, String> info=client.statsTube("phone");
  50. for(Entry<String, String>entry:info.entrySet()){
  51. System.out.println(entry.getKey()+"---------->"+entry.getValue());
  52. }
  53. client.close();
  54. }
  55.  
  56. @Test
  57. @Ignore
  58. public void testStatusDefault(){
  59. ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
  60. client.useTube("default");
  61. Map<String, String> info=client.statsTube("default");
  62. for(Entry<String, String>entry:info.entrySet()){
  63. System.out.println(entry.getKey()+"---------->"+entry.getValue());
  64. }
  65. client.close();
  66. }
  67.  
  68. @Test
  69. @Ignore
  70. public void testStatus(){
  71. ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
  72. Map<String, String> info=client.stats();
  73. for(Entry<String, String>entry:info.entrySet()){
  74. System.out.println(entry.getKey()+"---------->"+entry.getValue());
  75. }
  76. client.close();
  77. }
  78.  
  79. @Test
  80. @Ignore
  81. public void testStatusListTube(){
  82. ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
  83. List<String> info=client.listTubes();
  84. for(String key:info){
  85. System.out.println(key);
  86. }
  87. client.close();
  88. }
  89.  
  90. @Test
  91. @Ignore
  92. public void testStatusListTubeWatch(){
  93. ClientImpl client=new ClientImpl("10.21.25.196",11300,true);
  94. client.watch("log");
  95. client.watch("phone");
  96. client.ignore("default");
  97. List<String> info=client.listTubesWatched();
  98. for(String key:info){
  99. System.out.println(key);
  100. }
  101. client.close();
  102. }
  103.  
  104. }

BeanstalkClient学习的更多相关文章

  1. 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代

    2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...

  2. Angular2学习笔记(1)

    Angular2学习笔记(1) 1. 写在前面 之前基于Electron写过一个Markdown编辑器.就其功能而言,主要功能已经实现,一些小的不影响使用的功能由于时间关系还没有完成:但就代码而言,之 ...

  3. ABP入门系列(1)——学习Abp框架之实操演练

    作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...

  4. 消息队列——RabbitMQ学习笔记

    消息队列--RabbitMQ学习笔记 1. 写在前面 昨天简单学习了一个消息队列项目--RabbitMQ,今天趁热打铁,将学到的东西记录下来. 学习的资料主要是官网给出的6个基本的消息发送/接收模型, ...

  5. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  6. Unity3d学习 制作地形

    这周学习了如何在unity中制作地形,就是在一个Terrain的对象上盖几座小山,在山底种几棵树,那就讲一下如何完成上述内容. 1.在新键得项目的游戏的Hierarchy目录中新键一个Terrain对 ...

  7. 《Django By Example》第四章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:祝大家新年快乐,这次带来<D ...

  8. 菜鸟Python学习笔记第一天:关于一些函数库的使用

    2017年1月3日 星期二 大一学习一门新的计算机语言真的很难,有时候连函数拼写出错查错都能查半天,没办法,谁让我英语太渣. 关于计算机语言的学习我想还是从C语言学习开始为好,Python有很多语言的 ...

  9. 多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类)

    前言:刚学习了一段机器学习,最近需要重构一个java项目,又赶过来看java.大多是线程代码,没办法,那时候总觉得多线程是个很难的部分很少用到,所以一直没下决定去啃,那些年留下的坑,总是得自己跳进去填 ...

随机推荐

  1. .Net程序猿玩转Android开发---(3)登陆页面布局

    这一节我们来看看登陆页面如何布局.对于刚接触到Android开发的童鞋来说.Android的布局感觉比較棘手.须要结合各种属性进行设置,接下来我们由点入面来 了解安卓中页面如何布局,登陆页面非常eas ...

  2. 关于apache下同IP多域名支持HTTPS和80跳转HTTPS的配置

    httpd-ssl的配置: Listen 443 NameVirtualHost *:443 AddType application/x-x509-ca-cert .crt AddType appli ...

  3. 3.RxJava详解

    一.RxJava 到底是什么 异步(取代AsyncTask/Handler/XXX/...?)   二.RxJava 好在哪   简洁(逻辑的简洁,.一步一走)   举例: 题目:将文件夹中的图片都取 ...

  4. PHP常用代码大全

    1.连接MYSQL数据库代码 <?php $connec=mysql_connect("localhost","root","root" ...

  5. MySQL FROM 子查询

    FROM 子句中的子查询 MySQL FROM 子查询是指 FROM 的子句作为子查询语句,主查询再到子查询结果中获取需要的数据.FROM 子查询语法如下: SELECT ... FROM (subq ...

  6. STM8S和STM8L调试串口中断的注意点

    1. STM8L串口中断注意点 在调试PM2.5传感器GP2Y1051的时候,发现在仿真的时候开始能够进行数据的接受,但是如果暂停之后就不能接受数据,其实只是接收了一次完整的数据. 问题程序 解决方法 ...

  7. CRT内存调试标记

    static unsigned char _bNoMansLandFill = 0xFD; /* fill no-man's land with this */ static unsigned cha ...

  8. [转]Windows环境下利用“共享内存”实现进程间通信的C/C++代码---利用CreateFileMapping和MapViewOfFile

    http://blog.csdn.net/stpeace/article/details/39534361 进程间的通信方式有很多种, 上次我们说了最傻瓜的“共享外存/文件”的方法. 那么, 在本文中 ...

  9. Oracle数据库之创建表结构

    Oracle数据库之创建表结构 主键与外键 主键:关系型数据库中的一条记录中有若干个属性,若其中的某一个属性组(可以是一个属性,也可以是多个)能唯一标识一条记录,那么该属性组就是主键. 外键:关系型数 ...

  10. 细说PHP优化那些事

    我们在用PHP编程的时候,总是想要使自己的程序占用资源最小,运行速度更快,代码量更少.往往我们在追求这些的同时却失去了很多东西.下面我想讲讲我对PHP优化的理解.优化的目的是花最少的代价换来最快的运行 ...