文档章节

【阿里云产品公测】消息队列服务MQS java SDK 机器人应用初体验

阿里云官方博客
 阿里云官方博客
发布于 2014/10/15 14:31
字数 2587
阅读 43
收藏 1

【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>

【阿里云产品公测】消息队列服务MQS java SDK 机器人应用初体验

作者:阿里云用户啊里新人


初体验 之 测评环境 

       由于MQS支持外网访问,因此我在本地做了一些简单测试(可能有些业余),之后使用mqs应用到我的程序中在阿里的ecs中运行。

先上一张图这是初体验结果

 

     

开始正文                    


        本地模式

                          

       网络环境

 
    阿里云服务器环境

     


初体验 之 准备测试

首先就是阅读一下阿里的文档,以及介绍这个事必要的,磨刀不误砍柴工功么!建议大概的通读一下,然后可以将入门指南仔细看一下,里面包含了详细的操作,以及一些demo,包括界面上的操作,和java,Python的。可以让你很快的上手。

 

MQS基本概念 
MQS功能和特点 
MQS安全和可靠性 
MQS限制与局限 
MQS服务访问和地域 
MQS API&SDK 
MQS使用指南 
  
通读之后有几点我提一下 
1,MQS是支持外网访问的,这意味着你即使不是阿里的服务器也可以使用MQS
 
2,MQS的保留时间最长15天
 
3,消息最长64KB
 
4,队列个数和消息个数没有限制(不知道公测之后会怎么计算)
 
5,消息不保证按照生产的先后顺序被消费,(因为是集群的,只是保证优先)
    


 初体验 之 本地基础测试  

用了大概一下午的时间看阿里提供的所有帮助和文档,在脑海里基本有了一个印象,提供一套http的api,并提供几个版本的sdk,我就选择的顺手的java sdk测试了。
 
这里要说的是大家可以在入门指南中看到有示例代码。如果不是细心看完所有的文档,这里可能会让初接触者有些不容易找到sdk和示例代码之间的关系。关于这点稍后再说。
 
测试内容
1,外网消息生产速度
2,外网消息消费速度
3,定时消息延迟情况
4,消息的先后消费情况
测试基于javasdk,直接循环发送10000调消息,求平均时间
最终的测试结果为
发送消息测试10000调
发送时间538639毫秒,不到九分钟,平均18.58条/每秒
获取消息10000调
361956s         约6分钟,平均27.62 条/每秒
获取消息并删除  
729420s    约12.157 分钟   平均 平均 13.7条
以上数据看来,get消息要比put消息快一些,
以上测试都是单线程测试。
一个生产者,四个消费者,同时开始工作,定时10s   另外对定时消息做了一个测试,测试的过程依然是10000调消息,
平均时间在11s接收并消费成功,四个消费者的消费个数也在2500左右, 下面两张是运行最后的截图,(秒级别的消息提醒已经满足我的应用需求,稍后的应用会用到。这里还是比较开心的解决了我的一个一直想做的小功能。)

本地基本上就做这些测试都是基于外网访问,相信如果放在ecs之后内网访问效率会更高!,然后就准备进入实战阶段了。嵌入我的应用,应用才是王道。                     

 MQS初体验 之 应用实战 

我的应用比较特殊,是个小机器人,提供一些公共服务,比如天气,歌词,成语学习,小游戏。本次的测试想通过mqs的定时消息,实现一些生活中的小提醒功能。   
 
就拿我本程序猿来说,公司的上班时间是弹性制的,但是每次快到下班的时候总是忘记了具体是什么时候到公司的,要不需要问前台,(不太合适吧?嘿嘿),还有个办法就是看开机时间这个也差不了多少,但是看开始时间还是需要个cmd,或者我的电脑看启动日志,或者任务管理器看,(不过这里我总是觉得不太准)。如果这时候,当我到下班时间直接有个qq消息告诉我可以走了。是不是就爽了很多哈哈

先展示一下目前的实现

 由于时间的原因,目前还不成熟,文案也有一点小问题,不过定时消息结合mqs的架构已经基本实现,慢慢把MQS用起来,改进一下,实现我的目标,(我的目标是用我的代码服务的我生活。)  
   
下面说一下实现,我使用的javaSDK版本,其实很简单,如果仔细看就会发现在入门教程中是有demo的,我刚看一些文档的时候还抱怨没有教程,在我看完所有帮助文档说明之类的之后总算是看到了,(这里稍后有话要说)  
 
首先建议通读一下 入门指南  然后去下载sdk,  
这里阿里有说明如果是 maven环境很简单,只需要在项目的pom.xml 添加 代码即可。相应的依赖包就可以加载进来,   

复制代码

我使用的不是maven环境,这里也有全部依赖包的打包下载  传送门    
然后解压到项目就可以了,这里我就遇到一个坑,我的源码使用了和mqs的包有重叠,并且版本冲突。我哭了,没办法,只要修改了源码。(不多说都是泪)  

Java的sdk对队列的操作都做了基本的封装。以下将常用的代码列一下,  

Mqs 的客户端实例化
很简单只需要提供一个访问地址,以及你己的应用key,secret   

复制代码

首先就是创建一个队列

复制代码

这里创建队列方法返回的是队列访问地址,例如
http://iveo7.mqs-cn-qingdao.aliyuncs.com/dddddd  获取消息队列列表

复制代码

结果

http://iveo7.mqs-cn-qingdao.aliyuncs.com/MyQueue

http://iveo7.mqs-cn-qingdao.aliyuncs.com/dddddd 修改队列属性

复制代码


获取队列属性  

复制代码

 
删除队列  

复制代码

 
发送消息  

复制代码

 
获取消息  

复制代码

 
删除消息  

复制代码

 
查看消息
并不会改变消息的状态,即被 PeekMessage 获取消息后消息仍然处于 Active 状态,仍然可被查看或消费

复制代码

 
修改消息不可见时间  

复制代码

以上代码包括了api的基本操作。  

 初体验 之 总结

目前我的小机器人已经使用了mqs的消息队列,总而言之,Sdk封装后,接口使用简单,只需要了解了接口的概念,和设一下方法的参数就可以很快的上手。不过建议使用者将先关的文档全部通读一下,也没有多少。  
另外就是sdk建议对方法加上描述,和参数说明,或者提供一个文档,不然刚入还需要看一下源码,对一些方法只能根据名字猜测。
现在只是应用了mqs的延时消息做定时任务类题型,其实mqs还可以做很多事情 例如
定时消息(延迟服务)
      目前小机器人就是使用的定时消息。
多个应用之间的通信(外网访问,内网多应用)
      之后机器人会实现多渠道通信功能,比如网页发送qq题型消息,或者公告类消息。(已经在计划中
公告类消息推送
      mqs运行一个消息被多次消费,或者说查看。那么就可以作为公告类的消息通道来使用,一条公告被多个消费者查看。(可能会考虑这么干
任务执行类型消息(并且是有优先级的)
       很多应用需要在后台去执行不同的任务,通过MQS可以将任务执行和应用分离,并且按照优先级去执行。让你的应用功能解耦。单独的任务执行功能从 MQS 获取任务,然后去执行。这个记得之前做个一个采集类项目为了突破防采集就是使用这个原理干的,不过那时候还没有 MQS ,使用的是 MQ.
 
目前想到的使用场景,也许大家有更多的使用方式和场景,快来试试吧

初体验 之 建议&意见

1,文档有些乱,比如入门指南,和sdk没有很好的说明关联,最一开始都不知道入门指南里面的代码是sdk的。    

--建议已记录

2,sdk的方法都没有说明,只能是根据入门指南的一些代码查看,另外看到sdk其实还提供一些别的方法,但是没有说明,只能去看源码了。  
-- 主要是有Api Reference文档
3,mqs控制台的消息和api的消息是不通的,我在控制台添加的消息在api获取到是乱码,在通过api添加的消息在控制台看到的也是加密之后的。这点不知道是什么原因,还望阿里工程狮看看。如果这里不互通,感觉页面上添加消息接口也没有什么意义。
--建议已记录



最后,特大字号告诉坚持读到这的你一个秘密,原来sdk的jar解压之后竟然有源码。。。。悲催的我自己弄了半天,原来有源码。。。。

 
原文地址:http://bbs.aliyun.com/read/179171.html   
微博互动:http://weibo.com/1644971875/BrFjWoX3I?ref=#_rnd1413352813344 
参加活动:http://promotion.aliyun.com/act/aliyun/freebeta/ 


© 著作权归作者所有

阿里云官方博客
粉丝 206
博文 2332
码字总数 5560474
作品 0
杭州
程序员
私信 提问
阿里云物联网平台设备端开发样例

1. 创建产品 2. 添加设备 3. 创建规则 4. 编写SQL 5. 消息队列MQ:创建Topic 6. 规则引擎-添加操作 7. 启动规则引擎 8. 运行MQTT客户端 [1] 访问地址:阿里云物联网平台 > 设备端开发指南 > ...

shoen
2018/08/24
0
0
阿里云新版人脸识别 Python 使用示例教程

概述 前面分别介绍了新版人脸识别服务接口的开通、JAVA SDK对通用人脸识别通用方法的调用、C# SDK使用方法及1:N人脸识别接口的调用,可以参考阿里云人脸识别公测使用说明、阿里云人脸识别 1:...

taro_秋刀鱼
2019/07/25
0
0
阿里云新版人脸识别 C# 使用示例教程

概述 前面分别介绍了新版人脸识别服务接口的开通、JAVA SDK对通用人脸识别通用方法的调用及1:N人脸识别接口的调用,可以参考阿里云人脸识别公测使用说明与阿里云人脸识别 1:N 使用简明示例,...

taro_秋刀鱼
2019/07/23
0
0
如何提高阿里云上应用的可用性(一)

如今,开发并上线一款应用十分方便。因为云计算提供了从最基础的计算资源如服务器网络、数据库服务、中间件PaaS平台到各种应用支撑的云管理服务,同时开源社区的迅猛发展也提供了从数据库、缓...

阿里云云栖社区
2018/11/08
46
0
【阿里云一周要闻】阿里云数据库位列全球第三;《Java开发手册》正式发布;阿里云CDN实现毫秒级全网刷新

---------------------------------【一周要闻】--------------------------------- 突破!阿里云CDN实现毫秒级全网刷新 【阅读详情】 阿里云CDN技术团队进行大量协议优化与实践,最终达成突...

信雪蕊
2019/07/01
0
0

没有更多内容

加载失败,请刷新页面

加载更多

dynamic-connectivity 动态连通性问题之 quick-union 算法

quick-union 的思想是:若对象 p 的 root_id 和对象 q 的 root_id 相等,则认为 p 和 q 连通。 若要将对象 p 和对象 q 连通(已知两对象未连通),则将 p 的 root_id 的值设为 q 的 root_id ...

Phpythoner_Alei
今天
40
0
OSChina 周六乱弹 —— 实在选不出来就唱国歌

Osc乱弹歌单(2020)请戳(这里) 【今日歌曲】 @花间小酌 :#今日歌曲推荐# 分享阿冗的单曲《你的答案》。--祝大家在2020年都找到自己答案。 《你的答案》- 阿冗 手机党少年们想听歌,请使劲...

小小编辑
今天
25
1
Maven打包可执行Jar包的方法

在使用Java开发中,会使用到将工程打包成可执行的jar包的情况,那么在maven中怎么将项目中的依赖包都添加到jar中呢。在pom.xml中添加一下插件: <build><plugins><plugin><ar...

CapJes
今天
13
0
使用vue 开发地图类系统(openlayers.js)的注意。

使用vue 开发地图类系统的注意。 1、使用地图应该创建的对象 少使用 vue 的data 和计算属性(comments)存数据或是vuex。 为什么要要注意这个问题呢? 答:这个就要了解到vue的实现原理 。原理...

DY-Tao
昨天
10
0
web移动端学习:高德地图demo(一)

在高德地图开发中申请开发者资格,然后在控制台中新建应用,获得KEY; 新建模板HTML文件; <!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>地图demo</title><scri......

dxiya
昨天
10
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部