RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

java微服務架構(gòu)有哪些

lhl545545 ? 來源:電子發(fā)燒友網(wǎng) ? 2018-02-09 10:34 ? 次閱讀

前言

本文首先簡單介紹了微服務的概念以及使用微服務所能帶來的優(yōu)勢,然后結(jié)合實例介紹了幾個常見的Java微服務框架。

微服務在開發(fā)領域的應用越來越廣泛,因為開發(fā)人員致力于創(chuàng)建更大、更復雜的應用程序,而這些應用程序作為微小服務的組合能夠更好地得以開發(fā)和管理。這些微小的服務可以組合在一起工作,并實現(xiàn)更大、應用更廣泛的功能?,F(xiàn)在出現(xiàn)了很多的工具來滿足使用逐段法而不是一次性地設計和構(gòu)建應用程序的所有需求。今天,我們來看一下什么是微服務、使用微服務的好處,以及幾個代碼示例。

java微服務架構(gòu)有哪些

微服務是什么?

微服務是一種面向服務的架構(gòu)風格(Java開發(fā)人員最重要的技能之一),其中,應用程序被構(gòu)建為多個不同的小型服務的集合而不是單個應用程序。與單個程序不同的是,微服務讓你可以同時運行多個獨立的應用程序,而這些獨立的應用程序可以使用不同的編碼或編程語言來創(chuàng)建。龐大而又復雜的應用程序可以由多個可自行執(zhí)行的簡單而又獨立的程序所組成。這些較小的程序組合在一起,可以提供龐大的單程序所具備的所有功能。

微服務捕獲了你的業(yè)務場景,回答了“你想要試著解決什么問題”這個問題。微服務的開發(fā)團隊的成員數(shù)量比較少,而且可以用任何語言、任何框架進行開發(fā)。每個相關的程序都是獨立地版本化、執(zhí)行和擴展。這些微服務可以與其他微服務進行交互,并且具有唯一的URL或名字,同時,即使遇到故障,也能始終保持可用性和一致性。

微服務能帶來哪些好處?

使用微服務能帶來多個好處,其中有一個好處是,由于這些較小的應用程序無需使用相同的編程語言,因此,開發(fā)人員可以使用他們最熟悉的語言。這有助于開發(fā)人員用更低的成本和更少的錯誤來開發(fā)程序。靈活性和低成本這兩個特點也表現(xiàn)在可以將這些較小的程序重用在其他項目中,從而使其更有效率。

幾個Java微服務框架的例子

這里有幾個可用于Java開發(fā)的微服務框架:

Spring Boot:這可能是最好的Java微服務框架了,它適用于控制反轉(zhuǎn)、面向切面編程等等。

Jersey:這個開源框架支持Java的JAX-RS API,使用起來非常容易。

Swagger:在為你提供開發(fā)門戶網(wǎng)頁的同時,能幫助你生成API文檔,以允許用戶測試你的API。

你也可以考慮使用其他一些框架,包括:Dropwizard、Ninja Web框架、Play框架、RestExpress、Restlet、Restx和Spark Framework。

如何使用DropWizard來創(chuàng)建微服務

DropWizard將成熟穩(wěn)定的Java庫集成在一個輕量級的包中,你可以在自己的應用程序中使用這個包。它使用了Jetty for HTTP、Jersey for REST和Jackson for JSON,以及Metrics、Guava、Logback、Hibernate Validator、Apache HttpClient、Liquibase、Mustache、Joda Time和Freemarker。

你可以使用Maven來設置Dropwizard應用程序。怎么做呢?

在你的POM文件中,添加一個dropwizard.version屬性,值為DropWizard的最新版本。

LATEST VERSION

<--Then list the dropwizard-core library:-->

io.dropwizard

dropwizard-core

${version}

這將為你設置一個Maven項目。在這里,你可以創(chuàng)建配置類、應用程序類、表現(xiàn)類,資源類或一個健康檢查,還可以構(gòu)建Fat JARS,然后運行應用程序。

在此鏈接中可以查看Dropwizard用戶手冊,這個鏈接是GitHub庫。

示例代碼:

package com.example.helloworld;

import com.yammer.dropwizard.config.Configuration;

import com.fasterxml.jackson.annotation.JsonProperty;

import org.hibernate.validator.constraints.NotEmpty;

public class HelloWorldConfiguration extends Configuration {

@NotEmpty

@JsonProperty

private String template;

@NotEmpty

@JsonProperty

private String defaultName = “Stranger”;

public String getTemplate() {

return template;

}

public String getDefaultName() {

return defaultName;

}

}

Spring Boot微服務

Spring Boot讓你可以通過嵌入式服務器將它提供的Java應用程序與你自己的應用程序一起使用。它使用了Tomcat,因此你不必使用其他的Java EE容器。Spring Boot的教程示例可以訪問這里。

你可以在這里找到所有的Spring Boot工程,你會發(fā)現(xiàn)Spring Boot擁有你的應用程序所需的所有基礎架構(gòu)。無論你是在編寫安全類、配置類或是大數(shù)據(jù)類的應用程序,總能找到對應的Spring Boot工程。

Spring Boot的工程包括:

- Spring IO Platform:用于版本化應用程序的企業(yè)級分發(fā)。

- Spring Framework:用于事務管理、依賴注入、數(shù)據(jù)訪問、消息傳遞和Web應用程序。

- Spring Cloud:用于分布式系統(tǒng),用于構(gòu)建或部署你的微服務。

- Spring Data:用于與數(shù)據(jù)訪問相關的微服務,不管是映射還是歸約,關系型還是非關系型。

- Spring Batch:用于高級別的批量操作。

- Spring Security:用于授權(quán)和認證支持。

- Spring REST文檔:用于RESTful服務文檔化。

- Spring Social:用于連接社交媒體API。

- Spring Mobile:適用于移動網(wǎng)絡應用。

示例代碼:

import org.springframework.boot.*;

import org.springframework.boot.autoconfigure.*;

import org.springframework.stereotype.*;

import org.springframework.web.bind.annotation.*;

@RestController

@EnableAutoConfiguration

public class Example {

@RequestMapping(“/”)

String home() {

return “Hello World!”;

}

public static void main(String[] args) throws Exception {

SpringApplication.run(Example.class, args);

}

}

Jersey

Jersey RESTful框架是開源的,它基于JAX-RS規(guī)范。Jersey應用程序可以擴展現(xiàn)有的JAX-RS實現(xiàn),并通過添加功能和實用工具,使得RESTful服務更為簡單,客戶端開發(fā)變得更加輕松。

Jersey最好的一點是,它的文檔很詳細,有很多例子。它的速度很快,路由也非常簡單。

關于如何開始使用Jersey的文檔在這里,而更多的文檔可以在這里找到。

你可以嘗試運行下面的示例代碼:

package org.glassfish.jersey.examples.helloworld;

import javax.ws.rs.GET;

import javax.ws.rs.Path;

import javax.ws.rs.Produces;

@Path(“helloworld”)

public class HelloWorldResource {

public static final String CLICHED_MESSAGE = “Hello World!”;

@GET

@Produces(“text/plain”)

public String getHello() {

return CLICHED_MESSAGE;

}

}

Jersey可以很容易地與其他庫一起使用,如Netty或Grizzly,它支持異步連接。它不需要servlet容器。然而,它確實很粗魯?shù)匾蕾囎⑷雽崿F(xiàn)。

Play框架

Play框架可以讓你很方便地使用Scala和Java來構(gòu)建、創(chuàng)建和部署Web應用程序。對于需要并行處理遠程調(diào)用的RESTful應用程序來說,Play框架是理想的選擇。它是模塊化的,支持異步。Play框架的社區(qū)也是所有微服務框架中最大的社區(qū)之一。

你可以嘗試運行下面的示例代碼:

package controllers;

import play.mvc.*;

public class Application extends Controller {

public static void index() {

render();

}

public static void sayHello(String myName) {

render(myName);

}

}

Restlet

Restlet可以幫助開發(fā)人員創(chuàng)建遵循RESTful架構(gòu)模式的快速而又可擴展的Web API。它具有不錯的路由和過濾功能,可用于Java SE/EE、OSGi、Google AppEngine(Google Compute的一部分)、Android和其他主要的平臺。

由于它的社區(qū)是封閉的,因此Restlet的學習曲線比較陡峭,但是你可以從StackOverflow上獲得幫助。

示例代碼:

package firstSteps;

import org.restlet.resource.Get;

import org.restlet.resource.ServerResource;

/**

* Resource which has only one representation.

*/

public class HelloWorldResource extends ServerResource {

@Get

public String represent() {

return “hello, world”;

}

}

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
收藏 人收藏

    評論

    相關推薦

    寶藏級微服務架構(gòu)工具合集

    寶藏級熱門微服務架構(gòu)工具包含Spring Boot、Eclipse Vert.X、Kubernetes、Tyk、RabbitMQ、Apache Kafka等。其中,Spring Boot簡化了微服務
    的頭像 發(fā)表于 12-21 16:33 ?50次閱讀

    k8s微服務架構(gòu)就是云原生嗎?兩者是什么關系

    k8s微服務架構(gòu)就是云原生嗎?K8s微服務架構(gòu)并不等同于云原生,但兩者之間存在密切的聯(lián)系。Kubernetes在云原生架構(gòu)中扮演著核心組件的
    的頭像 發(fā)表于 11-25 09:39 ?136次閱讀

    SSR與微服務架構(gòu)的結(jié)合應用

    隨著互聯(lián)網(wǎng)技術(shù)的快速發(fā)展,前端技術(shù)棧不斷更新迭代,后端架構(gòu)也經(jīng)歷了從單體應用到微服務的變革。在這個過程中,服務端渲染(SSR)作為一種提升頁面加載速度和SEO性能的技術(shù),與微服務
    的頭像 發(fā)表于 11-18 11:34 ?316次閱讀

    架構(gòu)與設計 常見微服務分層架構(gòu)的區(qū)別和落地實踐

    架構(gòu)風格越傾向于清晰的職責定位,且讓領域模型成為架構(gòu)的核心。 基于這些架構(gòu)風格,在軟件架構(gòu)設計過程中又有非常多的架構(gòu)分層模型。 傳統(tǒng)三層
    的頭像 發(fā)表于 10-22 15:34 ?213次閱讀
    <b class='flag-5'>架構(gòu)</b>與設計 常見<b class='flag-5'>微服務</b>分層<b class='flag-5'>架構(gòu)</b>的區(qū)別和落地實踐

    微服務架構(gòu)與容器云的關系與區(qū)別

    微服務架構(gòu)與容器云密切相關又有所區(qū)別。微服務將大型應用拆分為小型、獨立的服務,而容器云基于容器技術(shù),為微服務提供構(gòu)建、發(fā)布和運行的平臺。區(qū)別
    的頭像 發(fā)表于 10-21 17:28 ?210次閱讀

    入門級攻略:如何容器化部署微服務

    第一步理解容器化基礎,第二步創(chuàng)建Dockerfile,第三步構(gòu)建推送鏡像,第四步部署微服務,第五步管理微服務、第六步優(yōu)化更新。容器化部署微服務是現(xiàn)代軟件開發(fā)中的一種高效方法,可提供良好的可移植性、可擴展性和管理性。容器化部署
    的頭像 發(fā)表于 10-09 10:08 ?149次閱讀

    服務器而言,ARM架構(gòu)與X86架構(gòu)什么區(qū)別?各自的優(yōu)勢在哪里?

    ,x86 架構(gòu)服務器在市場占主導,強大處理能力和廣泛軟件兼容性,廣泛用于企業(yè)數(shù)據(jù)中心。ARM 架構(gòu)服務器近年崛起,憑借低功耗、高效能優(yōu)勢在
    的頭像 發(fā)表于 09-09 14:05 ?1719次閱讀

    Proxyless的多活流量和微服務治理

    1. 引言 1.1 項目的背景及意義 在當今的微服務架構(gòu)中,應用程序通常被拆分成多個獨立的服務,這些服務通過網(wǎng)絡進行通信。這種架構(gòu)的優(yōu)勢在于
    的頭像 發(fā)表于 08-28 16:54 ?1575次閱讀
    Proxyless的多活流量和<b class='flag-5'>微服務</b>治理

    NVIDIA NIM微服務帶來巨大優(yōu)勢

    服務通過熱門 AI 模型為數(shù)百萬開發(fā)者帶來高達 5 倍的 token 效率提升,使他們能夠立即訪問在 NVIDIA DGX Cloud 上運行的 NIM 微服務。
    的頭像 發(fā)表于 08-23 15:20 ?479次閱讀

    采用OpenUSD和NVIDIA NIM微服務創(chuàng)建精準品牌視覺

    全球領先的創(chuàng)意和制作服務機構(gòu)率先采用 OpenUSD 和 NVIDIA NIM 微服務來創(chuàng)建精準的品牌視覺。
    的頭像 發(fā)表于 08-01 14:33 ?415次閱讀

    【算能RADXA微服務器試用體驗】Radxa Fogwise 1684X Mini 規(guī)格

    通過網(wǎng)絡可以了解到,算能RADXA微服務器的具體規(guī)格: 處理器:BM1684X 算力:高達32Tops INT8峰值算力 內(nèi)存:16GB LPDDR4X 內(nèi)存 存儲:64GB eMMC 編程框架
    發(fā)表于 02-28 11:21

    解析 Sermant 熱插拔能力:服務運行時動態(tài)掛載 JavaAgent 和插件

    一、概述 Sermant 是基于 Java 字節(jié)碼增強技術(shù)的無代理服務網(wǎng)格,其利用 Java 字節(jié)碼增強技術(shù),為宿主應用程序提供服務治理功能,以解決大規(guī)模
    的頭像 發(fā)表于 02-18 10:09 ?977次閱讀
    解析 Sermant 熱插拔能力:<b class='flag-5'>服務</b>運行時動態(tài)掛載 JavaAgent 和插件

    Java微服務隨機掉線排查過程簡析

    我們的業(yè)務共使用 11 臺(阿里云)服務器,使用 SpringcloudAlibaba 構(gòu)建微服務集群, 共計 60 個微服務, 全部注冊在同一個 Nacos 集群。
    的頭像 發(fā)表于 01-13 17:41 ?932次閱讀
    <b class='flag-5'>Java</b><b class='flag-5'>微服務</b>隨機掉線排查過程簡析

    游戲公司不使用微服務架構(gòu)的原因

    微服務基本只有 request/response 的模式。做不了 streaming?微服務通常要求應用是無狀態(tài)的才能做到水平擴展。streaming 本身就是加入了狀態(tài)
    的頭像 發(fā)表于 12-29 11:18 ?432次閱讀

    如何搭建微服務架構(gòu)的全局圖景

    如果一直保持共用數(shù)據(jù)庫的模式,則整個架構(gòu)會越來越僵化,失去了微服務架構(gòu)的意義。因此小明和小紅一鼓作氣,把數(shù)據(jù)庫也拆分了。所有持久化層相互隔離,由各個服務自己負責。另外,為了提高系統(tǒng)的實
    的頭像 發(fā)表于 12-27 15:16 ?508次閱讀
    如何搭建<b class='flag-5'>微服務</b><b class='flag-5'>架構(gòu)</b>的全局圖景
    RM新时代网站-首页