如何在 Windows Server 2022 阿里云服务器上搭建自己的 MQTT 服务器之一Apache-Apollo服务器。

如何,windows,server,阿里,服务器,搭建,自己,mqtt,之一,apache,apollo · 浏览次数 : 1455

小编点评

**使用MQTT工具访问MQTT服务器** **安装** 1. 下载并安装MQTT.fx版本1.7.1 2. 下载并安装apache-apollo管理平台 **配置** 1. 在config.properties中配置MQTT代理服务器的地址和端口号 2. 在config.properties中配置MQTT代理服务器的用户名和密码 3. 在config.properties中配置MQTT代理服务器的主题名称 4. 在config.properties中配置MQTT代理服务器的订阅主题名称 **测试** 1. 在MQTT.fx中测试连接到MQTT代理服务器 2. 在MQTT.fx中测试发布和订阅消息 3. 在控制台中查看MQTT代理服务器的链接状态 4. 测试其他功能,如订阅、发布、主题测试等 **总结** 完成MQTT工具访问MQTT服务器的测试,可以验证MQTT代理服务器的连接状态、发布和订阅消息、主题测试等功能。

正文

一、简介
    最近,在做一个项目的时候,需要在线管理网络继电器,以前也做过硬件的项目,但是这样的项目不多。现在我想实现一个在线可以接受网络继电器发送的信号,也可以向网络继电器发送命令,控制其的运行。这个功能的实现需要物联网的支持,我在咨询了网络继电器卖家,想要在线实现网络硬件的管理有三种解决方案。
    第一种:由于我买的是阿里云的服务器,可以在买阿里云的IOT组件,而且提供了全部功能,提供优化的接口,硬件、网络的管理和维护都不用关心,但是费用不菲。
    第二种:如果公司内部有特牛的 TCP/IP 软件工程师的话,可以自己写一套出来,但是这个开发过程、调试过程、维护过程等,周期比较长,这样的人也不好找,性价比不高。
    第三种:可以自己在云服务器上搭建MQTT服务器,通过其组件实现在线管理,这种方案总体来说,性价比最高。
    我选择的是第三种解决方案,我已经在云服务器上搭建了自己的MQTT服务器,硬件之间也可以实现管理了,我今天就把过程记录下来,以防以后使用的时候到处乱找,而且网上的有的也不是很全和很详细,如果大家有需要,也可以直接使用。我写的很详细,小白照着做都没有问题,高手就略过吧。

    我的搭建环境如下:
        云平台:阿里云平台
        操作系统:Windows Server 2022 Datacenter
        机器内存:8.00 GB (7.73 GB 可用)
        系统类型:64 位操作系统, 基于 x64 的处理器
        MQTT服务器:Apache-Apollo
        MQTT客户端:MQTT.fx

    IOT初次接触,当然了,很多相关的工具也是初始使用,使用不好,大家不要见笑。

二、配置详情
    想要安装 Apache-Apollo,必须安装他的运行时,因为它是用Java 写的,当然需要安装 Java 的运行环境,下载 JDK,直接安装就可以,很简单,没什么可说的。安装完成,也要配置环境变量,否则我们不能直接在 cmd 命令行终端种使用其命令。话不多说,直接开始。

    1、由于 Apache-Apollo 的运行需要使用 Java 的运行环境,第一个必须先下载 JDK。
        1)、下载 JDK 安装程序,我贴了两个地址,都可以直接下载。
            
地址1:https://www.java.com/zh-CN/   ,
            地址2:https://www.oracle.com/cn/java/technologies/downloads/#java8-windows

            

            点击两次才到真正下载页面。

            

              下载到本地的文件,我下载两个,一个是 JDK,一个是 JRE,大家只下载一个就好。

              

        2)、安装JDK步骤没有什么可说的,直接下一步就可以,根据自己的需求更改就可以。
            1】、第一步要先安装好JDK的运行环境, 点击jdk-8u271-windows-x64安装包,点击运行后弹出下列界面,点击下一步
                
            2】、 我把安装包放在了自定义目录下,好多国外软件安装路径出现中文或空格都会出现错误,所以我为了避免这种情况 安装国外软件的时候路径都不包含中文和空格,选择默认路径也可以。
                
        3)、配置Java环境变量
            1】、配置系统的环境变量
                 

                          
                      右键”计算机” => ”属性” => ”高级系统设置” => ”高级” => “环境变量” => “系统变量”。

            2】、新建:

                 变量名:JAVA_HOME

                 变量值:D:\program files\Java\jdk-1.8【具体要根据你自己的安装路径,我的是安装在D盘的】
                 


            3】、新建:

                 变量名:CLASSPATH

                 变量值:%JAVA_HOME%/lib/dt.jar;%JAVA_HOME/%/lib/tools.jar

                 


            4】、添加:找到PATH变量,选择编辑。
                 把  %JAVA_HOME%\bin;%JAVA_HOME%\jre\bin 添加到”变量值”的结尾处。
                 

           5】、确保电脑安装了Java 运行时环境 JRE 或者 JDK ( version >=1.7 )
                 在命令窗口中,输入java命令:java -version,回车,如果出现版本信息,说明安装成功。

                                     

    2、下载、配置 Apollo 服务器。
        1)、先上 Apollo 服务器的下载地址。
           
地址1:https://pan.baidu.com/s/1-tU9P5srKiM3P1Vy10eOQg 百度网盘下载地址(目前有效,不知是否一直有效
              提取码:e5l0
              (包含apache-apollo-1.7.1-windows-distro、jdk-8u271-windows-i586、jdk-8u271-windows-x64)

            地址2:http://archive.apache.org/dist/activemq/activemq-apollo/1.7.1/

            

        2)、 在CMD下输入 apollo.cmd create mqttServer,显示创建完成如下
             下载Apollo服务器并解压,在apache-apollo-1.7.1\bin的路径栏输入cmd运行,这种方式便于测试,如果想正常使用,安装为 Windows 服务。

            

            
            成功创建文件夹。
            

        3)、配置 apollo.xml 文件。
            
在 apache-apollo-1.7.1\bin\mqttServer\etc 目录下,其中 apollo.xml 是配置文件,再次强调一下,如果想要在外网访问,必须把以前的127.0.0.1 改成 0.0.0.0 ,如果是云服务器,通过网站访问就是:http://云服务器公网IP:61680/console/index.html,如果是通过MQTT客户端访问:云服务器公网IP:61613,我第一次就配置成了通过 IPconfig 命令获取的地址了,总是不通

            
 1 <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
 2 <!--
 3   Licensed to the Apache Software Foundation (ASF) under one or more
 4   contributor license agreements. See the NOTICE file distributed with
 5   this work for additional information regarding copyright ownership.
 6   The ASF licenses this file to You under the Apache License, Version
 7   2.0 (the "License"); you may not use this file except in compliance
 8   with the License. You may obtain a copy of the License at
 9   http://www.apache.org/licenses/LICENSE-2.0 Unless required by
10   applicable law or agreed to in writing, software distributed under
11   the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES
12   OR CONDITIONS OF ANY KIND, either express or implied. See the
13   License for the specific language governing permissions and
14   limitations under the License.
15 -->
16 
17 <!--
18   For more information on how configure this file please
19   reference:
20 
21   http://activemq.apache.org/apollo/versions/1.7.1/website/documentation/user-manual.html
22   -->
23 <broker xmlns="http://activemq.apache.org/schema/activemq/apollo">
24 
25   <notes>
26     The default configuration with tls/ssl enabled.
27   </notes>
28 
29   <log_category console="console" security="security" connection="connection" audit="audit"/>
30 
31   
32   <authentication domain="apollo"/>
33   <!-- Give admins full access -->
34   <access_rule allow="admins" action="*"/>
35   <access_rule allow="*" action="connect" kind="connector"/>
36   
37 
38   <virtual_host id="mqttServer">
39     <!--
40       You should add all the host names that this virtual host is known as
41       to properly support the STOMP 1.1 virtual host feature.
42       -->
43     <host_name>mqttServer</host_name>
44     <host_name>localhost</host_name>
45     <host_name>127.0.0.1</host_name>
46 
47     <!-- Uncomment to disable security for the virtual host -->
48     <!-- <authentication enabled="false"/> -->
49 
50     <!-- Uncomment to disable security for the virtual host -->
51     <!-- <authentication enabled="false"/> -->
52     <access_rule allow="users" action="connect create destroy send receive consume"/>
53     
54 
55     <!-- You can delete this element if you want to disable persistence for this virtual host -->
56     <leveldb_store directory="${apollo.base}/data"/>
57     
58 
59   </virtual_host>
60   //Web网站系统访问的IP地址,127.0.0.1,这样定义只能内网访问,如果想外网访问,改成:0.0.0.0,格式:http://1**.9*.11*.1**:61680/console/index.html#
61   <web_admin bind="http://0.0.0.0:61680"/>  
62   <web_admin bind="https://0.0.0.0:61681"/>
63  //这是MQTT服务器的地址,在使用MQTT客户端访问MQTT服务器的格式:云服务器公网地址(不是执行ipconfig获取的地址):端口号,格式:1**.9*.11*.1**:61613
64   <connector id="tcp" bind="tcp://0.0.0.0:61613" connection_limit="2000"/> 
65   <connector id="tls" bind="tls://0.0.0.0:61614" connection_limit="2000"/>
66   <connector id="ws"  bind="ws://0.0.0.0:61623"  connection_limit="2000"/>
67   <connector id="wss" bind="wss://0.0.0.0:61624" connection_limit="2000"/>
68 
69   <key_storage file="${apollo.base}/etc/keystore" password="password" key_password="password"/>
70 
71 </broker>

        4)、修改 users.properties 文件,我保持的默认。
             apache-apollo-1.7.1\bin\mqttServer\etc\users.properties 这个文件可以配置登录账号密码,示例有一个admin=password, admin是账号,password是密码,客户端连接服务器和web网页登录所用的账号密码都是这个。
            

            源码如下:

 1 ## ---------------------------------------------------------------------------
 2 ## Licensed to the Apache Software Foundation (ASF) under one or more
 3 ## contributor license agreements.  See the NOTICE file distributed with
 4 ## this work for additional information regarding copyright ownership.
 5 ## The ASF licenses this file to You under the Apache License, Version 2.0
 6 ## (the "License"); you may not use this file except in compliance with
 7 ## the License.  You may obtain a copy of the License at
 8 ##
 9 ## http://www.apache.org/licenses/LICENSE-2.0
10 ##
11 ## Unless required by applicable law or agreed to in writing, software
12 ## distributed under the License is distributed on an "AS IS" BASIS,
13 ## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 ## See the License for the specific language governing permissions and
15 ## limitations under the License.
16 ## ---------------------------------------------------------------------------
17 
18 #
19 # The list of users that can login.  This file supports both plain text or
20 # encrypted passwords.  Here is an example what an encrypted password
21 # would look like:
22 #
23 # admin=ENC(Cf3Jf3tM+UrSOoaKU50od5CuBa8rxjoL)
24 #
25 
26 admin=password
        5)、配置 groups.properties 文件。
            apache-apollo-1.7.1\bin\mqttServer\etc\groups.properties 这个文件可以配置多个账户,如示例中的,示例是admins=admin 如果想添加多个账户可以 admins=admin|test ,其中test就是新增账户。
            

            源码如下:

 1 ## ---------------------------------------------------------------------------
 2 ## Licensed to the Apache Software Foundation (ASF) under one or more
 3 ## contributor license agreements.  See the NOTICE file distributed with
 4 ## this work for additional information regarding copyright ownership.
 5 ## The ASF licenses this file to You under the Apache License, Version 2.0
 6 ## (the "License"); you may not use this file except in compliance with
 7 ## the License.  You may obtain a copy of the License at
 8 ##
 9 ## http://www.apache.org/licenses/LICENSE-2.0
10 ##
11 ## Unless required by applicable law or agreed to in writing, software
12 ## distributed under the License is distributed on an "AS IS" BASIS,
13 ## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 ## See the License for the specific language governing permissions and
15 ## limitations under the License.
16 ## ---------------------------------------------------------------------------
17 
18 #
19 # Allows you to place multiple users in a group.
20 # Example:
21 #
22 # power_users=admin|chirino
23 #
24 admins=admin

        6)、运行 apollo-broker.cmd 命令。
            在 apache-apollo-1.7.1\bin\mqttServer\bin 路径下输入CMD打开命令行,输入apollo-broker.cmd run运行,出现下图就说明配置成功
            

            

        7)、客户端(外网客户端和服务器本地,访问方式不同)测试运行。   
             如果在服务器本地访问,可以直接访问:http://localhost:61680,或者 http://127.0.0.1:61680,都可以访问,会出现如下界面,说明配置成功。
            当然,如果是在外网访问的话,就要使用服务器公网IP+端口号,否则也是不通的。比如:http://1**.9*.1**.1**:61680/
             
              其中connectors选项下的TCP就代表MQTT的访问
             如果我们有MQTT客户端连接的话,这里也是有显示的。
            
              这就是我们当前的链接

              


        8)、安装 Windows 服务。
            这个命令的目录是:\apache-apollo-1.7.1\bin\mqttServer\bin
            
            1】、执行 apollo-broker-service install 命令和 apollo-broker-service start 命令。
                 

            2】、通过services.msc 命令查看服务。
                  

    3、MQTT.fx 安装和使用
        MQTT服务器安装好了,现在我们开始使用使用MQTT工具来访问了。我使用的是MQTT.fx,使用的版本是。1.7.1,也把过程记录下来。这是启动的图标。MQTT.fx 是目前主流的mqtt客户端,可以快速验证是否可以与IoT Hub 服务交流发布或订阅消息。设备将当前所处的状态作为MQTT主题发送给IoT Hub,每个MQTT主题topic具有不同等级的名称,如“建筑/楼层/温度。” MQTT代理服务器将接收到的主题topic发送给给所有订阅的客户端。目前最新版下载地址(支持windows,linux,mac)
        
        1)、下载地址:https://pan.baidu.com/s/1jwA7GUcT8h-rk_kt4CZq1A  ,现在只有百度网盘有了1.7.1版本的,提取码:1234。
          我在贴一个地址:https://softblade.de/en/download-2/ 这个应该是可以的,安装很简单,就不多说了,我就说说如何使用把。

            【1】、首先配置 MQTT 代理
                

                           

            【2】、打开配置窗口如下:
                

            【3】、回到主界面,点击connect连接到MQTT 代理服务器上,就可以进行订阅和发布消息测试了。

                

            【4】、Publish 发布测试。(主题:这是测试,内容:this is my test 2023.7.13)
                

            【5】Subscribe即订阅(订阅该主题之后,每次发布消息均会收到通知)
                

            【6】、链接成功之后,在apache-apollo管理平台可以看到有一个链接存在了
               

三、总结    
    好了,今天就写道这里了,这个测试也挺麻烦的,不熟悉的也踩草不少坑,谁都有第一次,慢慢来就好了。最近接触了很多新的东西,也学到了不少东西,每天有进步,还是很开心的,不忘初心,继续努力吧。

与如何在 Windows Server 2022 阿里云服务器上搭建自己的 MQTT 服务器之一Apache-Apollo服务器。 相似的内容:

如何在 Windows Server 2022 阿里云服务器上搭建自己的 MQTT 服务器之一Apache-Apollo服务器。

一、简介 最近,在做一个项目的时候,需要在线管理网络继电器,以前也做过硬件的项目,但是这样的项目不多。现在我想实现一个在线可以接受网络继电器发送的信号,也可以向网络继电器发送命令,控制其的运行。这个功能的实现需要物联网的支持,我在咨询了网络继电器卖家,想要在线实现网络硬件的管理有三种解决方案。 第一

如何在 Windows Server 2022 阿里云服务器上搭建自己的 MQTT 服务器之二Mosquitto服务器

一、介绍 最近几天都在搭建MQTT服务器,几天前搭建好了一个 Apache-Apollo的 MQTT 服务器,当我们在管理我们的主题的时候,发现主题的名称的斜杠(/)变成了点号(.),正好我在调试程序,在调用的时候出现了一些问题,各种解决办法都想了,还是没有解决,于是就向重新搭建一个 MQTT 服务

Windows Server 2022 初始设置

添加本地用户 添加新的本地用户。 在CUI配置上,按如下方式设置。 使用管理员权限运行 PowerShell 并按如下方式进行配置。 Windows PowerShell 版权所由 (C) Microsoft Corporation。 保留所有权利。 安装最新的 PowerShell,了解新功能和改

Windows Server 2022 NTP服务器

一、配置NTP服务器 配置NTP服务器,为客户端提供时间同步服务。 如果计算机是Active Directory域控制器,则NTP服务器功能已自动启动。 因此,下面的示例是计算机在工作组环境中启用NTP服务器功能。 1.1 使用管理员权限运行 PowerShell 并配置。 Windows Powe

关于Unity 如何与Blazor Server结合

关于Unity 如何与Blazor Server结合 一、介绍 最近工作中有`Unity`与`Blazor Server`结合的需求,在网上找了一圈,发现这方面的资料比较少,特此写下这篇记录一下自己的实现过程,希望可以帮到有需要的朋友。(下方多图预警) OS Version : windows 11

基于 Vagrant 手动部署多个 Redis Server

环境准备 宿主机环境:Windows 10 虚拟机环境:Vagrant + VirtualBox Vagrantfile 配置 首先,我们需要编写一个 Vagrantfile 来定义我们的虚拟机配置。假设已经在 D:\Vagrant\redis 目录下创建了一个 Vagrantfile,其内容如下:

如何在 Windows 使用 Podman Desktop 取代 Docker Desktop

Podman Desktop 是 Docker Desktop 的免费替代品,是本地开发使用的另一个绝佳选择。它提供了类似的功能集,同时保持完全开源,让您避免使用 Docker 产品的许可问题。在本文中,您将学习如何安装和开始使用 Podman Desktop 来运行容器并部署到 Kubernete

UOS 开启 VisualStudio 远程调试 .NET 应用之旅

本文记录的是在 Windows 系统里面,使用 VisualStudio 2022 远程调试运行在 UOS 里面 dotnet 应用的配置方法 本文写于 2024.03.19 如果你阅读本文的时间距离本文编写的时间过于长,那本文可能包含过期的知识 我将以我的 UOS 虚拟机作为例子告诉大家如何在 W

《爆肝整理》保姆级系列教程-玩转Charles抓包神器教程(2)-charles安装激活(Mac)最新简单教程【亲测有效】

1.简介 上一篇中宏哥介绍了如何在Windows系统安装激活Charles,那么使用Mac系统的小伙伴或者童鞋们就不高兴了,怎么没有Mac的安装激活教程了。宏哥不能厚此薄彼,今天专门补充一篇在Mac上安装Charles并且将其激活。 2.Mac下载安装 2.1下载Charles 官网下载:https

FFmpeg开发笔记(三十九)给Visual Studio的C++工程集成FFmpeg

​《FFmpeg开发实战:从零基础到短视频上线》一书的“第11章 FFmpeg的桌面开发”介绍了如何在Windows环境对Qt结合FFmpeg实现桌面程序,那么Windows系统通过Visual Studio开发桌面程序也是很常见的,下面就介绍如何在Visual Studio的C++工程中集成FFm