Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Table of Contents
minLevel2
maxLevel2
outlinefalse
typelist
printablefalse

If you do not have a valid HiveMQ license, the HiveMQ cluster uses a trial licence that allows up to 25 concurrent client connections and is limited to testing and evaluation purposes only. To obtain a HiveMQ licence that is suitable for production use, or request an evaluation licence that allows more connections, contact our customer service team.

Info

While creating this guide, our Kubernetes Version is v1.27.7, it might be different in your case

Requirements

  • Microsoft Azure Account

  • HiveMQ License (optional)

  • Azure CLI
    The Azure command-line interface is used to create and manage Azure resources. In this procedure, you use the Azure CLI to create an Azure Resource Group with a Kubernetes cluster on the Azure cloud. To install the Azure CLI on macOS with Homebrew, open a terminal and enter the following. For other operating systems, see Azure CLI installation.

Code Block
brew install az

...

  • Kubectl is the official command-line interface for interacting with Kubernetes clusters. Here, you use kubectl to manage the created Kubernetes cluster on Azure. Once you install Azure CLI, you can enter the following command to install kubectl on any operating system:

Code Block
az aks install-cli
  • Helm
    Helm is the most commonly used package manager for Kubernetes. Helm helps you easily define, install, and update the software that you run on a Kubernetes cluster. In this procedure, you use Helm to install and configure HiveMQ on your K8s cluster. To install Helm on macOS with Homebrew, enter:

Code Block
brew install helm

For other operating systems, see Helm installation.

  • MQTT-CLI
    MQTT-CLI is an open-source command-line interface from HiveMQ that allows you to quickly simulate MQTT clients. Here, you use the MQTT-CLI to connect clients and interact with your HiveMQ cluster.
    To install MQTT-CLI on macOS with Homebrew, enter:

Code Block
brew install hivemq/mqtt-cli/mqtt-cli

For other operating systems, see MQTT-CLI installation.

Set Up Your Kubernetes Cluster With AKS

Set Up Your Kubernetes Cluster With Azure Kubernetes Service(AKS)

In case you get the following error , you can fix it by setting subscription for your account
The client XYZ with object id 'ABCD' does not have authorization to perform action 'Microsoft.Resources/subscriptions/resourcegroups/write' over scope or the scope is invalid. If access was recently granted, please refresh your credentials.
Code: AuthorizationFailed

Steps to fix the error:

  1. go to subscriptions under your azure account and look for subscription ID

  2. Run the following command to set subscription for your account:

az account set --subscription subscriptionID

  1. To create a Kubernetes cluster on Azure with the Azure CLI, open a terminal and enter:

Code Block
az login
  1. A window to sign in to your Microsoft account opens in your browser. After you successfully submit your credentials, a sign-in confirmation prints in your terminal.

...

  1. Before you create the cluster, you need to select the region where the cluster is hosted. To view a list of all available locations, enter:

Code Block
az account list-locations
  1. To create an Azure Resource Group with all the necessary resources for your cluster, enter the following command with the desired location (in this procedure, we use germanywestcentral):

Code Block
az group create --name hmqResourceGroup --location germanywestcentral

...

 
  1. To create a four-node AKS-managed Kubernetes cluster in your resource group with the Azure virtual machine type Standard_A8_v2 (8 CPUs, 16 GiB RAM), enter the following command and wait until the process completes.Processing time can vary:

Code Block
az aks create -g hmqResourceGroup -n HiveMQCluster --node-count 4 --node-vm-size Standard_A8_v2 --enable-managed-identity

Your Microsoft Azure account bills you for all resources you create.

Manage the cluster

  1. To manage the resulting Kubernetes cluster with kubectl, download the access credentials of the cluster:

Code Block
az login
Code Block
az aks get-credentials -g hmqResourceGroup -n HiveMQCluster
  1. To verify that all four nodes are available, enter:

Code Block
kubectl get nodes
  1. The output from the command is similar to the following: (k8s v1.27.7 in our case, it might be different for you)

Code Block
NAME                                STATUS   ROLES   AGE     VERSION
aks-nodepool1-37471664-vmss000000   Ready    agent   5m44s   v1.1827.107
aks-nodepool1-37471664-vmss000001   Ready    agent   5m50s   v1.1827.107
aks-nodepool1-37471664-vmss000002   Ready    agent   5m47s   v1.1827.107
aks-nodepool1-37471664-vmss000003   Ready    agent   5m47s   v1.1827.107

In case you do not see the right nodes, please check and fix the current context

  1. Check the current context, this should be set to HiveMQCluster in this case
    kubectl config current-context

  2. Fix the context
    kubectl config use-context HiveMQCluster

Delete Cluster

In case you do not need your cluster anymore, please use the following commands to delete the cluster.

Code Block
az aks delete -g hmqResourceGroup -n HiveMQCluster -y
Code Block
az group delete -n hmqResourceGroup -y --no-wait

Next steps

Install HiveMQ using Kubernetes Operator