Dubbox的入门小Demo

在进行入门demo之前我们要在虚拟机或者Linux的服务器上进行配置一下环境:虽然步骤多,但是每一步都写的很详细了,在动手前先把整个文章先读一遍,然后再动手一步一步的做,需要的文件在我的资源中已经上传了,需要的可以去下载。
我已经写好的项目在 https://github.com/MayuhanAiNi/dubbox-service
仓库地址在这里:https://github.com/MayuhanAiNi/Respository_New

Zookeeper 在Linux系统的安装
安装步骤:
第一步:安装 jdk(此步省略,我给大家提供的镜像已经安装好JDK)
第二步:把 zookeeper 的压缩包(zookeeper-3.4.6.tar.gz)上传到 linux 系统。以下是两个软件,看个人选择哪个。
使用SecureCRT软件:Alt+P 进入SFTP ,输入put d:\zookeeper-3.4.6.tar.gz 上传
使用XShell软件:rz命令,在弹出的页面中选择文件进行上传
第三步:解压缩压缩包

tar -zxvf zookeeper-3.4.6.tar.gz

第四步:进入 zookeeper-3.4.6 目录,创建 data 文件夹。

mkdir data

第五步:进入conf目录 ,把 zoo_sample.cfg 改名为 zoo.cfg

cd conf

mv zoo_sample.cfg zoo.cfg

第六步:打开zoo.cfg , 修改 data 属性:

dataDir=/root/zookeeper-3.4.6/data

Zookeeper 服务启动
进入bin目录,启动服务输入命令

 ./zkServer.sh start

输出以下内容表示启动成功
在这里插入图片描述
查看状态:

./zkServer.sh status

如果启动状态,提示
在这里插入图片描述

如果未启动状态,提示:
在这里插入图片描述

Dubbox本地 JAR包部署与安装(了解)
Dubbox的jar包并没有部署到Maven的中央仓库中,在Maven的中央仓库中可以查找到Dubbo的最终版本是2.5.3 , 阿里巴巴解散了Dubbo团队后由当当网继续维护此项目,并改名为 Dubbox ,坐标不变,版本变更了,但是并没有提交到中央仓库。
我们现在需要手动将Dubbox的jar包安装到我的本地仓库中。
先将dubbo-2.8.4.jar包放到d:\setup, 然后输入命令

mvn install:install-file -Dfile=d:\setup\dubbo-2.8.4.jar -DgroupId=com.alibaba -DartifactId=dubbo -Dversion=2.8.4 -Dpackaging=jar

**

服务提供者开发

开发步骤:
(1)创建Maven工程(WAR)dubboxdemo-service ,在pom.xml中引入依赖


  4.0.0
  cn.itcast.dubboxdemo
  dubboxdemo-service
  0.0.1-SNAPSHOT
  war  
   		
		4.2.4.RELEASE
       
	
		
		
			org.springframework
			spring-context
			${spring.version}
		
		
			org.springframework
			spring-beans
			${spring.version}
		
		
			org.springframework
			spring-webmvc
			${spring.version}
		
		
			org.springframework
			spring-jdbc
			${spring.version}
		
		
			org.springframework
			spring-aspects
			${spring.version}
		
		
			org.springframework
			spring-jms
			${spring.version}
		
		
			org.springframework
			spring-context-support
			${spring.version}
			
		
		
			com.alibaba
			dubbo
			2.8.4			
		
		
			org.apache.zookeeper
			zookeeper
			3.4.6
		
		
			com.github.sgroschupf
			zkclient
			0.1
				
		
			javassist
			javassist
			3.11.0.GA
				
	
     
	  
	        
	          org.apache.maven.plugins  
	          maven-compiler-plugin  
	          2.3.2  
	            
	              1.7  
	              1.7  
	            
	        
	      
				org.apache.tomcat.maven
				tomcat7-maven-plugin
				
					
					8081
					
					/
				
	  	  
	    
    

(2)在工程的webapps下创建WEB-INF文件夹,创建web.xml


	
	
	
		contextConfigLocation
		classpath:applicationContext*.xml
	
			org.springframework.web.context.ContextLoaderListener
		

(3)创建业务接口
创建包cn.itcast.dubbodemo.service,用于存放业务接口,创建接口

package cn.itcast.dubbodemo.service;
/**
 * 业务接口
 * @author Administrator
 *
 */
public interface UserService {	
	public String getName();	
}

(4)创建业务实现类
创建包cn.itcast.dubbodemo.service.impl ,用于存放业务实现类。创建业务实现类:

package cn.itcast.dubbodemo.service.impl;
import com.alibaba.dubbo.config.annotation.Service;
import cn.itcast.dubbodemo.service.UserService;
@Service
public class UserServiceImpl implements UserService {
	public String getName() {		
		return "itcast";
	}
}

注意:Service注解与原来不同,需要引入com.alibaba包下的
(5)编写配置文件
在src/main/resources下创建applicationContext-service.xml ,内容如下:



     
	  
 
 

注意:dubbo:annotation用于扫描@Service注解。
(6)测试运行
tomcat7:run
**

服务消费者开发

**
开发步骤:
(1)创建Maven工程(WAR)dubboxdemo-web ,在pom.xml引入依赖 ,同“dubboxdemo-service”工程。区别就是把tomcat插件的运行端口改为8082 。
(2)在webapps目录下创建WEB-INF 目录,并创建web.xml


	
   
	
		CharacterEncodingFilter		org.springframework.web.filter.CharacterEncodingFilter
		
			encoding
			utf-8
		
		  
            forceEncoding  
            true  
          
	
	
		CharacterEncodingFilter
		/*
			
  
  	springmvc  	org.springframework.web.servlet.DispatcherServlet
  	
  	
  		contextConfigLocation
  		classpath:applicationContext-web.xml
  	
    
  
  	springmvc
  	*.do
  

(3)拷贝业务接口
将“dubboxdemo-service”工程的cn.itcast.dubboxdemo.service 包以及下面的接口拷贝至此工程。
(4)编写Controller

package cn.itcast.dubboxdemo.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import cn.itcast.dubbodemo.service.UserService;
@Controller
@RequestMapping("/user")
public class UserController {
	@Reference
	private UserService userService;	
	@RequestMapping("/showName")
	@ResponseBody
	public String showName(){
		return userService.getName();
	}		
}

(5)编写spring配置文件
在src/main/resources下创建applicationContext-web.xml




	
		
			  
				
			  
			
	
	
	
	
     

(6)测试运行

tomcat7:run
在浏览器输入http://localhost:8082/user/showName.do,查看浏览器输出结果

管理中心的部署

**
我们在开发时,需要知道注册中心都注册了哪些服务,以便我们开发和测试。我们可以通过部署一个管理中心来实现。其实管理中心就是一个web应用,部署到tomcat即可。
(1)编译源码,得到war包
给大家下发的资源中有个dubbox-master.zip ,这个是dubbox的源码,我们可以使用maven命令编译源码得到“管理端”的war包
将此压缩包解压,在命令符下进入dubbo-admin目录 ,输入maven命令

mvn package -Dmaven.skip.test=true

如果你看到如下信息,就说明成功了

Dubbox的入门小Demo_第1张图片

(2)进入target文件夹,你会看到一个dubbo-admin-2.8.4.war , 在linux服务器上安装tomcat, 将此war包上传到linux服务器的tomcat的webapps下。为了访问方便,你可以把版本号去掉。 启动tomcat后自动解压。

(3)如果你部署在zookeeper同一台主机并且端口是默认的2181,则无需修改任何配置。如果不是在一台主机上或端口被修改,需要修改WEB-INF下的dubbo.properties ,修改如下配置:

dubbo.registry.address=zookeeper://127.0.0.1:2181

**

管理端使用

**
(1)打开浏览器,输入http://192.168.25.132:8080/dubbo-admin/ ,登录用户名和密码均为root 进入首页。 (192.168.25.132:)是我部署的linux主机地址。

Dubbox的入门小Demo_第2张图片
(2)启动服务提供者工程,即可在服务治理-提供者查看到该服务。
Dubbox的入门小Demo_第3张图片
点击其中一条数据后可以查看详情。
Dubbox的入门小Demo_第4张图片
(3)启动服务消费者工程,运行页面,观察“消费者”列表
Dubbox的入门小Demo_第5张图片

你可能感兴趣的:(Zookeeper)