All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.taobao.api.internal.cluster.DnsConfig Maven / Gradle / Ivy

The newest version!
package com.taobao.api.internal.cluster;

import java.net.URI;
import java.net.URL;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Random;

import com.taobao.api.internal.util.StringUtils;
import com.taobao.api.internal.util.TaobaoHashMap;
import com.taobao.api.internal.util.TaobaoUtils;

public class DnsConfig {

	private Map globalMap;
	private Map modleMap;
	private Map apiMap;
	private Map> envMap;
	private Map> userMap;

	public static DnsConfig parse(String json) {
		if(json == null || json.length() == 0){
			return null;
		}
		DnsConfig dnsConfig = new DnsConfig();
		Map root = (Map) TaobaoUtils.jsonToObject(json);

		for (Object configType : root.keySet()) {
			if ("config".equals(configType)) {
				dnsConfig.globalMap = new HashMap();
				Map globalInfo = (Map) root.get(configType);
				for (Object key : globalInfo.keySet()) {
					dnsConfig.globalMap.put(String.valueOf(key), String.valueOf(globalInfo.get(key)));
				}
			} else if ("env".equals(configType)) {
				Map envInfos = (Map) root.get(configType);
				dnsConfig.envMap = new HashMap>();
				for (Object envName : envInfos.keySet()) {
					Map envInfo = (Map) envInfos.get(envName);
					List envConfigs = new ArrayList();

					for (Object domainName : envInfo.keySet()) {
						Map domainInfo = (Map) envInfo.get(domainName);
						EnvConfig envConfig = new EnvConfig();
						envConfig.setDomain(String.valueOf(domainName));
						envConfig.setProtocol(String.valueOf(domainInfo.get("proto")));
						List vipInfos = (List) domainInfo.get("vip");
						List vipRules = new ArrayList();
						for (Object vipInfo : vipInfos) {
							String[] vipInfoTmp = vipInfo.toString().split("\\|");
							VipRule vipRule = new VipRule();
							vipRule.setVip(vipInfoTmp[0]);
							vipRule.setWeight(Double.parseDouble(vipInfoTmp[1]));
							vipRules.add(vipRule);
						}
						envConfig.setVipRules(vipRules);
						envConfigs.add(envConfig);
					}
					dnsConfig.envMap.put(String.valueOf(envName), envConfigs);
				}
			} else if ("api".equals(configType)) {
				dnsConfig.apiMap = new HashMap();
				Map apiInfos = (Map) root.get(configType);
				for (Object apiName : apiInfos.keySet()) {
					Map apiInfo = (Map) apiInfos.get(apiName);
					ApiConfig apiConfig = new ApiConfig();
					apiConfig.setUser(String.valueOf(apiInfo.get("user")));
					if(apiInfo.get("modle") != null){
						ApiModle apiModle = new ApiModle();
						String modle = String.valueOf(apiInfo.get("modle"));
						apiModle.setField(modle.split("\\|")[1]);
						apiModle.setModle(modle.split("\\|")[0]);
						apiConfig.setModle(apiModle);
					}
					List apiRules = new ArrayList();
					List apiRuleInfos = (List) apiInfo.get("rule");
					for (Object apiRuleInfo : apiRuleInfos) {
						String[] apiRuleInfoTmp = apiRuleInfo.toString().split("\\|");
						ApiRule apiRule = new ApiRule();
						apiRule.setName(apiRuleInfoTmp[0]);
						apiRule.setWeight(Double.parseDouble(apiRuleInfoTmp[1]));
						apiRules.add(apiRule);
					}
					apiConfig.setRules(apiRules);
					dnsConfig.apiMap.put(String.valueOf(apiName), apiConfig);
				}
			} else if ("user".equals(configType)) {
				dnsConfig.userMap = new HashMap>();
				Map userInfos = (Map) root.get(configType);
				for (Object routeName : userInfos.keySet()) {
					Map envInfos = (Map) userInfos.get(routeName);
					Map tags = new HashMap();
					for (Object envName : envInfos.keySet()) {
						List tagInfos = (List) envInfos.get(envName);
						for (Object tagName : tagInfos) {
							tags.put(String.valueOf(tagName), String.valueOf(envName));
						}
					}
					dnsConfig.userMap.put(String.valueOf(routeName), tags);
				}
			} else if("modle".equals(configType)){
				dnsConfig.modleMap = new HashMap();
				Map modleInfo = (Map) root.get(configType);
				for (Object key : modleInfo.keySet()) {
					dnsConfig.modleMap.put(String.valueOf(key), Integer.parseInt(modleInfo.get(key).toString()));
				}
			}
		}

		return dnsConfig;
	}
	
	public String getEnvVip(String envName,String serverUrl) {
		List envVipList = envMap.get(envName);
		if(envVipList != null && envVipList.size() > 0){
			return getEnvVipUrl(serverUrl,envVipList);
		}
		return serverUrl;
	}

	public String getBestVipUrl(String serverUrl, String apiName, String session,TaobaoHashMap appParams) {
		if (apiMap.containsKey(apiName)) {
			ApiConfig apiConfig = apiMap.get(apiName);
			String flag = null;
			//user modle,default
			if (!StringUtils.isEmpty(session) && apiConfig.getUser() != null && apiConfig.getModle() == null) {
				flag = getUserFlag(session);
			}
			//other modle
			if(apiConfig.getUser() != null && apiConfig.getModle() != null){
				flag = getModleFlag(apiConfig,appParams);
			}
			//if modle matched
			if (flag != null && userMap.containsKey(apiConfig.getUser())) {
				Map userEnvs = userMap.get(apiConfig.getUser());
				if (userEnvs.containsKey(flag)) {
					String userEnv = userEnvs.get(flag);
					if (envMap.containsKey(userEnv)) {
						List envConfigs = envMap.get(userEnv);
						return getEnvVipUrl(serverUrl, envConfigs);
					}
				}
			}
			return getApiVipUrl(serverUrl, apiConfig);
		} else {
			List envConfigs = envMap.get(globalMap.get("def_env"));
			return getEnvVipUrl(serverUrl, envConfigs);
		}
	}
	
	public String getVipUrl(String serverUrl) {
	    if(envMap == null || globalMap == null || globalMap.get("def_env") == null
	                      || serverUrl == null || serverUrl.length() == 0){
	        return serverUrl;
	    }
        List envConfigs = envMap.get(globalMap.get("def_env"));
        if(envConfigs == null || envConfigs.isEmpty()){
            return serverUrl;
        }
        try {
            return getBalancedUrl(serverUrl, envConfigs);
        } catch (Exception e) {
            return  serverUrl;
        }
        
    }
	
	private String getModleFlag(ApiConfig apiConfig,TaobaoHashMap appParams){
		String modle = apiConfig.getModle().getModle();
		String field = apiConfig.getModle().getField();
		if(modle != null && field != null && appParams.containsKey(field)){
			String value = appParams.get(field);
			Integer modleFalg = modleMap.get(modle);
			if(modleFalg < 0){
				return value.substring(value.length() + modleFalg,value.length() + modleFalg+1);
			}else{
				return value.substring(modleFalg,modleFalg+1);
			}
		}
		return null;
	}

	private String getApiVipUrl(String serverUrl, ApiConfig apiConfig) {
		ApiRule apiRule = ClusterManager.getElementByWeight(apiConfig.getRules());
		if (envMap.containsKey(apiRule.getName())) {
			List envConfigs = envMap.get(apiRule.getName());
			return getEnvVipUrl(serverUrl, envConfigs);
		} else {
			List envConfigs = envMap.get(globalMap.get("def_env"));
			return getEnvVipUrl(serverUrl, envConfigs);
		}
	}

	private String getEnvVipUrl(String serverUrl, List envConfigs) {
		for (EnvConfig envConfig : envConfigs) {
			try {
				URI uri = new URI(serverUrl);
				if (uri.getHost().equalsIgnoreCase(envConfig.getDomain()) && uri.getScheme().equalsIgnoreCase(envConfig.getProtocol())) {
					String vip = ClusterManager.getElementByWeight(envConfig.getVipRules()).getVip();
					return serverUrl.replace(envConfig.getDomain(), vip);
				}
			} catch (Exception e) {
				continue; // ignore invalid url
			}
		}
		return serverUrl;
	}
	
	private String getBalancedUrl(String serverUrl, List envConfigs) throws Exception {
	    URL uri = new URL(serverUrl);
	    String host = uri.getHost();
	    String scheme = uri.getProtocol();
        for (EnvConfig envConfig : envConfigs) {
            try {
                if (host.equalsIgnoreCase(envConfig.getDomain())) {
                    List  vipRuleList = envConfig.getVipRules();
                    if(vipRuleList == null || vipRuleList.isEmpty()){
                        return serverUrl;
                    }
                    Random random = new Random();
                    String  vip = vipRuleList.get(random.nextInt(vipRuleList.size())).getVip();
                    if(vip == null || vip.length() == 0){
                        return serverUrl;
                    }
                    StringBuilder urlBuilder = new StringBuilder(); 
                    urlBuilder.append(scheme).append("://").append(vip);
                    if(uri.getPort() > 0){
                        urlBuilder.append(":").append(uri.getPort());
                    }
                    if(uri.getFile() != null){
                        urlBuilder.append(uri.getFile());
                    }
                    return urlBuilder.toString();
                }
            } catch (Exception e) {
                continue; // ignore invalid url
            }
        }
        return serverUrl;
    }
	
	

	private String getUserFlag(String session) {
		if (!StringUtils.isEmpty(session) && session.length() > 5) {
			if (session.startsWith("6") || session.startsWith("7")) {
				return session.substring(session.length() - 1, session.length());
			} else if (session.startsWith("5") || session.startsWith("8")) {
				return session.substring(5, 5 + 1);
			}
		}
		return null;
	}
	
	public long getVersion(){
		if(globalMap == null){
	        return 0L;
	    }
		String tmp = globalMap.get("version");
		try{
			if (tmp != null) {
				return Long.parseLong(tmp);
			} else {
				return 0L;
			}
		}catch(Exception e){
			return 0L;
		}
	}

	public int getRefreshInterval() {
	    if(globalMap == null){
	        return 15;
	    }
		String tmp = globalMap.get("interval");
		if (tmp != null) {
			return Integer.parseInt(tmp);
		} else {
			return 15;// 默认15分钟刷新一次
		}
	}
	

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy