日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

从头开始搭建一个dubbo+zookeeper平台

發布時間:2023/12/31 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 从头开始搭建一个dubbo+zookeeper平台 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2019獨角獸企業重金招聘Python工程師標準>>>

?

本篇主要是來分享從頭開始搭建一個dubbo+zookeeper平臺的過程,其中會簡要介紹下dubbo服務的作用。

  • ? 首先,看下一般網站架構隨著業務的發展,邏輯越來越復雜,數據量越來越大,交互越來越多之后的常規方案演進歷程。

?????

  • ? 其次,當服務越來越多之后,我們需要做哪些服務治理?

??????

  • ? 最后,是dubbo的架構圖

??????
? 注冊中心的選擇


? dubbo支持多種類型的注冊中心:

  • ? Multicast注冊中心
  • ? Zookeeper注冊中心
  • ? Redis注冊中心
  • ? Simple注冊中心

? 這里我們選擇zookeeper,其實類型的優點缺點可詳細查看文檔。


? 1:zookeeper的安裝,還是采用docker這一招鮮的run命令來安裝zookeeper

docker run -dit --name zookeeper --hostname zookeeper-host -v /data:/data -p 2181:2181 jplock/zookeeper:latest

?


? 2:安裝zkui,可以參考zkui的項目地址來安裝,它提供了一個管理界面,可以針對zookeepr的節點值進行CRUD操作,同時也提供了安全認證,按照如下幾步就可以完成安裝。

  • ? mvn clean install,執行前需要安裝java環境,maven環境,執行成功后會生成一個jar文件。
  • ? 將config.cfg復制到上一步生成的jar文件所在目錄,然后修改配置文件中的zookeeper地址。
  • ? 執行 jar. ( nohup java -jar zkui-2.0-SNAPSHOT-jar-with-dependencies.jar & ),注意后面的那個&,是指不退出的意思。
  • ? 測試,http://localhost:9090,如能看到如下頁面則代表zookeeper安裝運行正常。

?????????

????????


? 下面是創建dubbo服務以及使用dubbo服務的過程:

?? dubbo提供者,創建一個java工程,注意以下幾點:

  • ?包依賴,引入如下三個主要的包就可以了,主要是spring,dubbo以及zkclient??
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>${spring-framework.version}</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>dubbo</artifactId> <version>2.4.10</version> <exclusions> <exclusion> <artifactId>spring</artifactId> <groupId>org.springframework</groupId> </exclusion> </exclusions> </dependency> <dependency> <groupId>com.101tec</groupId> <artifactId>zkclient</artifactId> <version>0.3</version> </dependency>

?

  • ?定義接口,這里為了演示,簡單定義了一個返回產品名稱的接口。
public interface IProduct { String getProductName();}

?

  • ?接口實現?
@Servicepublic class ProductService implements IProduct{ public String getProductName() { return "jim"; }}

?

  • ?服務啟動函數
    • 加載配置文件
    • 調用context.start()
    • 執行一個不退出程序的操作,這里有很多種做法。
public class App { private final static Logger logger = LoggerFactory.getLogger(App.class); public static void main(String[] args) { ClassPath= new ClassPath"classpath*:applicationContext.); context.start(); logger.info("dubbo service begin to start"); try { System.in.read(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } }}

?

  • ?服務配置文件,這里需要指出的是:
    • dubbo:service的定義配合了dubbo:annotation,ref="productService",是指定的一個id,實際的實現類通過注解掃描來完成的,并沒有在配置文件中指定實現類,后面的消費者配置文件中會有所體現。
    • dubbo:application中,可以指定logger的實現接口。
    • dubbo:protocol中,可以指定是否啟動訪問日志,這個對有時排查線上問題非常有幫助。
<??><beans ="http://www.springframework.org/schema/beans" ="http://www.w3.org/2001/ ="http://code.alibabatech.com/schema/dubbo" ="http://www.springframework.org/schema/context" ="http://www.springframework.org/schema/util" ="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util.xsd" > <context:property-placeholder location="classpath*:config.properties"/> <dubbo:application name="jim" logger="slf4j" /> <dubbo:registry protocol="zookeeper" address="192.168.21.128:2181" /> <dubbo:protocol accesslog="true" name="dubbo" port="20880" /> <dubbo:annotation package="jim" /> <dubbo:service interface="jim.IProduct" ref="productService"/> <context:component-scan base-package="jim" /> <import resource="redis-context./></beans>

?

?????????
?? dubbo消費者

????

  • ?? 消費者配置文件,它的配置相對提供者要簡單很多:
    • 指定消費者的名稱,這個可以隨意,不需要與提供者做任務相關聯的匹配。
    • 指定協定類型,zookeeper地址。
    • 指定引用的服務接口,注意這里的id就與服務提供者定義的ref值相同。
<??><beans ="http://www.springframework.org/schema/beans" ="http://www.w3.org/2001/ ="http://code.alibabatech.com/schema/dubbo" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"> <dubbo:application name="consumer-of-jim-app" /> <dubbo:registry protocol="zookeeper" address="192.168.21.128:2181"/> <dubbo:reference interface="jim.IProduct" id="productService" /></beans>

?

  • ?? 接口注解定義以及接口調用????
@Controllerpublic class HomeController { private static final Logger logger = LoggerFactory.getLogger(HomeController.class); @Autowired private IProduct productService; @RequestMapping(value = "/", method = RequestMethod.GET) public String home(Locale locale, Model model) { logger.info("Welcome home! The client locale is {}.", locale); String productName=this.productService.getProductName(); model.addAttribute("name", productName); return "home"; }}

?

? dubbo admin

? 有一個UI工具可以針對dubbo服務進行管理,可惜我沒有在官方文檔提供的鏈接中下載成功,隨后從其它地方雖然下載完成了,但在安裝部署方面暫時遇到了一定的問題,需要手續研究解決。

????

?? 正常應該可以看到如下界面:

  • 管理提供者
  • 管理消費者

???

?????? 服務治理

??????

??? 經過上面的步驟后,就可以啟動服務端以及客戶端來驗證了。上面只是簡單的搭建了dubbo環境以及實現了一個hello world的服務接口,要想使用好dubbo還有好多提供的最佳實踐,比如服務治理:

  • 本地存根
  • 本地偽裝
  • 結果緩存
  • 多版本
  • 服務降級
  • 框架簡介:

    本系統一款通用的SOA中間件平臺,用來開發各類J2EE企業級應用,節省時間和人力成本。本系統采用MVC模式、AOP引擎、任務調度器、工作流、Ajax、攔截器、過濾器、緩存、日志監控、數據訪問、表達式、國際化等技術。

    用戶權限系統:
    組織結構:角色、用戶、用戶組、組織機構;權限點:頁面、方法、按鈕、數據權限、分級授權

    項目管理新體驗:
    快速出原型系統、組件樹、版本控制、模塊移植、協同開發、實時監控、發布管理

    可持續集成:
    所有組件可移植、可定制、可擴充,開發成果不斷積累,形成可持續發展的良性循環

    框架/平臺構成:
    Springmvc + Mybatis + Shiro(權限)+SSO(單點登錄) + Tiles(模板) +ActiveMQ(消息隊列) + Rest(服務) + WebService(服務)+ EHcache(緩存) + Lucene(搜索引擎) + Quartz(定時調度)+ Html5(支持PC、IOS、Android)

    支持平臺平臺:?
    Windows XP、Windows 7 、Windows 10 、 Linux 、 Unix

    服務器容器:
    Tomcat 5/6/7 、Jetty、JBoss、WebSphere 8.5

    項目源碼結構截圖:



    項目運行截圖:
















































































    ?

轉載于:https://my.oschina.net/gdfgehre/blog/729119

總結

以上是生活随笔為你收集整理的从头开始搭建一个dubbo+zookeeper平台的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。