Docker下dubbo开发,三部曲之一:极速体验

DUBBO是一个分布式服务框架,从本章开始,我们由浅入深,先体验再实战,逐步入门dubbo服务的开发、部署和调用,本章的目标是以最快的速度体验dubbo服务;

启动容器

创建一个docker-compose.yml文件,内容如下:

version: '2'
services:
  zk_server: 
    image: daocloud.io/library/zookeeper:3.3.6
    restart: always
  dubbo_admin: 
    image: bolingcavalry/dubbo_admin_tomcat:0.0.1
    links: 
      - zk_server:zkhost
    depends_on:
          - "zk_server"
    ports: 
      - "8080:8080"
    restart: always
  dubbo_provider: 
    image: bolingcavalry/dubbo_provider_tomcat:0.0.1
    links: 
      - zk_server:zkhost
    depends_on:
          - "dubbo_admin"
    environment:
      TOMCAT_SERVER_ID: dubbo_provider_tomcat
    restart: always
  dubbo_consumer: 
    image: bolingcavalry/online_deploy_tomcat:0.0.1
    ports: 
      - "8082:8080"
    environment:
      TOMCAT_SERVER_ID: dubbo_consumer_tomcat
    restart: always

然后用命令行在docker-compose.yml所在的目录下执行命令docker-compose up -d,启动yml文件中定义的四个容器,如下图:

容器启动成功,开始体验吧,在本机浏览器输入地址”http://localhost:8080“,会弹出登录页面,如下图,输入用户名root,密码也是root:

登录成功后,在“服务治理“菜单下点击“应用“,如下图:

可以看到如下图的列表,有一个应用被dubbo发现:dubbo_service_provider,是服务提供者:

点击上图中的dubbo_service_provider,可以看到这个应用提供了两个服务,如下图:

部署服务消费者demo

接下来我们部署一个web应用来调用dubbo_provider提供的服务,部署分三步: 1. 确定zookeeper的ip; 2. 把zookeeeper的ip填入web应用的配置信息中; 3. 把web应用部署到docker容器16_dubbo_consumer_1中(执行docker-compose up -d命令时创建的容器);

先确定zookeeper的ip,前面执行docker-compose up -d的时候,控制台提示zookeeper容器的名称是16_zk_server_1,因此执行以下命令可看zookeeper容器ip:

docker exec -it 16_zk_server_1 ip a

如下图,ip是172.28.0.4

接下来下载web应用的源码,地址是git@github.com:zq2599/blog_demos.git,执行git clone git@github.com:zq2599/blog_demos.git即可,这个地址下载的是多个工程,本次实战用到的是dubbo_service_consumer工程,如下图红框所示:

不想用github的读者也可以点击这里直接下载压缩包;

下载源码后,在dubbo_service_consumer/src/main/resources目录下,打开spring-extends.xml文件,修改下图红框中的ip,改成172.28.0.4:

打开控制台,在dubbo_service_consumer目录下执行以下命令开始 编译、打包、部署:

mvn clean package -U -Dmaven.test.skip=true tomcat7:redeploy

从控制台上可以看到在线部署的情况,如下图:

验证远程调用

部署完成,可以测试了,测试的逻辑是在dubbo_consumer容器上的jsp页面发请求,对应的后台会远程调用dubbo_provider容器里的应用提供的RPC服务,也就是之前截图中看到的com.bolingcavalry.service.CalculateService和com.bolingcavalry.service.PlatformService这两个服务;

在浏览器输入http://localhost:8082/dubboserviceconsumer/add,可以看到一个简单的页面如下图:

在两个输入框随便填数字,提交后页面展示如下图:

这里的计算结果,就是调用dubbo_provider容器提供的CalculateService服务执行的结果,“来自[dubbo_provider_tomcat]“这句话中的”dubbo_provider_tomcat”则是PlatformService服务提供的(“dubbo_provider_tomcat“是dubbo_provider容器的环境变量,docker-compose.yml中设置的),都是dubbo_consumer容器中的应用远程调用服务的结果;

留下疑问

以上就是dubbo服务的体验过程,看完本文,您是否会有这样的疑惑:dubbo_provider的部署很简单,把war包和tomcat做成一个镜像就能通过docker-compose直接创建容器了,但dubbo_consumer为何要如此麻烦,自己下载源码、改参数、编译、部署,为什么不能像dubbo_provider那样直接做成镜像,那样的话体验起来不是更简单快捷么?

这的确是个问题,后面我会继续写文章和大家一起讨论,就不在本文展开了,本文的目的很简单,就是和大家一起体验一下dubbo环境和远程调用服务;

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏SDNLAB

ONOS编程系列(二)命令行命令与服务开发

此文章承接ONOS编程系列(一) Application Tutorial ,如果尚未看过上一篇,请先看完上一篇,再回过头来看此篇。 本文章的目的在于让读者明白...

35490
来自专栏weixuqin 的专栏

关于windows上 web 和 ftp 站点的创建及使用

其实这是我网络基础课上的一次作业,觉得挺实用的,遂写成博客分享,也算是对这次作业的一次总结。

24830
来自专栏CDA数据分析师

如何发布一个Python命令行工具

上次写的一个终端里面斗鱼TV弹幕Python版本和Ruby版本,并且发布到PIP和RubyGems上面.在发布PIP包的时候,居然Google不到一篇可以非常好...

38080
来自专栏我的技术笔记

在Ubuntu 14.04上安装GitLab(Trusty Tahr)

GitLab是一个基于Ruby on Rails的免费git存储库管理应用程序。假如您想托管自己的git存储库,这是一个很好的替代方案,因为在编写私有代码或则闭...

21910
来自专栏Python

CentOS下Redis的安装

CentOS下Redis的安装 前言 安装Redis需要知道自己需要哪个版本,有针对性的安装,比如如果需要redis GEO这个地理集合的特性,那么redis...

44170
来自专栏james大数据架构

入坑系列之HAProxy负载均衡

在大型系统设计中用代理在负载均衡是最常见的一种方式,而相对靠谱的解决方案中Nginx、HAProxy、LVS、F5在各大场中用得比较普遍,各有各的优势和使用场...

707100
来自专栏漏斗社区

仰望PHPSHE1.5漏洞

背景 最近拿到PHPSHE 1.5的源码进行了审计,于是撰写了本篇,把一些问题发出来,多处SQL注入,任意文件删除,host头部攻击进行讨论,如 host位置的...

39690
来自专栏黑白安全

80端口被system(pid=4)占用的解决方法

80端口一般被当做网页服务器的默认端口,使用本机搭建服务器环境的时候,都会默认使用80端口来作为网页访问端,但是有的时候80端口会被其他的不明身份的程序占用,导...

26420
来自专栏xingoo, 一个梦想做发明家的程序员

整理LVS架构压力测试工作

    首先,测试环境在模拟环境下进行。     测试环境:1director(apache2.2) + 1realserver(jboss4.2.3GA)+1...

36280
来自专栏编程坑太多

『高级篇』docker之Mesos集群架构图(23)

10240

扫码关注云+社区

领取腾讯云代金券