There are several ways you can deploy Solace PubSub+ container image, and it can be somewhat confusing when trying to select the correct approach to satisfy your short-term (trial or dev) needs, meet all of your long-term (production) requirements, and fit as well as possible into your existing deployment environments.
That’s because your needs and requirements might not be best met by your existing deployment environment. This can be because your container deployment environments may not be best suited for long term deployment of stateful infrastructure, like databases of event routing infrastructure. If that is the case you might need to decide whether to invest in a more suitable deployment model or augment the existing model to meet your long-term needs.
Keep in mind that the best solution for container deployment might be “none of the above” and a managed service via Solace Cloud might be the best fit for evaluation or even production deployment. And for some use cases, Solace PubSub+ Event Broker Appliance might be the best fit for performance, reliability and cost of ownership reasons.
Pros and Cons of Various Deployment Options
After considering the options of Solace Cloud and Event Broker Appliance, the next step is to briefly explore the options for deploying Solace PubSub+ Event Broker software and the pros and cons of each approach.
Machine Images
Solace provides a series machine image formats for private or on-prem installation, VHD for Microsoft Hyper-V installs, OVA for VMWare installs; as well as a public cloud AWS EC2 image.
Advantages
These images provide a very simple install of a Solace PubSub+ software broker with all container requirements and dependencies well thought through. The ease of install makes these a great option if you already have the required infrastructure to run, VMWare ESXi server or AWS account for example.
Things to Consider
This approach provides a single non fault tolerant broker and possibly a single point of failure disk. So, it is very good as-is for trials and development and can be used as a foundational building block for production deployments. Keeping in mind that operationalization for day one, (make fault tolerant), and day two, (monitor, upgrade), activities will need to be implemented. Since adding things like logging or monitoring agents into the base OS or inside the container is not supported, this can however be challenging.
Container Image
The machine image described above contains a Linux container image that can be directly deployed into a container runtime, (Docker, PodMan).
Advantages
This option has many of the same characteristics of a machine image install; great option if infrastructure exists for test and development but challenging for productization. The advantage of installing containers is that it is lighter weight infrastructure and you can build up the base OS as you require,(as long as container requirements are met), this means you can add in you logging and monitoring agents etc. as you see fit.
Things to Consider
Like the previously described machine images, this solution provides broker instances but does not solve the operational day one and day two requirements of being highly available and does not provide a full solution for upgrades. Additional management tooling would need to be purchased or built to bring container images to production.
Cloud Quickstarts or Docker Compose
Created to exemplify fault tolerant solutions in AWS CloudFormation Quickstart, Azure ARM Quickstart, GCP Quickstart, and Docker Compose example where created using the Solace PubSub+ event broker container image. This allows selection of custom base images for monitoring, logging, certificate injection, as well as disk and broker fault tolerance.
Advantages
This solution is good as-is for more robust UAT testing or small production deployments where the limitations can be handled manually.
Things to Consider
But, with is solution day two activities would still need to be integrated into Solace publicly available opensource quickstarts.
Kubernetes with Helm
Created to exemplify lifecycle managed solution in Kubernetes.
Advantages
Beyond being fault tolerant, the solution Kubernetes provides self-healing, in that failed infrastructure will be re-created and added back into the cluster. Upgrades are also gracefully handled. Kubernetes logging and monitoring are integrated with ability to track active broker and ability to monitor and restart stalled containers.
Things to Consider
Though the solution is highly tunable there is still requirement to integrate things like certificate management which is custom to each deployment. This solution is good for situations where developers need to deploy infrastructure as code and are allowed to define exactly what that infrastructure looks like.
Kubernetes with Operator
Created to exemplify corporate controlled deployments into Kubernetes.
Advantages
The operator provided allows a central management team to predetermine what a Solace PubSub+ Event Broker will consist of and offer that solution to the users of the Kubernetes cluster in a versioned and controlled manor. The teams that use the Solace broker can deploy a complete broker-based solution as they would any other Kubernetes resource.
Things to Consider
This solution may be too incombered for people that manage there own Kubernetes cluster, either themselves or through public cloud providers, for things like development and other non production use cases.
Summary of Selection Suggestions
This reference table shows which deployment solution is the best for which use case.
Use Case | Description | Deployment Option |
---|---|---|
Try before buy, Dev environments |
Docker Container Runtime or Public cloud account | AWS EC2 Machine Image |
Slightly more sophisticated Cloud development, UAT | Fault tolerant | AWS Container Image Quickstart Azure Container Image Quickstart GCP Container Image Quickstart Docker Compose |
Dev/Ops in production Developers deploy infrastructure they need | Self-healing, Upgradable, Any K8s Env | VMWare Tanzu/PKS Openshift Solace Helm |
Centralized corporate ownership of infrastructure deploy approved solutions | Build infrastructure based on version controlled, compossible resources. Exposed to dev teams. K8s | Solace Operator |
Explore other posts from category: For Architects