-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ipvs: Add simple weighted failover scheduler
Add simple weighted IPVS failover support to the Linux kernel. All other scheduling modules implement some form of load balancing, while this offers a simple failover solution. Connections are directed to the appropriate server based solely on highest weight value and server availability. Tested functionality with keepalived. Signed-off-by: Kenny Mathis <kmathis@chokepoint.net> Acked-by: Julian Anastasov <ja@ssi.bg> Signed-off-by: Simon Horman <horms@verge.net.au>
- Loading branch information
Kenny Mathis
authored and
Simon Horman
committed
Sep 16, 2014
1 parent
0bbe80e
commit 616a9be
Showing
3 changed files
with
90 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,79 @@ | ||
/* | ||
* IPVS: Weighted Fail Over module | ||
* | ||
* Authors: Kenny Mathis <kmathis@chokepoint.net> | ||
* | ||
* This program is free software; you can redistribute it and/or | ||
* modify it under the terms of the GNU General Public License | ||
* as published by the Free Software Foundation; either version | ||
* 2 of the License, or (at your option) any later version. | ||
* | ||
* Changes: | ||
* Kenny Mathis : added initial functionality based on weight | ||
* | ||
*/ | ||
|
||
#define KMSG_COMPONENT "IPVS" | ||
#define pr_fmt(fmt) KMSG_COMPONENT ": " fmt | ||
|
||
#include <linux/module.h> | ||
#include <linux/kernel.h> | ||
|
||
#include <net/ip_vs.h> | ||
|
||
/* Weighted Fail Over Module */ | ||
static struct ip_vs_dest * | ||
ip_vs_fo_schedule(struct ip_vs_service *svc, const struct sk_buff *skb, | ||
struct ip_vs_iphdr *iph) | ||
{ | ||
struct ip_vs_dest *dest, *hweight = NULL; | ||
int hw = 0; /* Track highest weight */ | ||
|
||
IP_VS_DBG(6, "ip_vs_fo_schedule(): Scheduling...\n"); | ||
|
||
/* Basic failover functionality | ||
* Find virtual server with highest weight and send it traffic | ||
*/ | ||
list_for_each_entry_rcu(dest, &svc->destinations, n_list) { | ||
if (!(dest->flags & IP_VS_DEST_F_OVERLOAD) && | ||
atomic_read(&dest->weight) > hw) { | ||
hweight = dest; | ||
hw = atomic_read(&dest->weight); | ||
} | ||
} | ||
|
||
if (hweight) { | ||
IP_VS_DBG_BUF(6, "FO: server %s:%u activeconns %d weight %d\n", | ||
IP_VS_DBG_ADDR(svc->af, &hweight->addr), | ||
ntohs(hweight->port), | ||
atomic_read(&hweight->activeconns), | ||
atomic_read(&hweight->weight)); | ||
return hweight; | ||
} | ||
|
||
ip_vs_scheduler_err(svc, "no destination available"); | ||
return NULL; | ||
} | ||
|
||
static struct ip_vs_scheduler ip_vs_fo_scheduler = { | ||
.name = "fo", | ||
.refcnt = ATOMIC_INIT(0), | ||
.module = THIS_MODULE, | ||
.n_list = LIST_HEAD_INIT(ip_vs_fo_scheduler.n_list), | ||
.schedule = ip_vs_fo_schedule, | ||
}; | ||
|
||
static int __init ip_vs_fo_init(void) | ||
{ | ||
return register_ip_vs_scheduler(&ip_vs_fo_scheduler); | ||
} | ||
|
||
static void __exit ip_vs_fo_cleanup(void) | ||
{ | ||
unregister_ip_vs_scheduler(&ip_vs_fo_scheduler); | ||
synchronize_rcu(); | ||
} | ||
|
||
module_init(ip_vs_fo_init); | ||
module_exit(ip_vs_fo_cleanup); | ||
MODULE_LICENSE("GPL"); |