日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
SpringCloud系列之Zuul網(wǎng)關和Zuul過濾器

Zuul網(wǎng)關

什么是Zuul網(wǎng)關?

Zuul是SpringCloud全家桶的微服務網(wǎng)關。所有從app或者網(wǎng)站(第三方)來的請求都會經(jīng)過Zuul到達后端的Netflix應用程序。作為一個邊界性質的應用程序,Zuul提供了動態(tài)路由、監(jiān)控、彈性負載和安全功能。

創(chuàng)新互聯(lián)公司擁有一支富有激情的企業(yè)網(wǎng)站制作團隊,在互聯(lián)網(wǎng)網(wǎng)站建設行業(yè)深耕10年,專業(yè)且經(jīng)驗豐富。10年網(wǎng)站優(yōu)化營銷經(jīng)驗,我們已為超過千家中小企業(yè)提供了網(wǎng)站建設、成都做網(wǎng)站解決方案,按需開發(fā),設計滿意,售后服務無憂。所有客戶皆提供一年免費網(wǎng)站維護!

Zuul底層利用filter實現(xiàn)如下功能:

  1. 認證和安全,識別每個需要認證的資源,拒絕不服務要求的請求。
  2. 性能檢測,在服務邊界追蹤并統(tǒng)計數(shù)據(jù),提供精確的生產(chǎn)視圖。
  3. 動態(tài)路由,根據(jù)需要將請求動態(tài)路由到后端集群。
  4. 壓力測試,逐漸增加對集群的流量以及了解其性能。
  5. 負載卸載,預先為每種類型的請求分配容量,當請求超過流量時自動丟棄。靜態(tài)資源處理,直接在邊界返回某種響應。
  6. 靜態(tài)資源處理,直接在Zuul處理靜態(tài)資源并響應,而并非轉發(fā)這些請求到內(nèi)部集群中。
  7. 多區(qū)域彈性,跨越AWS區(qū)域進行請求路由,旨在實現(xiàn)ELB使用多樣化并保證邊緣位置與使用者盡可能接近。

Zuul網(wǎng)關Demo

引入jar包:


org.springframework.cloud
spring-cloud-starter-eureka
1.3.5.RELEASE


org.springframework.cloud
spring-cloud-starter-zuul
1.3.5.RELEASE

配置文件:application.yml。

server:
port: 7004 # 端口
spring:
application:
name: zuul-getway # 服務名
eureka:
client:
service-url:
defaultZone: http://jack:666@localhost:8764/eureka/ # 需要注冊到eureka
instance:
instance-id: ${spring.application.name}:${server.port}
zuul:
routes:
order-service: /od/** # 對某個服務自定義路由規(guī)則
serviceId: order-service # 這個配置可以實現(xiàn)負載均衡,默認是輪詢
# 設置某些服務不要進行反向代理 進行路由,多個服務用逗號隔開
ignored-services: order-service, user-service
prefix: /api # 請求路徑的前綴

查看是否注冊到eureka。

Eureka注冊中心

訪問路徑:

localhost:7004/api/od/getOrder?token=1235。

(后面帶token是因為我配置了pre過濾器,下面會介紹)。

Zuul過濾器

Zuul四種過濾器類型,這些類型對應請求的生命周期

  • pre(前置):在請求被路由之前調(diào)用??衫眠@種過濾器來實現(xiàn)身份認證、在集群中選擇請求的微服務,記錄調(diào)試等。
  • routing(路由):將請求路由到微服務。用于構建發(fā)送給微服務的請求,并使用apache httpclient或netflix ribbon請求微服務。
  • post(后置):在路由到微服務后執(zhí)行??捎糜陧憫砑訕藴实膆ttp header、收集統(tǒng)計信息和指標、將響應從微服務發(fā)送到客戶端。
  • error(錯誤):在其他階段發(fā)送錯誤時執(zhí)行該過濾器。

注:除了默認的過濾器類型以外Zuul還允許創(chuàng)建自定義的過濾器類型。

如何禁用過濾器?

很簡單,只需設置zuul.ClassName.filterType.disable=true ,即可禁用SimpleClassName所對應的過濾器。例如:zuul.TokenFilter.pre.disable=true; 即可禁用TokenFilter過濾器。

pre過濾器

例子: 鑒權認證。如果參數(shù)帶了token就允許訪問。

/**
* pre過濾器
* @Author Big.Hu
*/
@Component
public class TokenFilter extends ZuulFilter {
@Override
public Object run() {
System.err.println("執(zhí)行pre前置過濾器。。。。。。。。。");
RequestContext currentContext = RequestContext.getCurrentContext();
HttpServletRequest request = currentContext.getRequest();
StringBuffer requestURL = request.getRequestURL();
System.out.println("requestURL:" + requestURL);
// 獲取請求的參數(shù)
String token = request.getParameter("token");
if (StringUtils.isEmpty(token)) {
// 如果參數(shù)為空則過濾該請求,不對其進行路由
currentContext.setSendZuulResponse(false);
// 設置錯誤碼:401
currentContext.setResponseStatusCode(HttpStatus.SC_UNAUTHORIZED);
currentContext.set("SUCCESS", false);
} else {
// 不過濾該請求,對其進行路由
currentContext.setSendZuulResponse(true);
// 設置成功碼:200
currentContext.setResponseStatusCode(HttpStatus.SC_OK);
currentContext.set("SUCCESS", true);
}
System.out.println("token:" + token);
return null;
}
/**
* 當前filter類型:pre、post、route、error
*/
@Override
public String filterType() {
return FilterConstants.PRE_TYPE;
}
/**
* 表示當前filter優(yōu)先級
*/
@Override
public int filterOrder() {
return FilterConstants.PRE_DECORATION_FILTER_ORDER - 1;
}
/**
* 是否執(zhí)行該過濾器?
**/
@Override
public boolean shouldFilter() {
return true;
}
}

POST過濾器

例: 在返回的時候設置一個cookie。

/**
* Post過濾器
* @Author Big.Hu
*/
@Component
public class PostFilter extends ZuulFilter {
/**
* POST過濾器:在route和error過濾器之后執(zhí)行
*/
@Override
public String filterType() {
return FilterConstants.POST_TYPE;
}
@Override
public int filterOrder() {
return FilterConstants.SEND_RESPONSE_FILTER_ORDER - 1;
}
@Override
public boolean shouldFilter() {
return true;
}
@Override
public Object run() {
System.err.println("執(zhí)行Post過濾器。。。。。。。。。");
RequestContext currentContext = RequestContext.getCurrentContext();
HttpServletResponse response = currentContext.getResponse();
Cookie cookie = new Cookie("name", "Jack.Hu");
cookie.setMaxAge(60 * 60 * 24);
response.addCookie(cookie);
return null;
}
}

訪問路徑:

localhost:7004/api/od/getOrder。

(沒帶token參數(shù))請求被pre過濾器過濾掉了。

不帶token請求

帶上token參數(shù)請求成功!

帶token請求

再按f12看post過濾器設置的cookie。

查看cookie

控制臺:

控制臺


分享名稱:SpringCloud系列之Zuul網(wǎng)關和Zuul過濾器
瀏覽地址:http://www.5511xx.com/article/djgcdso.html