Load balancing is critical to managing server resources efficiently and ensuring optimal performance in distributed systems. The weighted round robin (WRR) algorithm is commonly used to allocate incoming requests among servers based on their assigned weights. However, static weights may not reflect the changing demands of servers, leading to imbalanced workloads. To address this issue, this study proposes a dynamic mechanism for assigning weights to servers in the WRR algorithm based on the data rate and incorporates the least connection approach for the best result. The dynamic mechanism considers each server's real-time data rate, representing its current load. Servers with higher data rates are assigned higher weights to attract a larger share of incoming requests, while those with lower data rates receive lower weights to manage their loads effectively. This dynamic weight assignment allows the algorithm to adapt to varying workloads and achieve better load balancing across servers. To further refine the distribution of requests, the least connection approach is employed to handle tie-breaking situations and for more fairness in distributing the loads. The proposed algorithm is a hybrid of data rate and the least connection, it is evaluated through simulations and real-world experiments. The results demonstrate its superiority in achieving improved load balance compared to other algorithms, such as round-robin RR and traditional static-weight WRR algorithms. By dynamically adjusting weights based on data rate and employing the least connection approach, the algorithm optimizes server resource usage, minimizes response times, and enhances overall system performance in distributed environments.