The number of connections is mainly determined by the available bandwidth. What you’re not telling here, is the bitrate of each of the streams. A very rough calculation is to divide the available bandwidth by the average bitrate per stream multiplied by 1.2, thus
[available bandwidth] / ([average bitrate per stream] x 1.2)
If you can burst up to 10Gbps, let’s assume an average bitrate of 2Mbps, then the max. connections is 10000 / 2 x 1.2 = 4166. However, if you only serve HTTP streams (HLS, MPEG-DASH), then the real number of connection may be much more, because it depends on how fast Wowza can handle HTTP request, and serve HLS chunk, or MPEG-DASH segment, to the client. Last year, I managed almost 50K connections of a 500kbps stream on an 1Gbps in an optimized test environment.
This completely satisfies my question in place. Just one thing, I wanted to ask is does ram & CPU has anything to do with the max concurrent sessions as on one of my streaming servers I am serving like 6 like feeds with Wowza transcoder on for multiple bitrates & it’s CPU is lik 80% all the time?
In a situation without transcoder, RAM and CPU are definitely important factors too. It’s just that, in most cases, the network interface is the bottleneck (exceptions are situations where you have a disproportion, like a single-core CPU, or 2GB RAM alongside a 10Gbps NIC)
In a situation with transcoding enabled, the case becomes different. Transcoding is a very CPU-intensive process; each incoming feed must be decoded, and then re-encoded to the different new bitrates (in your case, 720p, 480p and 360p). That means that the bottleneck now becomes the CPU, and the number of streams you can serve from a server simultaneously is much more limited. Don’t confuse this with client connections though: one incoming stream can still have 1000s of clients. It’s not the number of client connections that gets limited, but the number of concurrent incoming feeds.
There are several options to build a successful business case when you need transcoding. On option is to consider either an NVidia GPU in your server, or use multiple smaller servers with CPUs that have Intel QuickSync. There are also live and VOD transcoding services available online; some built-in with a complete streaming service (e.g. Wowza Cloud), some as separate service.
If you’re interested in Live transcoding as a separate service, drop me an email: karel.boek@raskenlund.com
With regards to bandwidth usage you should always leave 20 percent of your bandwidth untouched for TCP overhead. In a best case scenario it looks like you may be able to fit 20 players within that 80 percent value.