阿里云mqtt收费标准,第1张

以下是阿里云mqtt收费标准:

其中铂金版实例、标准版实例、轻量版实例是包年包月(预付费)。是一种预付费模式,即先付费再使用。一般适用于业务量较大且长期运行的场景,通过包年包月付费方式您可以提前预留资源,同时享受更大的价格优化,帮您最大程度节省成本。

还有就是按量付费实例是按量付费(后付费)。即是一种后付费模式,即先使用再付费。一般适用于业务流量波峰波谷差异明显或临时测试的场景,可以有效避免资源浪费。

消息队列mqtt版费用组成:

按量付费包括:同时在线连接数;消息收发量;订阅关系数

包年包月包括:连接数上限;消息TPS上限;订阅关系数上限

计价倍率介绍:

MQTT协议QoS=0且cleanSession=true 1

MQTT协议QoS=0且cleanSession=false 1

MQTT协议QoS=1且cleanSession=true 2

MQTT协议QoS=1且cleanSession=false 5

MQTT协议QoS=2且cleanSession=true 5

  1、 下载Apollo服务器,下载后解压,然后运行apache-apollo-16\bin\apollocmd,输入create mybroker(名字任意取,这里是根据 官网 介绍的来取的)创建服务器实例,服务器实例包含了所有的配置,运行时数据等,并且和一个服务器进程关联。

  2、create mybroker之后会在bin目录下生成mybroker文件夹,里面包含有很多信息,其中etc\apolloxml文件下是配置服务器信息的文件,etc\usersproperties文件包含连接MQTT服务器时用到的用户名和密码,后面会介绍,可以修改原始的admin=password,可以接着换行添加新的用户名密码。

  3、打开cmd,运行…apache-apollo-16\bin\mybroker\bin\apollo-brokercmd run 开启服务器,可以在浏览器中输入 http://127001:61680/ 查看是否安装成功,该界面展示了topic,连接数等很多信息。

  经过上面的简单步骤,服务器基本上就已经完成,下一篇将介绍Android客户端的编写和注意事项。

  客户端使用的API,开始我使用的是mqtt-client,使用过后发现问题百出,不能很好的满足要求,后来使用了官方推荐的 Eclipse Paho ,下面开始客户端代码的编写,为了方便测试这里有android和j2se两个工程:

  1、新建android工程MQTTClient

  2、MainActivity代码如下:

  [java] view plaincopyprint

package ldwmqttclient;

import javautilconcurrentExecutors;

import javautilconcurrentScheduledExecutorService;

import javautilconcurrentTimeUnit;

import orgeclipsepahoclientmqttv3IMqttDeliveryToken;

import orgeclipsepahoclientmqttv3MqttCallback;

import orgeclipsepahoclientmqttv3MqttClient;

import orgeclipsepahoclientmqttv3MqttConnectOptions;

import orgeclipsepahoclientmqttv3MqttException;

import orgeclipsepahoclientmqttv3MqttMessage;

import orgeclipsepahoclientmqttv3persistMemoryPersistence;

import androidappActivity;

import androidosBundle;

import androidosHandler;

import androidosMessage;

import androidviewKeyEvent;

import androidwidgetTextView;

import androidwidgetToast;

public class MainActivity extends Activity {

private TextView resultTv;

private String host = "tcp://127001:1883";

private String userName = "admin";

private String passWord = "password";

private Handler handler;

private MqttClient client;

private String myTopic = "test/topic";

private MqttConnectOptions options;

private ScheduledExecutorService scheduler;

@Override

protected void onCreate(Bundle savedInstanceState) {

superonCreate(savedInstanceState);

setContentView(Rlayoutmain);

resultTv = (TextView) findViewById(Ridresult);

init();

handler = new Handler() {

@Override

public void handleMessage(Message msg) {

superhandleMessage(msg);

if(msgwhat == 1) {

ToastmakeText(MainActivitythis, (String) msgobj,

ToastLENGTH_SHORT)show();

Systemoutprintln("-----------------------------");

} else if(msgwhat == 2) {

ToastmakeText(MainActivitythis, "连接成功", ToastLENGTH_SHORT)show();

try {

clientsubscribe(myTopic, 1);

} catch (Exception e) {

eprintStackTrace();

}

} else if(msgwhat == 3) {

ToastmakeText(MainActivitythis, "连接失败,系统正在重连", ToastLENGTH_SHORT)show();

}

}

};

startReconnect();

}

private void startReconnect() {

scheduler = ExecutorsnewSingleThreadScheduledExecutor();

schedulerscheduleAtFixedRate(new Runnable() {

@Override

public void run() {

if(!clientisConnected()) {

connect();

}

}

}, 0 1000, 10 1000, TimeUnitMILLISECONDS);

}

private void init() {

try {

//host为主机名,test为clientid即连接MQTT的客户端ID,一般以客户端唯一标识符表示,MemoryPersistence设置clientid的保存形式,默认为以内存保存

client = new MqttClient(host, "test",

new MemoryPersistence());

//MQTT的连接设置

options = new MqttConnectOptions();

//设置是否清空session,这里如果设置为false表示服务器会保留客户端的连接记录,这里设置为true表示每次连接到服务器都以新的身份连接

optionssetCleanSession(true);

//设置连接的用户名

optionssetUserName(userName);

//设置连接的密码

optionssetPassword(passWordtoCharArray());

// 设置超时时间 单位为秒

optionssetConnectionTimeout(10);

// 设置会话心跳时间 单位为秒 服务器会每隔1520秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制

optionssetKeepAliveInterval(20);

//设置回调

clientsetCallback(new MqttCallback() {

@Override

public void connectionLost(Throwable cause) {

//连接丢失后,一般在这里面进行重连

Systemoutprintln("connectionLost----------");

}

@Override

public void deliveryComplete(IMqttDeliveryToken token) {

//publish后会执行到这里

Systemoutprintln("deliveryComplete---------"

+ tokenisComplete());

}

@Override

public void messageArrived(String topicName, MqttMessage message)

throws Exception {

//subscribe后得到的消息会执行到这里面

Systemoutprintln("messageArrived----------");

Message msg = new Message();

msgwhat = 1;

msgobj = topicName+"---"+messagetoString();

handlersendMessage(msg);

}

});

// connect();

} catch (Exception e) {

eprintStackTrace();

}

}

private void connect() {

new Thread(new Runnable() {

@Override

public void run() {

try {

clientconnect(options);

Message msg = new Message();

msgwhat = 2;

handlersendMessage(msg);

} catch (Exception e) {

eprintStackTrace();

Message msg = new Message();

msgwhat = 3;

handlersendMessage(msg);

}

}

})start();

}

@Override

public boolean onKeyDown(int keyCode, KeyEvent event) {

if(client != null && keyCode == KeyEventKEYCODE_BACK) {

try {

clientdisconnect();

} catch (Exception e) {

eprintStackTrace();

}

}

return superonKeyDown(keyCode, event);

}

@Override

protected void onDestroy() {

superonDestroy();

try {

schedulershutdown();

clientdisconnect();

} catch (MqttException e) {

eprintStackTrace();

}

}

}

  由于项目需要,我用到了心跳重连。根据 这里 的解释设置apolloxml,主要有设置主机连接的地址。另外,options还有个setWill方法,如果项目中需要知道客户端是否掉线可以调用该方法。

MQTT通信协议的基本介绍参考文章 NT35 MQTT通信 ,本篇给出阿里云的基本操作,NT35E通过订阅阿里云的主题&发布信息与阿里云平台相互通信。

登录阿里云 → 工作台 → 物联网平台 → 进入控制台→ 公共实例

阿里云默认通信协议为MQTT,不需要特殊选择,用户按照如下步骤创建自己的产品:

创建产品 → 添加设备 

在"查看"标签中,包含了MQTT连接的基本三元组信息,也就是后面设备要填充的基本参数

      用户每定义一类产品都会自动生成对应的Topic列表,当然我们也可以"自定义Topic"便于自己测试。

       指令解析参考《Lierda NT35E&NT26E-CN AT命令手册》,这里给出使用到的AT指令对应参数说明以便于理解。

AT+LMQTTCFG=cloud,<tcpconnectID>[,<cloud _ type>,<data_type > ]

<tcpconnectID> 。MQTT Socket 标识符。范围:0~4。

<cloud_type>整型。2 alibaba,其他参数指定其他平台

<data_type>整型。阿里云平台 1 json数据 

AT+LMQTTCFG="cloud",0,2,1   对应就是对接阿里云平台,发送json格式的数据

AT+LMQTTCFG=aliauth,<tcpconnectID>[,<product_key>,<device_name>,<device_secret>]

填充阿里云平台中设备的三元组信息

AT+LMQTTCFG="aliauth",0,"a1JszCpjS61","NT35E_06011","390358fc595040aa73221e8393aba86c"

这部分是模组进行TCP链路连接(需抓包确认)

AT+LMQTTOPEN=<tcpconnectID>,<host_name>,<port>

host_name对应阿里云 "设备信息"→"MQTT连接参数" 中的 "mqttHostUrl"

AT+LMQTTOPEN=0,"a1JszCpjS61iot-as-mqttcn-shanghaialiyuncscom",1883

模组作为客户端,通过MQTT协议连接到服务器(需抓包确认)

AT+LMQTTCONN=<tcpconnectID>[,<clientID>[,<username>[,<password>]]]

<clientID>字符串型。客户端标识符。用户可以随便定义。 <username>,<password> 不需要填写

AT+LMQTTCONN=0,"NT35E"

AT+LMQTTSUBUNSUB=<tcpconnectID>,<subflag>,<msgID>,<topic1>[,<qos1>[,<topic2>[,<qos2>]d…]]

<subflag>整型。消息类型 0 订阅 1 取消订阅

<msgID>整型。数据包消息标识符。范围:0~65535。

<topic>带双引号的字符串型。客户端订阅或者退订的主题。长度范围:0~256 字节。

<qos>整型。客户端发送订阅消息(SUBSCRIBE)的 QoS 等级,此时为必选参数。2 正好一次,该主题下的消息确保接收端仅接收到一次

AT+LMQTTSUBUNSUB=0,0,1,"/a1JszCpjS61/ NT35E_06011 /user/COMMUTEST",2

这里注意<topic>对应参数的替换,里面的deviceName需要替换。

订阅主题之后,服务器下发的数据模组就可以正常接收了。模组下发位置

       发布消息在对应的设备目录下,如果有设备"订阅"对应的消息,平台"发布"相应的数据设备就可以接收到了。

AT+LMQTTPUB=<tcpconnectID>,<msgID>,<qos>,<retain>,<topic>,<msglen>,<msg>

<msgID>整型。 0~65535。任意定义,但<qos>=0 时,该参数值只能为0。

<qos>整型。 0 最多一次 1 至少一次 2  正好一次

<retain>整型 。服务器是否保存该消息。0 不保存  1 保存

<topic>带双引号的字符串型。 客户端发布消息的主题。长度范围:0~256 字节

<msglen>整型 。指定的消息数据长度。范围:0~1460。

<msg>字符串型。 需要发布的消息数据。

AT+LMQTTPUB=0,0,0,1,"/a1JszCpjS61/ NT35E_06011 /user/COMMUTEST",10,"1122334455"

       注意刚刚自己创建的主题属性是" 发布和订阅 ",所以模组发送该主题的信息,阿里云也是可以收到的

注意这里模组发送数据的时候,也推送了自己发送的数据,因为刚刚订阅了这个主题,所以模组订阅(收)到了对应的数据

       前面我们通过NT35E与平台进行信息交互,那么为什么是这样填写对应的参数呢,每个参数对应的说明在阿里云上是什么样的呢,用户可以查看阿里云的<帮助文档>进行确认。

       上面我们使用三元组的方式( 一机一密 )实现NT35E与阿里云平台通信,但实际生产过程中该方式不好实现,比如工厂有1000个设备生产,如果每个设备都复制不同的三元组,很难实现工厂批量化生产,此时可以通过 一型一密 的通信方式解决该问题。

一型一密模组端实现方式后续更新。

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » 阿里云mqtt收费标准

0条评论

发表评论

提供最优质的资源集合

立即查看 了解详情