本篇主要是來分享從頭開始搭建一個dubbo+zookeeper平臺的過程,其中會簡要介紹下dubbo服務的作用。 ...
本篇主要是來分享從頭開始搭建一個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(); }
- 介面實現
@Service public 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) { ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext( "classpath*:applicationContext.xml"); 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中,可以指定是否啟動訪問日誌,這個對有時排查線上問題非常有幫助。
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo" xmlns:context="http://www.springframework.org/schema/context" xmlns:util="http://www.springframework.org/schema/util" xmlns:aop="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.xml"/> </beans>
dubbo消費者
- 消費者配置文件,它的配置相對提供者要簡單很多:
- 指定消費者的名稱,這個可以隨意,不需要與提供者做任務相關聯的匹配。
- 指定協定類型,zookeeper地址。
- 指定引用的服務介面,註意這裡的id就與服務提供者定義的ref值相同。
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="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>
- 介面註解定義以及介面調用
@Controller public 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還有好多提供的最佳實踐,比如服務治理:
- 本地存根
- 本地偽裝
- 結果緩存
- 多版本
- 服務降級
- ......
本文引用:
- http://dubbo.io/User+Guide-zh.htm#UserGuide-zh-%E5%A4%9A%E6%B3%A8%E5%86%8C%E4%B8%AD%E5%BF%83
- http://blog.csdn.net/yinwenjie/article/details/50113139
- https://github.com/DeemOpen/zkui