dubbo发布web服务实例
dubbo角色与调用执行过程 dubbo节点角色说明:
provider: 暴露服务的服务提供方
consumer: 调用远程服务的服务消费方
registry: 服务注册于发现的注册中心
monitor: 统计服务的调用次数和调用时间的监控中心
container:服务运行容器 dubbo调用关系说明:
1、服务容器负责启动,加载,运行服务提供者
2、服务提供者在启动时,向注册中心注册自己提供的服务
3、服务消费者在启动时,向注册中心订阅自己所需的服务
4、注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者
5、服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果的调用失败,则选择另一台调用
6、服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心 注册中心:
zookeeper(建议使用2.3.3以上版本)
dubbo未对zookeeper服务端做任何侵入修改,只需安装原生的zookeeper服务器即可.所有注册中心逻辑适配都在调用zookeeper客户端时完成 zookeeper注册中心安装 笔者环境:
a)虚拟机centos
IP地址:[192.168.1.107] b)zookeeper
zk版本: [zookeeper-3.4.6]
1、修改/etc/hosts文件添加host"192.168.1.107 zk-provider" 如下
[root@localhost local]# vim /etc/hosts
[root@localhost local]# cat /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
:: localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.1.107 zk-provider
2、解压zookeeper-3.4.6到/usr/local/
[root@localhost zookeeper-3.4.]# pwd
/usr/local/zookeeper-3.4.
3、在/usr/local/zookeeper-3.4.6目录下创建目录:
[root@localhost zookeeper-3.4.]# mkdir logs
[root@localhost zookeeper-3.4.]# mkdir data
4、将/usr/local/zookeeper-3.4.6/conf目录下的zoo_sample.cfg复制一份,命名为zoo.cfg
[root@localhost conf]# pwd
/usr/local/zookeeper-3.4./conf
[root@localhost conf]# cp zoo_sample.cfg zoo.cfg
5、修改zoo.cfg文件内容如下:
[root@localhost conf]# cat zoo.cfg
tickTime=
#initLimit这个配置项是用来配置zookeeper接口客户端
initLimit=
syncLimit=
dataDir=/usr/local/zookeeper-3.4./data
dtaLogDir=/usr/local/zookeeper-3.4./logs
clientPort=
server.=zk-provider::
说明:server.1=zk-provider:2888:3888等同于server.1=192.168.1.107:2888:3888
6、在/usr/local/zookeeper-3.4.6/data下创建myid文件,输入当前服务机器所对应的编号
[root@localhost data]# pwd
/usr/local/zookeeper-3.4./data
[root@localhost data]# ls
myid
[root@localhost data]# cat myid [root@localhost data]#
7、将zookeeper配置到环境变量
[root@localhost data]# vim /etc/profile
在文件末尾增加
# zookeeper env
export ZOOKEEPER_HOME=/usr/local/zookeeper-3.4.6
export PATH=$ZOOKEEPER_HOME/bin:$PATH
保存退出,使配置生效
[root@localhost data]# source /etc/profile
8、在防火墙打开要用到得到端口2181、2888、3888
[root@localhost data]# vim /etc/sysconfig/iptables
在COMMIT之前增加如下:
-A INPUT -m state --state NEW -m tcp -p tcp --dport 2181 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 2888 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3888 -j ACCEPT
重启防火墙
[root@localhost data]# service iptables restart
[root@localhost data]# service iptables status
9、启动zookeeper
[root@localhost zookeeper-3.4.]# /usr/local/zookeeper-3.4./bin/zkServer.sh start
JMX enabled by default
Using config: /usr/local/zookeeper-3.4./bin/../conf/zoo.cfg
Starting zookeeper ... STARTED
# 查看状态
[root@localhost zookeeper-3.4.]# zkServer.sh status
JMX enabled by default
Using config: /usr/local/zookeeper-3.4./bin/../conf/zoo.cfg
Mode: standalone
# 查看输出的服务信息
[root@localhost zookeeper-3.4.]# tail -500f /usr/local/zookeeper-3.4./bin/zookeeper.out
10、配置zookeeper随机启动
[root@localhost zookeeper-3.4.]# vim /etc/rc.local
# 增加如下命令
/usr/local/zookeeper-3.4./bin/zkServer.sh start
dubbo服务发布与调用
1、服务发布
<?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="ws-server-user" /> <!-- 使用zookeeper注册中心暴露服务地址 -->
<dubbo:registry protocol="zookeeper" address="192.168.1.107:2181" /> <!-- 用dubbo协议在20880端口暴露服务 -->
<dubbo:protocol name="dubbo" port="20880" /> <bean id="userFacade" class="com.ws.server.UserFacadeImpl" />
<!-- 用户服务接口 -->
<dubbo:service interface="com.ws.facade.UserFacade" ref="userFacade" /> </beans>
2、服务调用
<?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="ws-client-invoke-user" /> <!-- 使用zookeeper注册中心暴露服务地址 -->
<!-- 注册中心地址 -->
<dubbo:registry protocol="zookeeper" address="192.168.1.107:2181" /> <!-- 用户服务接口 -->
<dubbo:reference interface="com.ws.facade.UserFacade" id="userFacadeClient" check="false"/> </beans>
实例demo: http://files.cnblogs.com/files/dennisit/dubbo-ws.zip 转载请注明出处:[http://www.cnblogs.com/dennisit/p/4542901.html]
dubbo发布web服务实例的更多相关文章
- dubbo发布webservice服务
dubbo发布webservice服务 学习了:https://blog.csdn.net/zhangyunpengchang/article/details/51567127 https://blo ...
- dubbo 发布 RPC 服务
Dubbo 发布 RPC 服务 建立服务提供者项目 pom.xml <?xml version="1.0" encoding="UTF-8"?> & ...
- spring boot-18.使用dubbo发布分布式服务
我们新建两个项目分别模拟服务的提供者和服务的消费者,spring boot 集成dubbo主要分为以下几个步骤: 1.安装zookeeper 推荐使用docker 安装,使用以下几个命令即可完成 (1 ...
- svn + nginx unit + python3自动化发布web服务方法
本周将python web服务管理更换成nginx unit以后发现接口性能有了明显的提升,访问速度快了不少.不过有个很大的问题就是使用svn自动化发布以后,服务并没有刷新使用新的代码运行,而又不懂得 ...
- (七)CXF之与spring整合发布web服务
一.需求分析 用spring发布服务 二.案例 2.1 引入maven依赖 <dependencies> <!-- 添加Spring支持 --> <dependency& ...
- IIS7.0发布Web服务-0001
配置错误 不能在此路径中使用此配置节.如果在父级别上锁定了该节,便会出现这种情况.锁定是默认设置的 (overrideModeDefault="Deny"),或者是通过包含 ove ...
- Jetty 发布web服务
Jetty provides a Web server and javax.servlet container, plus support for HTTP/2, WebSocket, OSGi, J ...
- 在Eclipse中,用XFire发布web服务
配置及相关说明见http://www.cnblogs.com/xshy3412/archive/2007/09/29/910848.html 仅确定发布xfire需要的最基本的jar activati ...
- VS2015发布web服务
一.IIS中 ①添加网站 二.VS2015 ①右键解决方案→发布: ②自定义,设置配置文件名称: ③ ④发布 三.IIS中浏览(图片的ip地址是自己,上面的ip是截图别人的,所以不一样)
随机推荐
- Asp.Net 基础理论
WebForm是微软开发的一款产品,它将用户的请求和响应都封装为控件.让开发者认为自己是在操作一个windows界面.极大地提高了开发效率. 在学习WebForm时,其知识量比WinForm要多,在实 ...
- jQuery in action 3rd - Introducing jQuery
2014 年 10 月, jQuery Foundation 的总裁 Dave Methvin 发布了一篇博客(http://blog.jquery.com/2014/10/29/jquery-3-0 ...
- iOS开发零基础--Swift篇:逻辑分支
一. 分支的介绍 分支即if/switch/三目运算符等判断语句 通过分支语句可以控制程序的执行流程 二. if分支语句 和OC中if语句有一定的区别 判断句可以不加() 在Swift的判断句中必须有 ...
- CentOS 一个网卡设置多个IP
方法1:少量IP手动绑定: (这里以绑定IP到eth0为例,其它网卡的话修改相应的文件名即可) 1.复制ifcfg-eth0的网卡配置文件并改名为ifcfg-eth0:0 [root@akinlau ...
- PHP日期时间处理
<?php //时区设置,可在php.ini文件中进行全局设置,默认使用的UTC时间 #date_default_timezone_set("Asia/Chongqing") ...
- SQL Server 利用锁提示优化Row_number()-程序员需知
网站中一些老页面仍采用Row_number类似的开窗函数进行分页处理,此时如果遭遇挖坟帖的情形可能就需要漫长的等待且消耗巨大.这里给大家介绍根据Row_number()特性采用特定锁Hint提升查询速 ...
- Dynamic CRM 2013学习笔记(二十三)CRM JS智能提示(CRM 相关的方法、属性以及页面字段),及发布前调试
我们知道在CRM的js文件里引用XrmPageTemplate.js后,就可以实现智能提示,但每个js文件都引用太麻烦了,其实可以利用vs的功能让每个js文件自动实现智能提示CRM的js: 另外,我们 ...
- Asp.Net Web API 2第十一课——在Web API中使用Dependency Resolver
前言 阅读本文之前,您也可以到Asp.Net Web API 2 系列导航进行查看 http://www.cnblogs.com/aehyok/p/3446289.html 本文主要来介绍在Asp.N ...
- C#中手工进行声明式验证,从此远离if验证
今天在一个ASP.NET MVC Controller Action中写代码时,需要对ViewModel的字段进行验证.但这个Action处理的是手工编写的ajax请求(不是表单提交),无法使用ASP ...
- mongo(四)索引
mongo(四)索引 根据这里http://www.cnblogs.com/huangxincheng/archive/2012/02/29/2372699.html 首先,需要构造一些数据,如下 ...