基于mave的dubbo分别架构


开始前,先看一下demo项目工程结构:

1、抽离接口
dubbo-api工程,根据业务抽离接口,deploy到mave nexus。
public interface TestService {
    /**
     * @param name
     * @return
     */
    public String sayHello(String name);
    /**
     * @param cmd
     * @return
     */
    public String linuxCMD(String cmd);
}
提供三维坐标:
<dependency>
<groupId>com.dubbo</groupId>
<artifactId>dubbo-api</artifactId>
<version>0.0.-SNAPSHOT</version>
</dependency>
2、提供者和消费者并行
dubbo-service工程pom引入实现接口三维坐标实现接口。
import com.dubbo.service.TestService;
import com.dubbo.common.TestLinuxCmd;
public class TestServiceImpl implements TestService {
@Override
public String sayHello(String name) {
// TODO Auto-generated method stub
return null;
}
@Override
public String linuxCMD(String cmd) {
String exec = TestLinuxCmd.exec("192.168.20.20", "root", "", , name);
return exec;
}
}
注:TestLinuxCmd方法来至dubbo-common工程,公共方法到放到这里,就不多做解释了。
写完服务记得暴露出服务:
<dubbo:service interface="com.dubbo.service.TestService" ref="testService" />
dubbo-controller工程pom同样也要引入实现接口三维坐标,调用这个接口。
package com.dubbo.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.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import com.dubbo.service.TestService;
@Controller
public class MyController {
@Autowired
private TestService testService;
@RequestMapping(value = "/test")
@ResponseBody
public String testSay(@RequestParam(value = "name",defaultValue = "") String name){
StringBuffer sb = new StringBuffer();
sb.append("Dubbo: ").append(testService.sayHello(name));
return sb.toString();
}
}
消费者不需要关心谁提供的服务,它只需要调用三维坐标的接口即可。
写完同样记得暴露出服务:
<dubbo:reference interface="com.dubbo.service.TestService" id="testService" check="false" />
源码下载:
https://files.cnblogs.com/files/Javame/dubbo.zip
基于mave的dubbo分别架构的更多相关文章
- 基于 Docker 的微服务架构实践
		本文来自作者 未闻 在 GitChat 分享的{基于 Docker 的微服务架构实践} 前言 基于 Docker 的容器技术是在2015年的时候开始接触的,两年多的时间,作为一名 Docker 的 D ... 
- 分享我们项目中基于EF事务机制的架构
		写在前面: 1. 本文中单元测试用到的数据库,在执行测试之前,会被清空,即使用空数据库. 2. 本文中的单元测试都是正确通过的. 要理解EF的事务机制,首先要理解这2个类:TransactionSco ... 
- 通过dubbo暴露接口调用方法,及基于zookeeper的dubbo涉及配置文件
		现在很流行的Dubbo很多朋友都听说过吧,最近我也在看这方面的东西,分享先我的心得笔记. 先说说我们团队要做的项目框架,很简单重在实现基于zookeeper的dubbo注册. 框架:springmvc ... 
- 基于netty的微服务架构
		基于netty的微服务架构 微服务一篇好文章 http://san-yun.iteye.com/blog/1693759 教程 http://udn.yyuap.com/doc/essential-n ... 
- 新项目架构从零开始(三)------基于简单ESB的服务架构
		这几个月一直在修改架构,所以迟迟没有更新博客. 新的架构是一个基于简单esb的服务架构,主要构成是esb服务注册,wcf服务,MVC项目构成. 首先,我门来看一看解决方案, 1.Common 在Com ... 
- 分享我们项目中基于EF事务机制的架构 【转载】
		http://www.cnblogs.com/leotsai/p/how-to-use-entity-framework-transaction-scope.html 写在前面: 1. 本文中单元测试 ... 
- 基于springboot构建dubbo的入门demo
		之前记录了构建dubbo入门demo所需的环境以及基于普通maven项目构建dubbo的入门案例,今天记录在这些的基础上基于springboot来构建dubbo的入门demo:众所周知,springb ... 
- 配置percona mysql server 5.7基于gtid主主复制架构
		配置mysql基于gtid主主复制架构 环境: 操作系统 centos7. x86_64 mysql版本:Percona-Server-- 测试环境: node1 10.11.0.210 node2 ... 
- 基于注解的Dubbo服务配置
		基于注解的Dubbo服务配置可以大大减少dubbo xml配置文件中的Service配置量,主要步骤如下: 一.服务提供方 1. Dubbo配置文件中增加Dubbo注解扫描 <!-- ... 
随机推荐
- JavaWeb核心之Servlet
			servlet规范:包含三个技术点 1)servlet技术 2)filter技术---过滤器 3)listener技术---监听器 Servlet快速入门 实现步骤: 1)创建类实现Servlet接口 ... 
- 18个分形图形的GIF动画演示
			这里提供18个几何线段分形的GIF动画图像.图形颜色是白色,背景色为黑色,使用最基本的黑与白以表现分形图形. (1)科赫(Koch)雪花 (2)列维(levy)曲线 (3)龙形曲线(Drago ... 
- issue:ssh自动断开
			使用ssh连接云服务器的时候,几分钟不操作terminal就会卡住,实际上ssh连接已经断开了,感觉很不爽.(可能云服务器供应商在系统中做了设置) 解决办法: step1:vim /etc/ssh/s ... 
- Awake()跟Start()差在哪?
			刚开始学Unity的时候,最难搞定的就是这两个functions的差异,依照官方文件所描述的: Awake(): Awake is called when the script instance is ... 
- 【洛谷4070】 [SDOI2016]生成魔咒(SAM)
			传送门 洛谷 Solution 考虑要求的是什么,前缀的本质不同的字符串个数? 如果只要求一个串那么显然答案是\(\sum_{i=1}^{tot}len[i]-len[fa[i]]\)(实际上这个并不 ... 
- 牛客JS编程大题(一)
			1.找出元素 item 在给定数组 arr 中的位置 function indexOf(arr,item){ return arr.indexOf(item);} 2.计算给定数组 arr 中所有元素 ... 
- 2.html基础标签:无序+有序+自定义列表
			<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ... 
- Java正则表达式API详解
			1. Pattern类 public class PatternExample { /** * public static String quote(String s) * 返回指定字符串的字面值模式 ... 
- go操作redis
			package main import ( "fmt" "github.com/gomodule/redigo/redis" ) func main() { c ... 
- Java学习笔记29(集合框架三:泛型)
			泛型的概念: 简单地讲,就是同一个方法(类),可以接受不同的数据类型并运行得到相对应的结果,不会出现安全问题 上一篇有一段这样的代码: 没有定义集合类型.迭代器类型 package demo; imp ... 
