29. Apache apollo

一. 简介

引用其他文章:

Apache Apollo是一个代理服务器,其是在ActiveMQ基础上发展而来的,可以支持STOMP, AMQP, MQTT, Openwire, SSL, and WebSockets 等多种协议。

Apollo允许客户端通过开放的MQTT协议连接。该协议主要是用在资源有限的驱动上,以及网络不稳定的情况下使用,是一个订阅、发布模型。这种驱动通常不适用类似http,stomp这类基于文本,或者类似openfire,AMQP等传统二进制协议。MQTT是一个简介的二进制协议,适用这类驱动资源受限,而且是不稳定的网络条件下。之前的稳定发布版本中,MQTT是作为一个Apollo的一个插件提供的。但是现在,这个插件已经变为开发项目的一部分。MQTT在Apollo中已经不需要其他配置文件或者是第三方插件支持了。
MQTT是一个线路层的协议,任何实现该协议的客户端都可以连接到Apollo。当然也可以整合其他MQTT兼容的消息代理中。

二. Mac下apollo安装

1.下载

apollo下载以及源代码下载

2.解压

3. 添加环境变量

APOLLO_HOME=解压目录

4. 新建broker目录,最好不要跟APOLLO_HOME一致,便于以后升级

5. 创建broker

1. cd broker目录

2. ${APOLLO_HOME}/bin/apollo create mybroker

注意windows下命令可能不同,应该可以直接把apollo.bat拖过来执行。

执行完之后,应该会提示怎么运行:

You can now start the broker by executing:
"/Users/huangrongwei/Documents/1_work_project/apache_apollo/apollo_broker/mybroker/bin/apollo-broker" run

Or you can run the broker in the background using:

"/Users/huangrongwei/Documents/1_work_project/apache_apollo/apollo_broker/mybroker/bin/apollo-broker-service" start

6. 运行broker

按照上面的提示,选择一个运行。第一个是前台运行,就是会占用你的命令行,不会退出。

下面一个命令是后台运行。

7.查看apollo进程

ps -elf | grep apollo

结果如下;

501  5418  5361     400e   0  31  0  5048532 125212 -      S+                  0 ttys006    2:00.45 apollo -ea -serv  1:27下午

8. 浏览器查看结果

http://127.0.0.1:61680/ 或者 https://127.0.0.1:61681/

第一个是http的,后面一个是https的。

默认登录的用户名是admin/password,这样就可以看到apollo的管理界面。

三. 客户端测试apollo

在apollo的解压文件夹里面有个example文件夹,里面有个mqtt->java

用eclipse导入这个maven工程(eclipse->file->import->maven project),注意可能需要安装maven eclipse插件

然后里面有个Listener.java和Publisher.java,可以订阅和发布消息。直接右击->Run as java application启动起来。

然后看输出结果。

Listener.java最后会输入下面的消息。表示1万条消息接受花费了0.93秒

Received 0 messages.
Received 1000 messages.
Received 2000 messages.
Received 3000 messages.
Received 4000 messages.
Received 5000 messages.
Received 6000 messages.
Received 7000 messages.
Received 8000 messages.
Received 9000 messages.
Received 10000 in 0.93 seconds

四. 其他

1. curl访问apollo

curl -u "admin:password" http://localhost:61680/broker.json

结果{"id":"default","state":"STARTED","state_since":1499318856654,"version":"1.7.1","home_location":"/Users/huangrongwei/Documents/1_work_project/apache_apollo/apache-apollo-1.7.1","base_location":"/Users/huangrongwei/Documents/1_work_project/apache_apollo/apollo_broker/mybroker","jvm_metrics":{"heap_memory":{"used":23072848,"alloc":79691776,"max":954728448},"non_heap_memory":{"used":71784880,"alloc":74203136,"max":-1},"classes_loaded":7893,"classes_unloaded":0,"threads_current":27,"threads_peak":32,"os_arch":"x86_64","os_name":"Mac OS X 10.12.4","os_memory_total":8589934592,"os_memory_free":60743680,"os_swap_total":0,"os_swap_free":1073741824,"os_fd_open":135,"os_fd_max":6250,"os_load_average":2.90869140625,"os_cpu_time":128597245000,"os_processors":4,"runtime_name":"[email protected]","jvm_name":"Java HotSpot(TM) 64-Bit Server VM 1.8.0_131 (Oracle Corporation)","uptime":14200613,"start_time":1499318843487},"current_time":1499333764968,"virtual_hosts":["mybroker"],"connectors":["tcp","tls","ws","wss"],"connection_counter":16,"connected":0,"messages_sent":80008,"messages_received":70007,"read_counter":19251413,"write_counter":22040503}

时间: 2024-08-27 03:29:59

29. Apache apollo的相关文章

MQTT协议之 Apache Apollo服务

一.说明 MQTT是IBM开发的一个即时通讯协议,有可能成为物联网的重要组成部分.该协议支持所有平台,几乎可以把所有联网物品和外部连接起来,被用来当做传感器和致动器(比如通过Twitter让房屋联网)的通信协议. Apache Apollo是一个代理服务器,其是在ActiveMQ基础上发展而来的,可以支持STOMP, AMQP, MQTT, Openwire, SSL, and WebSockets 等多种协议. 总结来说MQTT只是一种消息推送的协议目前(2016/1/13)为V3.1版本,而

Apache Apollo 1.7.1的学习

查看原文:http://wenku.baidu.com/link?url=erY5oLQQ40WxBycTDz5yWGQRBxg7MpALGKtwzYy70Dl1X5PEmsW9moN7N2Ti-s6WedjdkMqn0sny2JfsmrZ0KGZCFP81m0NO3DnNVW38ZHK

如何解决Apache无法启动的问题

今天重装xampp后,一直无法启动Apache,提示以下错误: 22:36:54 [Apache] Attempting to start Apache app...22:36:54 [Apache] Status change detected: running22:36:55 [Apache] Status change detected: stopped22:36:55 [Apache] Error: Apache shutdown unexpectedly.22:36:55 [Apach

kali中安装apache和CGI

Apache 中的提交了一种利用扩展应用程序执行动态网页的机制. 称为Common Gateway Interface (通用网关接口)简称CGI. 安装apache 首先到apache的主页下载最新版本的apache http server,地址为 http://httpd.apache.org/ 本文写于2006.4.29,apache版本为2.2.0 .如果你也想用这一个版本的话请点击:http://mirror.vmmatrix.net/apache/httpd/httpd-2.2.0.

30.apollo源代码在mac下编译

一. Apollo简介 Apache Apollo是一个代理服务器,其是在ActiveMQ基础上发展而来的,可以支持STOMP, AMQP, MQTT, Openwire, SSL, and WebSockets 等多种协议. 官网链接 自己使用Apollo主要是用它做mqtt服务器. 二. 源代码下载 代码下载编译官方指导 使用svn checkout代码: svn co http://svn.apache.org/repos/asf/activemq/activemq-apollo/trun

ansible中角色和模板使用及部署lamp平台

一.roles ansilbe自1.2版本引入的新特性,用于层次性.结构化地组织playbook.roles能够根据层次型结构自动装载变量文件.tasks以及handlers等.要使用roles只需要在playbook中使用include指令即可.简单来讲,roles就是通过分别将变量.文件.任务.模块及处理器放置于单独的目录中,并可以便捷地include它们的一种机制.角色一般用于基于主机构建服务的场景中,但也可以是用于构建守护进程等场景中. 一个roles的案例如下所示:        si

大数据:从入门到XX(二)

想了解APACHE 项目是怎么分类,又或者想了解APACHE项目是用什么语言开发的,直接访问APACHE官网中的By Category和By Programming Language就可以了,但是如果想同时看到每个 项目的分类信息和开发语言,看看下面这张表就可以了.有几个小调整需要说一下: 1.原始数据中JavaScript.Javascript:NODE.JS.NODE.js都当作两种语言了(大小写不一致),在这张表里做了合并. 2.原始数据中有67个项目没有LANGUAGE相关的描述,在这张

(转)Three challenges you’re going to face when building a chatbot

转自:https://blog.infermedica.com/three-challenges-youre-going-to-face-when-building-a-chatbot/ Three challenges you're going to face when building a chatbot Adam Radziszewski on Dec. 01, 20166 min read Developing your own chatbot? You're likely to mee

[1] MQTT,mosquitto,Eclipse Paho----入门

MQTT,mosquitto,Eclipse Paho这三个单词陌生而又神秘.那么这三个单词究竟是什么意思,代表了什么技术,他们之间有关联吗?不着急,请听笔者慢慢给大家分享. (1)MQTT(英语全称,Message Queue Telemetry Transport),中文翻译过来就是遥测传输协议:其主要提供订阅/发布模式,更为简约.轻量,易于使用,针对受限环境(带宽低.网络延迟高.网络通信不稳定),属于物联网(Internet of Thing)的一个传输协议.具体协议内容,请参考:http