- Prerequisites:
Quick Start
To build images, you can open the
network.sh
file and modify_IMAGE_NAME
andIMAGE_VERSION
to change the image tags.shellcd example/test-network-k8s ./network.sh build-images
Pull some necessary images
shelldocker pull k8s.gcr.io/ingress-nginx/controller:v1.1.2 docker pull quay.io/jetstack/cert-manager-webhook:v1.6.1 docker pull quay.io/jetstack/cert-manager-controller:v1.6.1 docker pull quay.io/jetstack/cert-manager-cainjector:v1.6.1 docker pull k8s.gcr.io/ingress-nginx/kube-webhook-certgen:v1.1.1
Initialize the KIND cluster
shell./network.sh kind
Load images into the KIND cluster
shell./network.sh kind-load-images
Launch the KIND Kubernetes cluster
shell./network.sh cluster-init
Start the RobustMQ cluster
shell./network.sh up
Cleanup
shell./network.sh unkind
Review the Process
- Install KIND
- Pull some necessary images
- Initialize the KIND cluster
- Load images into the KIND cluster
- Launch the KIND Kubernetes cluster
- Start the RobustMQ cluster
Enter docket
For more commands, please refer to cli-command
Publish messages
console% kubectl exec -it cli-command-6fbf8b6cc-7ldqp -n robustmq -- /bin/sh # ./cli-command mqtt --server=mqtt-server-cs.robustmq.svc.cluster.local:1883 publish --username=admin --password=pwd123 --topic=test/topic1 --qos=0 able to connect: "mqtt-server-cs.robustmq.svc.cluster.local:1883" you can post a message on the terminal: 1 > You typed: 1 2 > You typed: 2 3 > You typed: 3 ^C> Ctrl+C detected, Please press ENTER to end the program.
Subscribe to messages
consolekubectl exec -it cli-command-6fbf8b6cc-7ldqp -n robustmq -- /bin/sh # cd libs # ./cli-command mqtt --server=mqtt-server-cs.robustmq.svc.cluster.local:1883 subscribe --username=admin --password=pwd123 --topic=test/topic1 --qos=0 able to connect: "mqtt-server-cs.robustmq.svc.cluster.local:1883" subscribe success payload: 1 payload: 2 payload: 3 ^C Ctrl+C detected, Please press ENTER to end the program. End of input stream.
Verify that MQTT functions correctly
This KIND-Kubernetes cluster will start a cli-command
pod, from which you can execute cli-command commands within the cluster.
First, get the name of the cli-command
pod
```console
% kubectl get pods -n robustmq
NAME READY STATUS RESTARTS AGE
cli-command-6fbf8b6cc-7ldqp 1/1 Running 0 16m
```
Enter the cli-command
pod and run commands
Check the documentation to run the test:MQTT functional tests