1.使用技術html
Springboot,SpringCloud,Zuul,Nignxjava
2.目的nginx
使用Zuul搭建微服務高可用的網關spring
3.項目建立apache
3.1 建立註冊中心(略)api
3.2 建立一個hello-service的服務工程服務器
3.3 建立springcloud-zuul-ha網關服務app
3.3.1 建立工程(略)負載均衡
3.3.2 pom.xmlmaven
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>qinfeng.zheng</groupId> <artifactId>springcloud-zuul-ha</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>springcloud-zuul-ha</name> <description>Demo project for Spring Boot</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zuul</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> </dependency> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <!--Dalston.RC1這個高版本的zuul依賴有問題--> <version>Brixton.SR7</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
3.3.3 application.yml
###服務註冊地址 eureka: client: serviceUrl: defaultZone: http://localhost:8763/eureka/ ###api網關端口號 server: port: 82 ###網關名稱 spring: application: name: service-zuul zuul: routes: ###定義轉發服務規則 api-a: path: /api-hello/** #請求路徑中含有api-hello,都會轉發到hello-service服務 ###服務別名 zuul網關默認整合ribbon 自動實現負載均衡輪訓效果 serviceId: hello-service
3.3.4 定義一個過濾器
qinfeng.zheng.filter.AccessFilter
import com.netflix.zuul.ZuulFilter; import com.netflix.zuul.context.RequestContext; import org.apache.commons.lang.StringUtils; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; import javax.servlet.http.HttpServletRequest; /** * 建立時間: 16:07 2018/7/16 * 修改時間: * 編碼人員: ZhengQf * 版 本: 0.0.1 * 功能描述: 自定義一個Zuul Filter,它在請求路由以前進行過濾 * * 補: zuul兩大功能: 1.路由請求 * 2.過濾 */ @Component public class AccessFilter extends ZuulFilter { @Value("${server.port}") private String serverPort; /** * 過濾器的類型,它決定過濾器在請求的哪一個生命週期中執行, * pre:請求被路由以前作一些前置工做 ,好比請求和校驗 * routing : 在路由請求時被調用,路由請求轉發,便是將請求轉發到具體的服務實例上去. * post : 在routing 和 error過濾器以後被調用..因此post類型的過濾器能夠對請求結果進行一些加工 * error :處理請求發生錯誤時調用 */ @Override public String filterType() { return "pre"; // } /** *過濾器的執行順序. *在一個階段有多個過濾器時,須要用此指定過濾順序 * 數值越小優先級越高 */ @Override public int filterOrder() { return 0; } /** * 判斷過濾器是否執行,直接返回true,表明對全部請求過濾 * 此方法指定過濾範圍 * @return */ @Override public boolean shouldFilter() { return true; } /** * 過濾的具體邏輯 * @return */ @Override public Object run() { // 1.獲取上下文 RequestContext currentContext = RequestContext.getCurrentContext(); // 2.獲取 Request HttpServletRequest request = currentContext.getRequest(); // 3.獲取token 的時候 從請求頭中獲取 String token = request.getParameter("token"); request.setAttribute("serverPort", serverPort); if (StringUtils.isEmpty(token)) { // 不會繼續執行... 不會去調用服務接口,網關服務直接響應給客戶端 currentContext.setSendZuulResponse(false); currentContext.setResponseBody("token is null"); currentContext.setResponseStatusCode(401); return null; // 返回一個錯誤提示 } // 正常執行調用其餘服務接口... System.out.println("網關執行端口號:" + serverPort); return null; } }
3.3.5 啓動類
import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.EnableEurekaClient; import org.springframework.cloud.netflix.zuul.EnableZuulProxy; @EnableZuulProxy @EnableEurekaClient @SpringBootApplication public class SpringcloudZuulHaApplication { public static void main(String[] args) { SpringApplication.run(SpringcloudZuulHaApplication.class, args); } }
3.3.6 啓動網關項目
使用server.port模擬兩個網關項目,端口號分別爲81,82 -------> 測試網關高可用
使用server.port模擬兩個hello-service項目,端口號分別爲8080,8081 ---->測試zuul的路由時,自動負載均衡
查看註冊中心,一共有四個服務:
3.4 nginx配置負載均衡,而後 cmd ,start nginx.exe啓動nginx服務
upstream backServer{
server 127.0.0.1:81;
server 127.0.0.1:82;
}
server {
listen 80;
server_name qinfeng.zheng.com;
location / {
### 指定上游服務器負載均衡服務器
proxy_pass http://backServer/;
index index.html index.htm;
}
}
3.5 在本地host文件中配置 qinfeng.zheng.com 的域名
4.測試
第一次請求: http://qinfeng.zheng.com/api-hello/hello/index?token=123
第二次請求:http://qinfeng.zheng.com/api-hello/hello/index?token=123
5.總結
1.使用nignx負載均衡和反向代理技術能夠實現網關的高可用
2.zuul網關自動集成ribbon客戶端,實現路由的負載均衡