Build Dubbo + ZooKeeper with Mav
Step 1 Make the service a Dubbo service
data:image/s3,"s3://crabby-images/ffa33/ffa3341fc4d16b2ad70c8d574a60b3ccc55631d3" alt=""
data:image/s3,"s3://crabby-images/ca8e4/ca8e46a1dc42f4c824ef06d8833bc0791ba50204" alt=""
Here, we need to add an exclusion section inside the dependency-secion, to strike with some pitfall from dubbo
<dependencies>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
<version>2.5.3</version>
<exclusions>
<exclusion>
<groupId>org.springframework</groupId>
<artifactId>spring</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
data:image/s3,"s3://crabby-images/5cdb5/5cdb54cbc010958f42230bde3955d3bf44daf8e1" alt=""
data:image/s3,"s3://crabby-images/4f5f2/4f5f24483482164bfbeb01f18f991e15d370fbc3" alt=""
data:image/s3,"s3://crabby-images/e559a/e559a82ff06e66776efc98fe9671ce689c0a8bbd" alt=""
Step 2 Import Spring and make use of its annotation
Open 'pom.xml' again, and add the below dependency block into 'dependencies' section.
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>4.2.5.RELEASE</version>
</dependency>
data:image/s3,"s3://crabby-images/abdae/abdae8995e71bf79fa9380e5e2e7381b1d2022d0" alt=""
Open HelloService.java
, cursor above the declaration of the method and start typing @Autowired
data:image/s3,"s3://crabby-images/86845/86845014f6fcd3c56e089a9c0c2f405d9e518572" alt=""
data:image/s3,"s3://crabby-images/86293/862936585a0f4148066383939a52b7e1b68e27ac" alt=""
Step 3 Take a break here and compile, to see it works.
data:image/s3,"s3://crabby-images/27b6e/27b6e7c1110d06a12231493d187846656d64692c" alt=""
Step 4 Add a main-entry to the project
Till now, we didn't have a main-entry for the project, now let's add it.
data:image/s3,"s3://crabby-images/f2b62/f2b62d45b3fd0c38a9cab53c464663dcaec74236" alt=""
data:image/s3,"s3://crabby-images/d158b/d158b73ecac943b42d0bb60358f37d1370bb8109" alt=""
data:image/s3,"s3://crabby-images/553f7/553f7043017300089552f8fa7b1e1561b39883d4" alt=""
data:image/s3,"s3://crabby-images/0e001/0e001963ca3f3db50e73ce50aff57953ca416c2a" alt=""
We specified a dubbo-provider.xm
to create the context, which we never see before. We will create it now.
Step 5 Create the XML file to define the usage of ZooKeeper server
data:image/s3,"s3://crabby-images/e9967/e99674b0c3df28d8899148c9811671d08d00f893" alt=""
It should be an XML file, and its name should be the same as the one in code.
data:image/s3,"s3://crabby-images/e0ed7/e0ed7b7d54abdfaa07822574a68115c361749963" alt=""
Declare that it uses dubbo-protocol to work with zookeeper
data:image/s3,"s3://crabby-images/f7bdc/f7bdc6f935a56448096d1b0b038ee0285f0ccd35" alt=""
data:image/s3,"s3://crabby-images/c93d0/c93d0f209f5e31e95a5079b0f97c64e18354fa8f" alt=""
data:image/s3,"s3://crabby-images/733ae/733ae033d7a853885ba54a8280f6f76d4ea71a77" alt=""
Step 6 Try to run it
data:image/s3,"s3://crabby-images/838d3/838d373fc1628356437e80fa3115dadc718c0791" alt=""
data:image/s3,"s3://crabby-images/5c68f/5c68f3719caff469370371b9f4238cd907068ef8" alt=""
From the exception message, we know that it relates to something about ZooKeeper.
The reason is that we didn't add a dependency to ZooKeeper.
In the next article, we will fix it.