日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

nacos中DistroFilter的作用是什么

發布時間:2023/12/15 综合教程 31 生活家
生活随笔 收集整理的這篇文章主要介紹了 nacos中DistroFilter的作用是什么 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本篇文章為大家展示了nacos中DistroFilter的作用是什么,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

CanDistro

nacos-1.1.3/naming/src/main/java/com/alibaba/nacos/naming/web/CanDistro.java

@Retention(RetentionPolicy.RUNTIME)
public@interfaceCanDistro{
}
  • CanDistro用于標識一個方法需要判斷是否應該根據distro被重定向

DistroFilter

nacos-1.1.3/naming/src/main/java/com/alibaba/nacos/naming/web/DistroFilter.java

publicclassDistroFilterimplementsFilter{

privatestaticfinalintPROXY_CONNECT_TIMEOUT=2000;
privatestaticfinalintPROXY_READ_TIMEOUT=2000;

@Autowired
privateDistroMapperdistroMapper;

@Autowired
privateSwitchDomainswitchDomain;

@Autowired
privateFilterBasefilterBase;

@Override
publicvoidinit(FilterConfigfilterConfig)throwsServletException{

}

@Override
publicvoiddoFilter(ServletRequestservletRequest,ServletResponseservletResponse,FilterChainfilterChain)throwsIOException,ServletException{
HttpServletRequestreq=(HttpServletRequest)servletRequest;
HttpServletResponseresp=(HttpServletResponse)servletResponse;

StringurlString=req.getRequestURI();

if(StringUtils.isNotBlank(req.getQueryString())){
urlString+="?"+req.getQueryString();
}

try{
Stringpath=newURI(req.getRequestURI()).getPath();
StringserviceName=req.getParameter(CommonParams.SERVICE_NAME);
//Forclientunder0.8.0:
if(StringUtils.isBlank(serviceName)){
serviceName=req.getParameter("dom");
}
Methodmethod=filterBase.getMethod(req.getMethod(),path);

if(method==null){
thrownewNoSuchMethodException(req.getMethod()+""+path);
}

StringgroupName=req.getParameter(CommonParams.GROUP_NAME);
if(StringUtils.isBlank(groupName)){
groupName=Constants.DEFAULT_GROUP;
}

//usegroupName@@serviceNameasnewservicename:
StringgroupedServiceName=serviceName;
if(StringUtils.isNotBlank(serviceName)&&!serviceName.contains(Constants.SERVICE_INFO_SPLITER)){
groupedServiceName=groupName+Constants.SERVICE_INFO_SPLITER+serviceName;
}

//proxyrequesttootherserverifnecessary:
if(method.isAnnotationPresent(CanDistro.class)&&!distroMapper.responsible(groupedServiceName)){

StringuserAgent=req.getHeader("User-Agent");

if(StringUtils.isNotBlank(userAgent)&&userAgent.contains(UtilsAndCommons.NACOS_SERVER_HEADER)){
//Thisrequestissentfrompeerserver,shouldnotberedirectedagain:
Loggers.SRV_LOG.error("receiveinvalidredirectrequestfrompeer{}",req.getRemoteAddr());
resp.sendError(HttpServletResponse.SC_BAD_REQUEST,
"receiveinvalidredirectrequestfrompeer"+req.getRemoteAddr());
return;
}

List<String>headerList=newArrayList<>(16);
Enumeration<String>headers=req.getHeaderNames();
while(headers.hasMoreElements()){
StringheaderName=headers.nextElement();
headerList.add(headerName);
headerList.add(req.getHeader(headerName));
}
HttpClient.HttpResultresult=
HttpClient.request("http://"+distroMapper.mapSrv(groupedServiceName)+urlString,headerList,
StringUtils.isBlank(req.getQueryString())?HttpClient.translateParameterMap(req.getParameterMap()):newHashMap<>(2)
,PROXY_CONNECT_TIMEOUT,PROXY_READ_TIMEOUT,"UTF-8",req.getMethod());

try{
resp.setCharacterEncoding("UTF-8");
resp.getWriter().write(result.content);
resp.setStatus(result.code);
}catch(Exceptionignore){
Loggers.SRV_LOG.warn("[DISTRO-FILTER]requestfailed:"+distroMapper.mapSrv(groupedServiceName)+urlString);
}
return;
}

OverrideParameterRequestWrapperrequestWrapper=OverrideParameterRequestWrapper.buildRequest(req);
requestWrapper.addParameter(CommonParams.SERVICE_NAME,groupedServiceName);
filterChain.doFilter(requestWrapper,resp);
}catch(AccessControlExceptione){
resp.sendError(HttpServletResponse.SC_FORBIDDEN,"accessdenied:"+UtilsAndCommons.getAllExceptionMsg(e));
return;
}catch(NoSuchMethodExceptione){
resp.sendError(HttpServletResponse.SC_NOT_IMPLEMENTED,"nosuchapi:"+e.getMessage());
return;
}catch(Exceptione){
resp.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR,
"Serverfailed,"+UtilsAndCommons.getAllExceptionMsg(e));
return;
}

}

@Override
publicvoiddestroy(){

}
}
  • DistroFilter實現了servlet的Filter接口;其doFilter方法會從servletRequest中讀取serviceName、method、groupName等,然后判斷method是否標注CanDistro,如果是而且distroMapper不負責該service則構建http請求然后將結果寫回Filter;如果不需要重定向則繼續filterChain.doFilter

HttpClient.request

nacos-1.1.3/naming/src/main/java/com/alibaba/nacos/naming/misc/HttpClient.java

publicclassHttpClient{
privatestaticfinalintTIME_OUT_MILLIS=10000;
privatestaticfinalintCON_TIME_OUT_MILLIS=5000;

privatestaticAsyncHttpClientasyncHttpClient;

privatestaticCloseableHttpClientpostClient;

//......

publicstaticHttpResultrequest(Stringurl,List<String>headers,Map<String,String>paramValues,intconnectTimeout,intreadTimeout,Stringencoding,Stringmethod){
HttpURLConnectionconn=null;
try{
StringencodedContent=encodingParams(paramValues,encoding);
url+=(null==encodedContent)?"":("?"+encodedContent);

conn=(HttpURLConnection)newURL(url).openConnection();
conn.setConnectTimeout(connectTimeout);
conn.setReadTimeout(readTimeout);
conn.setRequestMethod(method);

conn.addRequestProperty("Client-Version",UtilsAndCommons.SERVER_VERSION);
conn.addRequestProperty("User-Agent",UtilsAndCommons.SERVER_VERSION);
setHeaders(conn,headers,encoding);
conn.connect();

returngetResult(conn);
}catch(Exceptione){
Loggers.SRV_LOG.warn("Exceptionwhilerequest:{},caused:{}",url,e);
returnnewHttpResult(500,e.toString(),Collections.<String,String>emptyMap());
}finally{
if(conn!=null){
conn.disconnect();
}
}
}

privatestaticHttpResultgetResult(HttpURLConnectionconn)throwsIOException{
intrespCode=conn.getResponseCode();

InputStreaminputStream;
if(HttpURLConnection.HTTP_OK==respCode){
inputStream=conn.getInputStream();
}else{
inputStream=conn.getErrorStream();
}

Map<String,String>respHeaders=newHashMap<String,String>(conn.getHeaderFields().size());
for(Map.Entry<String,List<String>>entry:conn.getHeaderFields().entrySet()){
respHeaders.put(entry.getKey(),entry.getValue().get(0));
}

StringgzipEncoding="gzip";

if(gzipEncoding.equals(respHeaders.get(HttpHeaders.CONTENT_ENCODING))){
inputStream=newGZIPInputStream(inputStream);
}

HttpResultresult=newHttpResult(respCode,IOUtils.toString(inputStream,getCharset(conn)),respHeaders);
inputStream.close();

returnresult;
}

publicstaticclassHttpResult{
finalpublicintcode;
finalpublicStringcontent;
finalprivateMap<String,String>respHeaders;

publicHttpResult(intcode,Stringcontent,Map<String,String>respHeaders){
this.code=code;
this.content=content;
this.respHeaders=respHeaders;
}

publicStringgetHeader(Stringname){
returnrespHeaders.get(name);
}
}

//......
}
  • HttpClient的request方法直接使用jdk的HttpURLConnection進行請求,返回結果封裝為HttpResult,其content即為響應的body

小結

DistroFilter實現了servlet的Filter接口;其doFilter方法會從servletRequest中讀取serviceName、method、groupName等,然后判斷method是否標注CanDistro,如果是而且distroMapper不負責該service則構建http請求然后將結果寫回Filter;如果不需要重定向則繼續filterChain.doFilter

總結

以上是生活随笔為你收集整理的nacos中DistroFilter的作用是什么的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 久久精品免费看 | 亚洲av无码一区二区三区在线播放 | av噜噜在线观看 | 秘密基地在线观看完整版免费 | 欧美国产三级 | 狼人伊人久久 | 欧美成人黄色 | 操综合网| 99精品一级欧美片免费播放 | 网友自拍视频 | 成人不卡在线 | 欧美成人免费网站 | 99热国产在线 | 成人免费无码大片a毛片抽搐色欲 | 九色蝌蚪9l视频蝌蚪9l视频 | 青青色在线 | 露脸啪啪清纯大学生美女 | 一级黄色大片免费看 | 国产精品99久久久久久动医院 | 男女扒开双腿猛进入爽爽免费 | 亚洲精品乱码久久久久久蜜桃91 | 久久久亚洲一区 | 天天艹日日干 | 中国人与拘一级毛片 | 少妇性色av | 18岁免费观看电视连续剧 | 欧美大尺度视频 | 精品成人免费视频 | 另类小说亚洲色图 | xxxxxx黄色 | 无码人妻精品一区二区三区99不卡 | 欧美人体视频一区二区三区 | 日本精品视频在线播放 | 北条麻妃一区二区三区在线观看 | 色小姐在线视频 | 亚洲AV无码成人精品区东京热 | 日韩大片免费看 | 操你妹影院 | 久久久久亚洲精品系列色欲 | 456亚洲影视| 日韩性网站 | 日本黄色美女 | 欧美 亚洲 一区 | 久久99深爱久久99精品 | 黄片毛片在线观看 | 火影忍者羞羞漫画 | 国产农村妇女aaaaa视频 | 精品国产自在精品国产精小说 | www.久久av| 中文在线资源天堂 | 欧美少妇色图 | 日韩www | 97色吧| 中出白浆| 91导航| 国产高潮又爽又无遮挡又免费 | 久色伊人 | 四虎网址大全 | a级黄色网址 | 美女免费福利视频 | 中文字幕一区二区在线观看 | 老鸭窝一区二区 | 五月依人网 | a毛片视频 | 日日夜夜国产精品 | 国产精品无码一区二区三区免费 | 亚洲综合色av| 国产性―交―乱―色―情人 | 久久国产精品久久久久 | 国产在线中文 | 91精品国产色综合久久不卡粉嫩 | 粉嫩av一区二区三区天美传媒 | 亚洲欧美在线成人 | 国产欧美一区二区三区在线老狼 | 国产白浆一区二区 | 日本热久久 | 日日干夜夜操 | 日韩三级不卡 | 越南毛茸茸的少妇 | 国产乱强伦一区二区三区 | 欧美a级成人淫片免费看 | 97精品一区二区 | 国产毛片精品 | 免费三级av| 国产一二三四五区 | 99国产精品一区 | 国产精品第五页 | 乱人伦av| 亚色一区 | 免费看黄在线观看 | 谁有免费的黄色网址 | 日韩精品久久久久久久酒店 | 99国产精品久久久久 | 国产毛片在线看 | 日韩精品久久久久久久酒店 | 国产精品三级视频 | 免费成人美女女 | 隔壁人妻偷人bd中字 | 九七影院在线观看免费观看电视 |