從業3年了,最近一年不知怎麼了,陰差陽錯的就這麼過去了,貌似有好長時間沒有寫過代碼了,自認爲是開發人員的我,感覺有點對不起自己了;就在今天早上,突然心血來潮,想要擼一下代碼,找找當年的感覺,於是決定回顧一下dubbo微服務的搭建過程,當然整個demo只是入門級,沒有什麼難點,就是找找滿足感,娛樂自己一下;
先用maven創建一個parent項目,這一步傻瓜式創建,起個名字,點點鼠標就完成了,我給的名字是:dubbo-spring-demo
在該項目下創建兩個maven模塊,分別爲dubbo-consumer.dubbo-provider
分別引入所需要的依賴,dubbo-consumer的pom.xml如下
<?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>com.minbo.dubbo.consumer</groupId>
<artifactId>dubbo-consumer</artifactId>
<packaging>jar</packaging>
<name>dubbo-consumer</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>com.minbo.dubbo</groupId>
<artifactId>dubbo-spring-study</artifactId>
<version>0.0.1-SNAPSHOT</version>
</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>
<!-- 構建成可運行的Web項目 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>1.5.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<version>1.5.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<version>1.5.2.RELEASE</version>
<scope>test</scope>
</dependency>
<!-- 格式化對象,方便輸出日誌 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.1.41</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>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.6</version>
<exclusions>
<exclusion>
<artifactId>slf4j-log4j12</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
<version>0.1</version>
</dependency>
<dependency>
<groupId>com.minbo.dubbo.provider</groupId>
<artifactId>dubbo-provider</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>1.5.2.RELEASE</version>
</plugin>
</plugins>
</build>
</project>
服務端dubbo-provider的pom.xml如下:
<?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>com.minbo.dubbo.provider</groupId>
<artifactId>dubbo-provider</artifactId>
<packaging>jar</packaging>
<name>dubbo-provider</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>com.minbo.dubbo</groupId>
<artifactId>dubbo-spring-study</artifactId>
<version>0.0.1-SNAPSHOT</version>
</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.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>1.5.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<version>1.5.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<version>1.5.2.RELEASE</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>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.6</version>
<exclusions>
<exclusion>
<artifactId>slf4j-log4j12</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
<version>0.1</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>1.5.2.RELEASE</version>
</plugin>
</plugins>
</build>
</project>
在parent的pom.xml中添加這兩個模塊
客戶端及服務端項目結構:
application.properties文件目前只配置服務端口號;
consumers.xml文件配置如下:
<?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="dubbo-consumer" owner="dubbo-consumer" />
<!-- 定義 zookeeper 註冊中心地址及協議 -->
<dubbo:registry protocol="zookeeper" address="0.0.0.0:2181" client="zkclient" />
<!-- 生成遠程服務代理,可以和本地 bean 一樣使用 demoService -->
<dubbo:reference id="demoService" interface="com.minbo.dubbo.provider.DemoService" />
</beans>
providers.xml文件內容如下:
<?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">
<!-- 配置可參考 http://dubbo.io/User+Guide-zh.htm -->
<!--服務提供方應用名,用於計算依賴關係 -->
<dubbo:application name="dubbo-provider" owner="dubbo-provider" />
<!-- 定義 zookeeper 註冊中心地址及協議 -->
<dubbo:registry protocol="zookeeper" address="0.0.0.0:2181" client="zkclient" />
<!-- 定義 Dubbo 協議名稱及使用的端口,dubbo 協議缺省端口爲 20880,如果配置爲 -1 或者沒有配置 port,則會分配一個沒有被佔用的端口 -->
<dubbo:protocol name="dubbo" port="-1" />
<!-- 聲明需要暴露的服務接口 -->
<dubbo:service interface="com.minbo.dubbo.provider.DemoService"
ref="demoService" timeout="10000" />
<!-- 和本地 bean 一樣實現服務 -->
<bean id="demoService" class="com.minbo.dubbo.provider.DemoServiceImpl" />
</beans>
我的zookeeper是配置在linux雲服務器上的哈;
可能缺點啥,只是記錄一下自己的消化過程;
如果需要成品的話,建議去github搜索,一搜一大串,總有你想要的;