com.huawei.discovery.interceptors.httpconnection.HttpUrlConnectionConnectInterceptor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of springboot-registry-plugin Show documentation
Show all versions of springboot-registry-plugin Show documentation
The plugin module of registry from springboot
/*
* Copyright (C) 2022-2022 Huawei Technologies Co., Ltd. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.huawei.discovery.interceptors.httpconnection;
import com.huawei.discovery.config.LbConfig;
import com.huawei.discovery.interceptors.MarkInterceptor;
import com.huawei.discovery.retry.InvokerContext;
import com.huawei.discovery.service.InvokerService;
import com.huawei.discovery.utils.HttpConnectionUtils;
import com.huawei.discovery.utils.HttpConnectionUtils.HttpConnectionContext;
import com.huawei.discovery.utils.HttpConstants;
import com.huawei.discovery.utils.PlugEffectWhiteBlackUtils;
import com.huawei.discovery.utils.RequestInterceptorUtils;
import com.huaweicloud.sermant.core.common.LoggerFactory;
import com.huaweicloud.sermant.core.plugin.agent.entity.ExecuteContext;
import com.huaweicloud.sermant.core.plugin.config.PluginConfigManager;
import com.huaweicloud.sermant.core.plugin.service.PluginServiceManager;
import com.huaweicloud.sermant.core.utils.ReflectUtils;
import java.net.InetSocketAddress;
import java.net.Proxy;
import java.net.Proxy.Type;
import java.net.URL;
import java.util.Map;
import java.util.Optional;
import java.util.concurrent.ConcurrentHashMap;
import java.util.function.Function;
import java.util.logging.Level;
import java.util.logging.Logger;
/**
* 拦截HttpUrlConnection#connect方法, 检查SocketTimeoutException: connect timed out
*
* @author zhouss
* @since 2022-10-20
*/
public class HttpUrlConnectionConnectInterceptor extends MarkInterceptor {
private static final Logger LOGGER = LoggerFactory.getLogger();
/**
* 代理缓存, 针对用户使用代理的情况
* key: host
* value: Proxy
*/
private final Map proxyCache;
private final LbConfig lbConfig;
/**
* 构造器
*/
public HttpUrlConnectionConnectInterceptor() {
this.lbConfig = PluginConfigManager.getPluginConfig(LbConfig.class);
if (this.lbConfig.isEnableCacheProxy()) {
proxyCache = new ConcurrentHashMap<>();
} else {
proxyCache = null;
}
}
@Override
protected ExecuteContext doBefore(ExecuteContext context) throws Exception {
final InvokerService invokerService = PluginServiceManager.getPluginService(InvokerService.class);
final Optional rawUrl = getUrl(context.getObject());
if (!rawUrl.isPresent()) {
return context;
}
final URL url = rawUrl.get();
if (!PlugEffectWhiteBlackUtils.isHostEqualRealmName(url.getHost())) {
return context;
}
final String fullUrl = url.toString();
Map urlInfo = RequestInterceptorUtils.recoverUrl(url);
if (!PlugEffectWhiteBlackUtils.isPlugEffect(urlInfo.get(HttpConstants.HTTP_URI_SERVICE))) {
return context;
}
HttpConnectionUtils.save(new HttpConnectionContext(urlInfo, url));
RequestInterceptorUtils.printRequestLog("HttpURLConnection", urlInfo);
invokerService.invoke(
buildInvokerFunc(context, url, urlInfo),
ex -> ex,
urlInfo.get(HttpConstants.HTTP_URI_SERVICE))
.ifPresent(obj -> {
if (obj instanceof Exception) {
LOGGER.log(Level.SEVERE, "request is error, uri is " + fullUrl, (Exception) obj);
context.setThrowableOut((Exception) obj);
return;
}
context.skip(obj);
});
return context;
}
private Optional getUrl(Object target) {
final Optional