1
dorentus 2014 年 2 月 8 日 via iPhone
对十取模再加一…
|
2
Livid MOD PRO 所有的 IP 地址都是可以转化成一个整数的,在 PHP 里的话,就是 ip2long()
|
4
family 2014 年 2 月 8 日 via iPhone
nginx做吧
|
5
likexian 2014 年 2 月 8 日
根据ip没办法均衡分配吧,得看访问的人的ip分布了
用dns轮询就省事了,直接加x条a记录 或者参考dns轮询,自己加个计数器 |
6
wklken 2014 年 2 月 8 日
python用socket模块,可以直接转得到int再取模
|
7
stackpop 2014 年 2 月 8 日 ip本身就是一个32位的无符号整数,直接模5好了。但是这样并不保证均衡。
|
8
dorentus 2014 年 2 月 8 日 via iPhone
所以这明显是个 X-Y 问题么…
想要实现你后来说的,又要尽量平均分布,其实很简单,每个客户端第一次访问的时候随机选择一个分配给它,然后记下来就是了,下次它再来访问的时候分配记下来的给它。 如果你并不是严格地要按 IP 来分,那么其实不记在服务器端都可以,客户端浏览器每次访问的时候服务器随机选择一个目标,然后输出 HTTP 永久跳转给客户端,这样一般来说只要用户不去折腾浏览器缓存,下次访问的时候浏览器就会直接去之前选中的目标网址了。(这么做似乎有滥用之嫌…不过话说回来,你的这个需求是怎么来的,怎么这么奇怪…) |
9
otakustay 2014 年 2 月 9 日
@dorentus 永久跳转可能会让用户再也回不来,基本上我觉得楼主是在做小流量AB试验,这么玩可能会造成用户再也脱离不了小流量的状况,并不合适,还是在cookie里加一个标记更好,随时可以清除
|
10
yaroot 2014 年 2 月 9 日
consistent hashing
|
11
workaholic 2014 年 2 月 9 日
按照你的意思,各个节点负载要相同,需要用到负载均衡算法: 轮询(Round Robin, RR),你可以查一下具体实现,比较简单
|
12
mengzhuo 2014 年 2 月 10 日
python
struct.unpack("!L", socket.inet_aton(ip))[0] % (自个模吧) |