您好,登錄后才能下訂單哦!
這篇文章主要介紹Spring Cloud中服務網關Zuul的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
在微服務架構中,需要幾個關鍵的組件,服務注冊與發現、服務消費、負載均衡、斷路器、智能路由、配置管理等,由這幾個組件可以組建一個簡單的微服務架構,如下圖:
客戶端的請求首先經過負載均衡(zuul、Ngnix),再到達服務網關(zuul集群),然后再到具體的服務,服務統一注冊到高可用的服務注冊中心集群,服務的所有的配置文件由配置服務管理(下一篇文章講述),配置服務的配置文件放在git倉庫,方便開發人員隨時改配置。
一、Zuul簡介
Zuul的主要功能是路由和過濾器。路由功能是微服務的一部分,比如/api/user映射到user服務,/api/shop映射到shop服務。zuul實現了負載均衡。
zuul有以下功能:
Authentication
Insights
Stress Testing
Canary Testing
Dynamic Routing
Service Migration
Load Shedding
Security
Static Response handling
Active/Active traffic management
二、準備工作
繼續使用上一節的工程。在原有的工程上,創建一個新的工程。
三、創建service-zuul工程
其pom.xml文件如下:
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-zuul</artifactId></dependency>
在其入口applicaton類加上注解@EnableZuulProxy,開啟zuul:
@EnableZuulProxy @EnableEurekaClient @SpringBootApplication public class ServiceZuulApplication { public static void main(String[] args) { SpringApplication.run(ServiceZuulApplication.class, args); } }
加上配置文件:
eureka: client: serviceUrl: defaultZone: http://localhost:8761/eureka/ server: port: 8769 spring: application: name: service-zuul zuul: routes: api-a: path: /api-a/** serviceId: service-ribbon api-b: path: /api-b/** serviceId: service-feign
首先向eureka注冊自己,端口為8769,服務名為service-zuul;以/api-a/ 開頭的請求都指向service-ribbon;以/api-b/開頭的請求都指向service-feign;
依次運行這五個工程;打開瀏覽器訪問:http://localhost:8769/api-a/hi?name=forezp ;瀏覽器顯示:
hi forezp,i am from port:8762
打開瀏覽器訪問:http://localhost:8769/api-b/hi?name=forezp ;瀏覽器顯示:
hi forezp,i am from port:8762
這說明zuul起到了路由的作用;
四、服務過濾
zuul不僅只是路由,并且還能過濾,做一些安全驗證。繼續改造工程;
@Component public class MyFilter extends ZuulFilter{ private static Logger log = LoggerFactory.getLogger(MyFilter.class); @Override public String filterType() { return "pre"; } @Override public int filterOrder() { return 0; } @Override public boolean shouldFilter() { return true; } @Override public Object run() { RequestContext ctx = RequestContext.getCurrentContext(); HttpServletRequest request = ctx.getRequest(); log.info(String.format("%s >>> %s", request.getMethod(), request.getRequestURL().toString())); Object accessToken = request.getParameter("token"); if(accessToken == null) { log.warn("token is empty"); ctx.setSendZuulResponse(false); ctx.setResponseStatusCode(401); try { ctx.getResponse().getWriter().write("token is empty"); }catch (Exception e){} return null; } log.info("ok"); return null; } }
filterType:返回一個字符串代表過濾器的類型,在zuul中定義了四種不同生命周期的過濾器類型,具體如下:
pre:路由之前
routing:路由之時
post: 路由之后
error:發送錯誤調用
filterOrder:過濾的順序
shouldFilter:這里可以寫邏輯判斷,是否要過濾,本文true,永遠過濾。
run:過濾器的具體邏輯。可用很復雜,包括查sql,nosql去判斷該請求到底有沒有權限訪問。
這時訪問:http://localhost:8769/api-a/hi?name=forezp ;網頁顯示:
token is empty
訪問 http://localhost:8769/api-a/hi?name=forezp&token=22 ; 網頁顯示:
hi forezp,i am from port:8762
以上是“Spring Cloud中服務網關Zuul的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。