-
Notifications
You must be signed in to change notification settings - Fork 641
How to Setup Ant Media Server Clustering on Azure
In this guide, I will explain how to setup Ant Media Server Clustering on Azure. When your load is high, one server instance is not enough for you and you can handle that load with a clustering solution.
For streaming applications, you will need a clustering solution when you have high numbers of publishers and viewers. Especially when you require ultra-low latency and adaptive bitrate because they need more processing power. Ultra-low latency is achieved by WebRTC and it is a CPU intensive protocol. Adaptive bitrating is downgrading video quality in bad networks if needed. It is also CPU intensive because there is video conversion. Luckily, Ant Media Server Enterprise Edition supports clustering, so that you can handle the high load in your streaming applications.
Requirements:
To set up media server, Having an Azure account and a ready AntMedia Server Image are needed.
The architecture of the cluster setup could be found here. Introduction to clustering with AntMedia Server could be found here.
Each resource created must be in the same resource group. For this, we will first create a resource group. Named antmedia-cluster
Click Resource groups in the portal which is on the left side then click +Add
Enter "Resource group" then choose your zone.
Proceed by clicking "Create" button
We need to create a virtual network named antmedia-cluster-virtual-network, and then we will add gateway-subnet, origin-subnet and edge-subnet
Click Create a Resource in the portal which is on the upper left. Enter Virtual network in the Search the Marketplace box at the top of the New pane that appears. Click Virtual network when it appears in the search results.
click "Create"
Select the resource group that we created before, enter antmedia-cluster-virtual-network in the name field and click on the "Next: IP Address" button.
Click on the Add subnet button and create the antmedia-origin-subnet, antmedia-edge-subnet and antmedia-gw-subnet as shown in the figure below.
The subnets that you created will look like the following. If everything is ok, click the "Review + create" button and create your Virtual Network.
The process is completed by clicking on the "Create" button.
Click Virtual Machines on the left bar and then click +Add
Enter the following values and click "Next: Disks"
Resource group "antmedia-cluster"
Image "Ubuntu 18.04 LTS"
Enter the following values and click "Next: Networking"
Select the Virtual Network that you created, click "Advanced" from "Nic network security group" and click "Create new"
Acilan pencerede Add an inbound Rule tiklayin ve asagidaki gibi inbound security rule ekleyin.
Enter the following values and click next:
Custom data alanina asagidaki satirlari ekleyin ve "Review + Create" butonuna tiklayip MongoDB instnacesini olusturun.
#!/bin/bash
wget -qO - https://www.mongodb.org/static/pgp/server-4.2.asc | sudo apt-key add -
echo "deb [ arch=amd64 ] https://repo.mongodb.org/apt/ubuntu `lsb_release -cs`/mongodb-org/4.2 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.2.list
sudo apt-get update
sudo apt-get install -y mongodb-org
sed -i 's/bindIp:.*/bindIp: 0.0.0.0/g' /etc/mongod.conf
systemctl restart mongod
Click Create a Resource in the portal which is on the upper left. Enter Application Gateway in the Search the Marketplace box at the top of the New pane that appears. Click Application Gateway when it appears in the search results.
Select Classic in the Select a deployment model box in the Application Gateway pane that appears, then click Create.
Resource Group, Application Gateway Name, Region ve Virtual Network ayarlarini asagidaki gibi giriniz ve "Next: Frontends" e tiklayin.
Add New butonuna tiklayip asagidaki gibi girin ve "Next: Backends" 'e tiklayin.
Add a Backend pool 'a tiklayip ekram goruntusundeki gibi hem origin hem de Edge icin poollar olusturun ve "Next: Configuration" 'a tiklayin.
Add a routing rule 'e atiklayin.
Ekran goruntundeki gibi alanlari doldurup "Backend targets" 'i tiklayin.
Backend target "Edge" poolunu secin ve HTTP settings icon Add new 'e tiklayin.
Asagidaki gibi doldurun. Bu ayar hem origin hem de origin icin olacaktir.
Ayarlariniz asagidaki gibiyse HTTP istekler icin Edge yapilandirilmasi bitmistir.
Tekrar "Add a routing rule" 'e tiklayip Origin icin HTTP ayarlarini yapalim. Asagidaki gibi ayarlari yapip "Backend target" tiklayin.
Backend target olarak Origin poolunu secin ve HTTP settings olarakta onceden olusturdugumuz "BackendHttpSettings" i secin.
Simdi sirada Origin icin HTTPS isteklerini yonlendirmeye geldi. Bunun icin asagidaki gibi ayarlari yapin. cluster.antmedia.io.pfx sertifikasi icin bu linki kullanabilirsiniz.
Backend target olarak Origin ve HTTP Settings olarak "BackendHttpSetting" secin.
Ayni sekilde Edge icin 5443 icin yapilandirmayi asagidaki gibi yapin.
Backend target olarak Edge ve HTTP Settings olarak "BackendHttpSetting" secin.
Tam olarak application-gateway ayarlari asagidaki gibi gozukecektir. Her sey yolundaysa "Next:Tags" tiklayin.
Son olarak "Create" basarak kurulumu tamamlayin.
We need to setup scale sets. Click Create a Resource in the portal which is on the upper left. Enter Application Gateway in the Search the Marketplace box at the top of the New pane that appears. Click Application Gateway when it appears in the search results.
Select Classic in the Select a deployment model box in the "Virtual Machine Scale Set" pane that appears, then clicks Create.
Ilk olarak Origin Scale Set'i olusturacagiz. Resource Groupu secin Virtual Machine scale set name Region ayarlarini asagidaki gibi yapin. Browse all public and private images 'e tiklayin.
Acilan pencerede Ant Media Server diye aratip "Ant Media Server Enterprise 2.1.0" surumu secin.
Disk secimini yaptiktan sonra "Next: Networking" 'i secin.
Bu ekranda Virtual Network olarak onceden olusturmus oldugumuz antmedia-cluster-virtual-network 'u secin. Network interface olarak origin subnetini secin ve Use a load Balancer Yes tiklayin. Onceden olusturmus oldugumuz application gateway 'i secin ve Backend Pool olarak origin i secin ve "Next: Scaling" 'i tiklayin.
Bu ekranda Custom'i secin ve Cpu threshold %60 'a getirin. Diger ayarlari kendinize gore yapabilirsiniz.
Management ve Health sekmelerinde direk next diyerek devam edin ve Advanced kisminda Custom data alanina asagidaki satirlari ekleyin.
#!/bin/bash
cd /usr/local/antmedia/
./change_server_mode.sh cluster 10.0.2.4
10.0.2.4 IP adresi daha once kurmus oldugum MongoDB instanceinin private IP adresidir. Kendinize gore duzenleyiniz.
Create butonuna tiklayarak Origin icin Scale Set'ini olusturun.
Tekrar yeni bir adet Scale Set olusturun yukaridaki adimlari tekrarlayin. Sonra Networking kismini da asagidaki gibi duzenleyin. Network Interface olarak Edge Subnetu olacak ve Application Gateway Backend pool icin de Edge secili olacaktir.
Son olarak scale setleriniz asagidaki gibi gozukecektir.
Asagidaki sayfalar cevap veriyorsa edge/origin yonlendirmeleriniz dogru calisiyor demektir.
Edge icin login https://application-gateway-ip:5443 Origin icin login https://application-gateway-ip
Cluster Menusune geldiginizde de asagidaki gibi join olmus nodelari gorebilirsiniz.
- Introduction
- Quick Start
- Installation
- Publishing Live Streams
- Playing Live Streams
- Conference Call
- Peer to Peer Call
- Adaptive Bitrate(Multi-Bitrate) Streaming
- Data Channel
- Video on Demand Streaming
- Simulcasting to Social Media Channels
- Clustering & Scaling
- Monitor Ant Media Servers with Apache Kafka and Grafana
- WebRTC SDKs
- Security
- Integration with your Project
- Advanced
- WebRTC Load Testing
- TURN Servers
- AWS Wavelength Deployment
- Multi-Tenancy Support
- Monitor Ant Media Server with Datadog
- Clustering in Alibaba
- Playlist
- Kubernetes
- Time based One Time Password
- Kubernetes Autoscaling
- Kubernetes Ingress
- How to Install Ant Media Server on EKS
- Release Tests
- Spaceport Volumetric Video
- WebRTC Viewers Info
- Webhook Authentication for Publishing Streams
- Recording Streams
- How to Update Ant Media Server with Cloudformation
- How to Install Ant Media Server on GKE
- Ant Media Server on Docker Swarm
- Developer Quick Start
- Recording HLS, MP4 and how to recover
- Re-streaming update
- Git Branching
- UML Diagrams