Forum

Geo balance by ping to server

Paul 2016-03-14 01:13:20 UTC in Nimble Streamer

Is there any plans for this?

It seems like a LOT of work to add all the 2 digit country codes to create load balance for each individual country.
Then what about Asia, very big continent. If I create lists manually and force user in West Asia (Iran etc) to connect to server in Singapore, maybe they will not have a good connection and would be better connected to server in Europe.
But I wont know this.
Would be great if ping test to servers and connect to best ping...maybe?

Alex Pokotilo 2016-03-14 01:49:30 UTC 

But if you ping server from client side what exactly you expect to implement from server ?
If you expect serve to ping client you should understand that it's not possible

Paul 2016-03-14 12:59:56 UTC 

So client connects to the closest server based on ping times.

It seems a very large amount of work to manually add 2 digit ISO code for every country in the world to the php script.
Then to also go through every sub-region for the big countries, another few hundred codes to add.

How do other CDN / streaming providers manage this?

Paul 2016-03-14 13:08:05 UTC 

I guess it is done by DNS load balancing by a 3rd party provider such as one of these:

https://www.maxcdn.com/blog/dns-load-balancing-comparison-4-services/

Maybe something that could be implemented in the future.

For now I will have user select their (closest) location and go to different video player pages based on where my edge servers are located, UK, USA, Australia. Or maybe I can find a geo based plugin for wordpress to rewrite links automatically based on continent or sub-continent (eg South Europe). This would save loads of work having to add every country 2 digit code etc.

Paul 2017-05-08 11:16:19 UTC 

Maybe one day you can work on adding something such as "anycast", or some better DNS balancing to get users to nearest video server?

Seems to be easier than complicated geo balance and load balance setup where I have to enter every single country 2 digit code, and then even, sub continents ISO code...hundreds and hundreds of them :(

https://en.wikipedia.org/wiki/Anycast
https://aws.amazon.com/route53/
https://medium.com/netflix-techblog/netflix-shares-cloud-load-balancing-and-failover-tool-eureka-c10647ef95e5

Mārcis Pauls 2017-05-10 08:14:45 UTC 

We use route53 for GEO balancing, works not 100% accurate, but is enough for us.

Paul 2017-05-12 12:11:59 UTC 

Excellent, thank for your reply - I will look in to it. Glad to know another Nimble user has had success with it.

Regards

Post a reply


Post a new question

Categories:

Tags:

nimbleNimble StreamerFAQHLSDVRRTMPhlsnimble streamerABRcachewmsauthNimbleAPItranscoderSRTdvrapirtmpffmpegVODsrtfailoverDASHsldpstreamingrtspwmspanellivevodudppaywallsubtitlesDispersaRTSPvideoSLDPyoutubeabrlivestreamingmp4WMSAuthMPEG-DASHpay-per-viewgeodashstreamerWMSPaneledgebandwidthWindowsencryptionUDPhttpswhite labelconfigsmilmulticastFFMPEGsslMPEG-TSaudioCORSchunksraspberry pire-streamingmpeg-dashperformancecorsadvertizervlcrepublishingS3cloudfrontDRMuser agentandroidNDILarixrules.confplaylistadvertisingipv6MPEGTSFastSpringRAMthumbnailFMLEVATcrossdomainmpegtsSMILRecordingaespushakamaiwowzaserversPullmobilecodecerrorSSLbalanceTranscodem3u8chromecastplaylist_dvrWowzaIDreportingconfigurationbugdownloadpublish controlRepublishingnimblestreamerdomainLarix Broadcastermpeg-tsraspianloopVidillionHttpschunkAWSawsoriginCDNwms panelroutesamazonIPipupdatenimble webcam html5UIbitrateRegistration Issuedirect link32-bit Windowstwitchcache_controlitworkmelive abr support mpeg-dashwmspanelapiresumertmp abrbeirutWWDCdubaideep statsCentOS v6.4hls to multicast udpnooblogWowza AgentRemote StorageIIS Smooth StreamingcloudmediaAbrHTTPSHot-linking protectionHDSvaddioalertsjwplayer websitewhmcsbaselineAuthentication in HLSPi4nginx rtmp nimbleAV BridgepricelimitOld logsVaddioscte-35screencastPI3 Ubuntuview timeattaching domainscontainerinterfacesDVRRecordingloadbalancingmod_rewritemetadatadatmessageWMSCONFIG_HOMEprofileID3 tagsgbpsAxisrestreamcostwmsauthsignhighhds streamlocalciscohls restreaming.net hotlinkVLCniblergentoo install server nimblePublic Iptranscoding using NvidiaPaywall Authdecodertransocding republishingVideo PlayerofflinedocumentationNimble streamer upgradeTrancoderconcurrent-connectionsAliasfilelost trafficServer-sideicecast urlstoppedNimble Streamer versionrulemainhot linkingchangelebanonlocationmanifestMP4 not playedspaceLarix Groveamfpay per viewseekingdvr_archivesmpeg dashonSteam stopped workingobsTCORaspian BusternginxPlayReadyamazon web servicelimuxopensslHLS voddvr stream twicesdpshoutcasthot-linkAXVVGanalyticspaywalapplicationblocknvencExpression Encoder7brandingtrialHLS PlayerDASH Playerdebianmicrosoft streamMP4errorsrocksoftlog traffic statslive video on demandbandwithservernimblesessionidFFmpegmultiple originsscreen freezecan't registerprogressive downloadABR DASHprivate networkLarge DVR filessourceheaderno WMSPanelSnapshotslive videolog nimble analysertmp playbackinterleavingvideojsmac osx installvideo stopwotermarkadaptiveAV1 codecvimeohelp errorstreamsNGINX-RTMPJWPLAYERload balanceattachmentcache expiryvod no soundconcurrent connectioncdnvsomdvr streamconnectivityUbuntu 20 ARM - AWSunique visitor4Kcrossdomain more then 1 domainlive streamViewer StatscpuWidevineDelaympeg2tsFairplayServer-Side-Task-Controldisk migrationAWS 3buttnot foundCPU Loadscreen capturestereo to monopullAS3drmresourceaes encryptionTranscoderLive streamingsubscriptionsecurityinstall players setup ready to goDVRSettingstwitch larix broadcaster androidAppleDelete recordsABR HLS Bitrateslive pull settingsWMSPanel settingsrtmp for YouTubevideo loopicecastudp streamingoutratestarttime duration seekpointrebootmonitornimble streamer vod hls transmuxinglogginglearnerapi accessDeep statsloadbalancernimble.confrtmp republishing transcodeIIS Media Servicsweb playerinsert logodvr streamsautomationnimble streamer web server php script pageNimble Streamer APIlivestreamcontent-dispositionAVCaptureMovieFileOutputblock downloadNimble CapacityABR DVR problemLive SwitcherPost processingadd_chunk failedfake extensionMPEG DASHUbuntu artful 17.10Transcoder MPEG DASHNimble Servernot to stealLive Broadcaststatus:errorFFMPEG;RTMP;I/O errortranscodingRTMP republishHotlinking ProtectionStreaming routefacebookPIDMPEG-Dashlarix broadcasterbroadcasterOSXpaymentstatsreloadpremium featureserver incorrect timeThumbnailsLiveLIVEadvp9contentRTMP RepublishssaiDVR Setting limitdemandHow to do live stream with multiple audio trackrmtpno internetIOSProgressivenimble aliasesHLS Streamingthumbnail dvr-thumbnailLoad-Balancingnimble streamer mpeg-ts multiple inputswmsAuthSignreportsavoid refreshraspberrysoundHLS Meta Tag editing.transcoder nimbleSecureJetson Nanotranscodevbv-maxratedvr on wmspanelVideo cant be playedS3 AWSuser_agentautomateAndroidVR-360Failoverdockerlivestream bitrateABR bitratesPacketizingbuildpublish streamStream Delaytraffichd25AArch64delaympeg4.movalias routestoragedomain lockVOD HLS streaming on public IPoutputUsers limitcloudflareanalisysscteno soundInvalid frame headerincoming streamHTML5 playerGopwirecasta recordhttp serverNimbleStreamerav1 codecabr fallbackNimble connectionsdistributionfastspringNimble streamermp2 audiodata slicesaliasplayer sldpqataritworkscdnvideo.jsspeedup my videoiOSissuepricinggoogle cloud storagedissapointmentpay-per-minuteRAM LoadlivestreamintransocderPaywallvideo and audio not matchdiskstorage space available3.6.1-1SO_RCVBUFbuffering videocompatibility protocolsMax connectionUDP MulticastgpurestarthelpFallbackError when installinghow-tomanage_dvrrulesDVRStreamsaws amazonserver ip21SSL requestMPEG2 Videologo in streamVP9sha265nimble on cloudprerollDVR SettingPORTanalyseStreamIDcredentialsincomingmulti-viewervideo audioCross DomainSRT protocolmd5nimble dvrrtpdurationBandwidthbufferRIST BondingplayoutControl APIfallbackQuickTimevideo streamingartifactsrtsp push androidtuningactionscript 3server ssl errorCSSRistwebhookdvr to liveprogressivebroadcast videoRTMP to SRTscte35ubuntu 18Teradek DecoderlatencyNimble_Crushdynamic linksTLSV 1.2 Certificatefairplayre-publishingSRT RTMPsoftware versionadjustBroadcasthotlink protectionultra low latencyRaspberryPi4Raspberrytasks-control

This website or its third-party tools use cookies, which are necessary to its functioning and required to achieve the purposes illustrated in the Privacy Policy. If you want to know more or withdraw your consent to all or some of the cookies, please refer to the Privacy Policy.
By closing this banner, scrolling this page, clicking a link or continuing to browse otherwise, you agree to the use of cookies.