IDEA搭建dubbo项目以及存在的问题

3 篇文章 0 订阅
3 篇文章 0 订阅

IDEA搭建dubbo项目以及存在的问题

本人新手,有什么问题 还请指出来,大家一起学习进步,话不多说。

一、dubbo是什么?
Dubbo是阿里巴巴开源的基于 Java 的高性能 RPC(远程调用) 分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。
二、为什么要用dubbo?
因为是阿里开源项目,国内很多互联网公司都在用,已经经过很多线上考验,保证了高性能高可用性。

dubbo流程图
在这里插入图片描述

首先,搭建dubbo项目,要有三个工程。

它们分别是:
maven java工程 这个工程放model对象以及需要暴露的接口。
maven webapp工程 服务提供者。
maven webapp工程 服务消费者。

怎么创建maven java工程 我就不说了。需要注意的是在写完接口后需要打成jar包。

服务提供者所需要的依赖:

	servlet的依赖
		<dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
            <scope>provided</scope>
        </dependency>
        
	spring的依赖
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>4.3.16.RELEASE</version>
        </dependency>
        
	spring的依赖
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>4.3.16.RELEASE</version>
        </dependency>
        
	dubbo的依赖 需要跟dubbo版本对应
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.6.2</version>
        </dependency>
        
	接口工程的依赖
        <dependency>
            <groupId>com.fkh.dubbo</groupId>
            <artifactId>dubboApi</artifactId>
            <version>1.0.0</version>
        </dependency>
        
	dubbo客户端依赖 dubbo版本在2.2以上需要curator依赖
        <dependency>
            <groupId>com.101tec</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.10</version>
        </dependency>
        
	zookeeper需要的依赖
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.14</version>
        </dependency>
        
        dubbo客户端的依赖
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-framework</artifactId>
            <version>4.0.1</version>
            <type>bundle</type>
        </dependency>
       
        dubbo客户端的依赖
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-recipes</artifactId>
            <version>4.0.1</version>
            <type>bundle</type>
        </dependency>

服务消费者需要的依赖:

		<dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>4.3.16.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>4.3.16.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.6.2</version>
        </dependency>

        <dependency>
            <groupId>com.fkh.dubbo</groupId>
            <artifactId>dubboApi</artifactId>
            <version>1.0.0</version>
        </dependency>

        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-framework</artifactId>
            <version>4.0.1</version>
        </dependency>

        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.14</version>
        </dependency>

服务消费者xml配置:
服务消费者控制器xml:
在这里插入图片描述

服务提供者xml配置:
在这里插入图片描述整个过程中遇到的问题有:

1.在消费者web.xml中配置中央控制器DispatcherServlet的时候,有红色波浪线,这个意思是说 找不到对应的包。
解决方法是在pom文件中加入:

		<dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
        </dependency>
zookeeper的依赖必须跟zookeeper版本一样。

jsp界面获取不到值的问题:

web.xml头部信息版本过低造成的,正确的是:

<?xml version="1.0" encoding="UTF-8"?>
<!--<!DOCTYPE web-app PUBLIC
        "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
        "http://java.sun.com/dtd/web-app_2_3.dtd" >-->
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">

启动顺序的问题:
一般我会先把接口工程打成jar包。
打开zookeeper注册中心,
然后启动服务提供者,
最后启动服务消费者。

这样,一个简单的dubbo项目就搭建起来的,有什么问题,欢迎大家留言。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值