亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

淺談SpringCloud實現簡單的微服務架構

2024-07-13 10:16:22
字體:
來源:轉載
供稿:網友

Spring Cloud是一系列框架的有序集合。它利用Spring Boot的開發便利性巧妙地簡化了分布式系統基礎設施的開發,如服務發現注冊、配置中心、消息總線、負載均衡、斷路器、數據監控等,都可以用Spring Boot的開發風格做到一鍵啟動和部署。Spring并沒有重復制造輪子,它只是將目前各家公司開發的比較成熟、經得起實際考驗的服務框架組合起來,通過Spring Boot風格進行再封裝屏蔽掉了復雜的配置和實現原理,最終給開發者留出了一套簡單易懂、易部署和易維護的分布式系統開發工具包。

接下來我們就使用SpringCloud實現一套簡單的微服務架構。

以下所有代碼都已開源到github上了,地址:https://github.com/lynnlovemin/softservice

Eureka(服務注冊與發現)

首先引入相關的依賴包

<parent>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-parent</artifactId>    <version>1.5.9.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-eureka</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.cloud</groupId>      <artifactId>spring-cloud-starter-eureka-server</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-web</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-test</artifactId>      <scope>test</scope>    </dependency>  </dependencies>  <dependencyManagement>    <dependencies>      <dependency>        <groupId>org.springframework.cloud</groupId>        <artifactId>spring-cloud-dependencies</artifactId>        <version>Dalston.RC1</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>  <repositories>    <repository>      <id>spring-milestones</id>      <name>Spring Milestones</name>      <url>https://repo.spring.io/milestone</url>      <snapshots>        <enabled>false</enabled>      </snapshots>    </repository>  </repositories>

配置application.yml

server: port: 8761eureka: instance:  hostname: localhost client:  registerWithEureka: false  fetchRegistry: false  serviceUrl:   defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

創建啟動類Application

@EnableEurekaServer@SpringBootApplicationpublic class Application {  public static void main(String[] args) {    SpringApplication.run(Application.class, args);  }}

運行main方法,瀏覽器訪問:http://localhost:8761,我們就能在瀏覽器看到如下界面:

Spring,Cloud,微服務架構,微服務

說明eureka啟動成功。

接下來,我們實現負債均衡、斷路器、網關、客戶端,所有的服務都應該注冊到eureka中,并且訪問eureka就能看到所有注冊的服務

client(客戶端)

pom.xml

<parent>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-parent</artifactId>    <version>1.5.9.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-eureka</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-web</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-test</artifactId>      <scope>test</scope>    </dependency>  </dependencies>  <dependencyManagement>    <dependencies>      <dependency>        <groupId>org.springframework.cloud</groupId>        <artifactId>spring-cloud-dependencies</artifactId>        <version>Dalston.RC1</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>  <repositories>    <repository>      <id>spring-milestones</id>      <name>Spring Milestones</name>      <url>https://repo.spring.io/milestone</url>      <snapshots>        <enabled>false</enabled>      </snapshots>    </repository>  </repositories>

application.yml

eureka: client:  serviceUrl:   defaultZone: http://localhost:8761/eureka/ #這里注冊到eureka中server: port: 8763spring: application:  name: service-hi

Application類

@SpringBootApplication@EnableEurekaClient@RestControllerpublic class Application {  public static void main(String[] args) {    SpringApplication.run(Applicatioin.class, args);  }  @Value("${server.port}")  String port;  //這里我們提供一個接口  @RequestMapping("/hi")  public String home(@RequestParam String name) {    return "hi "+name+",i am from port:" +port;  }}

Feign(負債均衡、斷路器)

pom.xml

<parent>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-parent</artifactId>    <version>1.5.9.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-eureka</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-web</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.cloud</groupId>      <artifactId>spring-cloud-starter-feign</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-actuator</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.cloud</groupId>      <artifactId>spring-cloud-starter-hystrix-dashboard</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-test</artifactId>      <scope>test</scope>    </dependency>  </dependencies>  <dependencyManagement>    <dependencies>      <dependency>        <groupId>org.springframework.cloud</groupId>        <artifactId>spring-cloud-dependencies</artifactId>        <version>Dalston.RC1</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>  <repositories>    <repository>      <id>spring-milestones</id>      <name>Spring Milestones</name>      <url>https://repo.spring.io/milestone</url>      <snapshots>        <enabled>false</enabled>      </snapshots>    </repository>  </repositories>

application.yml

eureka: client:  serviceUrl:   defaultZone: http://localhost:8761/eureka/server: port: 8765spring: application:  name: service-feignfeign: hystrix:  enabled: true

Application類

@SpringBootApplication@EnableDiscoveryClient@EnableFeignClients@EnableHystrixDashboardpublic class Application {  public static void main(String[] args) {    SpringApplication.run(Application.class, args);  }}

然后再提供一個service,他的作用就是做負債均衡和斷路器功能

@FeignClient(value = "service-hi",fallback = SchedualServiceHiHystric.class)public interface SchedualServiceHi {  @RequestMapping(value = "/hi",method = RequestMethod.GET)  String sayHiFromClientOne(@RequestParam(value = "name") String name);}
@Componentpublic class SchedualServiceHiHystric implements SchedualServiceHi {  @Override  public String sayHiFromClientOne(String name) {    return "sorry "+name;  }}

FeignClient我們指定之前創建client時指定的name:service-hi,fallback指定服務不可用時的返回數據,這樣我們啟動多個client時就可以看到http請求時會交替訪問不同的feign端口,當停掉clien時再訪問接口會返回錯誤信息。

zuul(服務網關)

在一般情況下,我們不會直接暴露客戶端給外部,而是通過服務網關來轉發,內部服務都是在局域網內通信,外部訪問不了,通過服務網關,我們還可以統一做接口的安全性校驗,統一攔截,請看代碼:

pom.xml

<parent>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-parent</artifactId>    <version>1.5.9.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-eureka</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-web</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.cloud</groupId>      <artifactId>spring-cloud-starter-zuul</artifactId>    </dependency>    <dependency>      <groupId>org.springframework.boot</groupId>      <artifactId>spring-boot-starter-test</artifactId>      <scope>test</scope>    </dependency>  </dependencies>  <dependencyManagement>    <dependencies>      <dependency>        <groupId>org.springframework.cloud</groupId>        <artifactId>spring-cloud-dependencies</artifactId>        <version>Dalston.RC1</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>  <repositories>    <repository>      <id>spring-milestones</id>      <name>Spring Milestones</name>      <url>https://repo.spring.io/milestone</url>      <snapshots>        <enabled>false</enabled>      </snapshots>    </repository>

application.yml

eureka: client:  serviceUrl:   defaultZone: http://localhost:8761/eureka/server: port: 8080spring: application:  name: service-zuulzuul: routes:  api-b:   path: /api/**   serviceId: service-feign #凡是以api開始的請求都訪問service-feign服務

Application類

@EnableZuulProxy@EnableEurekaClient@SpringBootApplicationpublic class Application {  public static void main(String[] args) {    SpringApplication.run(Application.class, args);  }}

啟動Application,訪問:http://localhost:8080/api/hi,就能訪問到之前我們定義的接口,接下來我們做接口的攔截:

/** * filterType:返回一個字符串代表過濾器的類型,在zuul中定義了四種不同生命周期的過濾器類型,具體如下: pre:路由之前 routing:路由之時 post: 路由之后 error:發送錯誤調用 filterOrder:過濾的順序 shouldFilter:這里可以寫邏輯判斷,是否要過濾,本文true,永遠過濾。 run:過濾器的具體邏輯??捎煤軓碗s,包括查sql,nosql去判斷該請求到底有沒有權限訪問。 */@Componentpublic 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;  }}

這樣我們在調用接口前會先執行MyFilter類中的run方法,在這個方法里可以做一系列安全驗證,比如token。

好了,一個簡單的微服務架構就已經搭建完成了。

以上所有代碼都已開源到github上了,地址:https://github.com/lynnlovemin/softservice

以上所述是小編給大家介紹的SpringCloud實現簡單的微服務架構,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
午夜精品久久久久久久男人的天堂| 欧美国产精品人人做人人爱| 国产亚洲欧美日韩精品| 欧美成人精品三级在线观看| 国产免费一区二区三区在线观看| 欧美网站在线观看| 国产精品劲爆视频| 神马久久久久久| 欧美激情喷水视频| 国产精品极品美女粉嫩高清在线| 伊人一区二区三区久久精品| 亚洲男人第一网站| 亚洲国产高清福利视频| 在线播放国产一区二区三区| 欧美激情图片区| 日韩电影免费观看中文字幕| 亚洲美女黄色片| 欧美日韩国产页| 欧美性videos高清精品| 欧美激情网站在线观看| 亚洲国产精品福利| 成人免费直播live| 久久99精品久久久久久青青91| 成人亚洲激情网| 中文字幕亚洲综合久久筱田步美| 欧美日韩中文在线| 国产一区二区在线免费| 成人免费在线视频网站| 国产免费一区视频观看免费| 成人黄色影片在线| 欧美一区二区视频97| 成人激情在线观看| 国产伦精品一区二区三区精品视频| 国产精品美女主播| 色播久久人人爽人人爽人人片视av| 成人网页在线免费观看| 国内精品中文字幕| 91精品久久久久久久久不口人| 国产一区二区三区在线观看视频| 2019日本中文字幕| 北条麻妃一区二区在线观看| 欧美极品少妇xxxxx| 欧美在线视频在线播放完整版免费观看| 欧美高清videos高潮hd| 欧美精品18videos性欧| 亚洲欧美色婷婷| 亚洲天堂男人天堂女人天堂| 欧美日韩亚洲系列| 福利微拍一区二区| 97视频免费在线观看| 中文字幕亚洲精品| 久久婷婷国产麻豆91天堂| 亚洲欧美资源在线| 久久精品美女视频网站| 国内精品久久久久久久久| 亚洲国产中文字幕在线观看| 91精品在线观看视频| 欧美成人一二三| 亚洲国产精品网站| 九九热精品视频在线播放| 中文字幕v亚洲ⅴv天堂| 成人黄色免费片| 欧美性xxxxx| 自拍偷拍亚洲区| 欧美老少做受xxxx高潮| 欧美日韩在线视频一区| 精品免费在线观看| 久久欧美在线电影| 欧美激情xxxx性bbbb| 91精品啪aⅴ在线观看国产| 国产精品久久久久91| 精品少妇v888av| 91精品国产综合久久久久久久久| 亚洲免费电影一区| 亚洲偷欧美偷国内偷| 亚洲精品电影在线| 亚洲欧美国内爽妇网| 欧美精品videosex极品1| 日韩视频在线观看免费| 国产精品日日摸夜夜添夜夜av| 日韩成人激情在线| 国产精品一区久久| 日韩福利视频在线观看| 国产主播在线一区| 欧美高清不卡在线| 日韩在线观看免费全集电视剧网站| 亚洲欧美一区二区三区情侣bbw| 亚洲欧洲国产伦综合| 国产综合福利在线| 久久99青青精品免费观看| 国外成人在线直播| 久久精品小视频| 国产精品一区二区久久国产| 人人澡人人澡人人看欧美| 综合久久五月天| 欧美黑人巨大精品一区二区| 国产一区玩具在线观看| 亚洲欧美日韩第一区| 久久久久久久久久久网站| 日韩激情视频在线| 自拍偷拍亚洲欧美| 欧美激情在线观看| 亚洲美女av在线播放| 久色乳综合思思在线视频| 日韩精品在线视频美女| 7777精品久久久久久| 97人人模人人爽人人喊中文字| 欧美精品免费在线观看| 国产成人97精品免费看片| 国产欧美在线看| 少妇高潮久久久久久潘金莲| 亚洲品质视频自拍网| 欧美老女人性视频| 国内精品一区二区三区四区| 中文字幕久久亚洲| 亚洲a级在线播放观看| 欧美一区亚洲一区| 亚洲香蕉av在线一区二区三区| 国产精品久久久久久久久久久久| 国产日本欧美视频| www.日本久久久久com.| 91美女福利视频高清| 欧美日韩国产成人在线观看| 欧美老女人在线视频| 国产日韩视频在线观看| 欧美丰满少妇xxxxx| 8090成年在线看片午夜| 亚洲最新av在线| 久久91精品国产91久久跳| 精品国产一区二区三区四区在线观看| 亚洲国产天堂久久综合网| 精品久久久久国产| 欧美劲爆第一页| 精品国产精品三级精品av网址| 欧美日韩另类在线| 日韩最新中文字幕电影免费看| 国产精品成人免费电影| 日韩成人在线视频观看| 日韩亚洲综合在线| 久久久久久com| 亚洲免费中文字幕| 国产日韩欧美影视| 97视频国产在线| 欧美在线日韩在线| 亚洲国产精品人久久电影| 高潮白浆女日韩av免费看| 久久夜精品va视频免费观看| 最近2019中文字幕mv免费看| 亚洲有声小说3d| 精品在线欧美视频| 日韩av在线播放资源| 日本久久91av| 亚洲欧美日韩视频一区| 精品国产鲁一鲁一区二区张丽| 亚洲国产精品久久久久| 亚洲精品久久在线| 九九精品在线视频| 成人黄色免费在线观看| 国产精品尤物福利片在线观看| 欧美性理论片在线观看片免费| 国自在线精品视频| 国产97色在线|日韩| 国产裸体写真av一区二区| 中文字幕日韩免费视频|