-- 需要選擇一個擁有空閒連接的從數據庫
if s.type == proxy.BACKEND_TYPE_RO and
s.idling_connections > 0 then
if max_conns == -1 or
s.connected_clIEnts < max_conns then
max_conns = s.connected_clIEnts
max_conns_ndx = i
end
end
end
-- 至此,我們找到了一個擁有空閒連接的從數據庫
if max_conns_ndx > 0 then
proxy.connection.backend_ndx = max_conns_ndx
end
else
-- 發送到主數據庫
end
return proxy.PROXY_SEND_QUERY
注釋:此技巧還可以用來實現其他的數據分布策略,例如分片(Sharding)。