dubbo入门zookeeper入门

由于是基于soa的架构,表现层和服务层是不同的工程。所以要实现商品列表查询需要两个系统之间进行通信。

       如何实现远程通信?

       1.WebService:效率不高,基于soap协议。在项目中不推荐使用。

       2.使用restful形式的服务:http+json。很多项目中应用。但是有个缺点是,如果服务太多,服务之间的调用关系就非常混乱,需要治疗服务。

       3.使用dubbo。使用rpc协议进行远程调用,直接使用socket通信。传输效率高,并且可以统计出系统之间的调用关系、调用次数。但是dubbo也有个比较大的缺点,那就是使用它的工程必须都是用java开发的才行,如果一个用的java,另一个用的PHP,就无法使用dubbo。

        那么,什么是dubbo?

        随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进。Dubbo架构发展路线图如下。


         从上图可以看到,发展经历了四个阶段:

第一阶段:单一应用架构

      当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。此时,用于简化增删改查工作量的数据访问框架(ORM)是关键。其中1~10的意思是,当一个tomcat服务无法满足要求时,我们可以增加部署tomcat的数量并用反向代理来做负载均衡。由于不同的tomcat之间session要共享,方法就是要定时向其它节点进行广播,其它tomcat发现发现与之不同时便会进行同步,当节点数量较多时,广播将会占用大部分带宽,以至于真正的通信所用的带宽严重不足。因此该架构只能用于节点数小于10的情况。

第二阶段:垂直应用架构

       当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个应用,以提升效率。举个例子,比如把一个大的项目拆分成订单系统、会员系统、前台系统、后台系统、搜索系统,每个系统自成一家,服务层和web层都在一起,哪个系统压力大,就给那个系统增加节点以提升性能。此时用于加速前端开发的Web框架(MVC)是关键。

第三阶段:分布式服务架构

       当垂直应用越来越多,应用之间交互不可避免,这时代码将非常臃肿(因为同一套代码逻辑可能会被写多遍)。这时将核心业务抽离出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能够更快速的响应市场需求。此时用于提高业务复用及整合的分布式服务框架(RPC)是关键。

第四阶段:流动计算架构

       当服务越来越多,容量的评估、小服务资源的浪费等问题逐渐显现,此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率。此时用于提高机器利用率的资源调度和治理中心(SOA)是关键。

      下面我们来看下Dobbo的架构,第0步是服务提供者的发布,provider的发布需要用到容器,我们的spring便是专门用来做容器的,因此服务提供者的发布需要用到spring。

第1步是进行注册,就是说服务提供者在发布之后,要在dubbo的注册管理中心进行注册,扮演Registry(注册中心的最好是zookeeper,其次可以选择redis),这样注册中心便知道有哪些服务可供消费者使用了。第2步是消费者要调用服务,但是它是不知道有哪些服务可供调用的,因此它需要先到注册中心进行询问,查询一下是否有自己想要调用的服务,注册中心查找之后发现有匹配的服务可供调用,便会向消费者返回可供调用的服务的IP和端口号。消费者拿到IP和端口号之后,便不再需要经过注册中心,直接就可以访问服务了(这就是第4步),第5步是指dobbo想要监测都是哪些消费者调用了哪些服务,调用了多少次,这样便于管理。


       上图的节点角色说明:

       Provider:暴露服务的服务提供方。

      Consumer:调用远程服务的服务消费方。

      Registry:服务注册与发现的注册中心。

      Monitor:统计服务的调用次数和调用时间的监控中心。

      Container:服务运行容器。

      调用关系说明:

      0.服务容器负责启动、加载,运行服务提供者。

      1.服务提供者在启动时,向注册中心注册自己提供的服务。

      2.服务消费者在启动时,向注册中心订阅自己所需的服务。

      3.注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。

      4.服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。

      5.服务消费者和服务提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。

Zookeeper单机版安装

      下面我们来说下zookeeper如何安装,在实际开发中,zookeeper都是运行在linux系统上的,因此,我们也把zookeeper安装到linux系统上,由于我们的电脑系统是windows系统,因此要想有linux环境就需要安装虚拟机,然后在虚拟机中进行安装。这里我们使用的是CentOS6虚拟机,而且是最小化安装的CentOS,关于如何最小化安装CentOS,大家可以参考http://blog.csdn.net/u012453843/article/details/68947589这篇博客进行学习。安装完CentOS之后我们需要配置下静态IP而且要保证能上网,大家可以参考:http://blog.csdn.net/u012453843/article/details/52839105这篇博客进行学习。配置完之后,我们还需要zookeeper安装包,大家可以到http://download.csdn.net/detail/u012453843/9793647这个地址进行下载。

       做好准备条件后,我们需要使用连接工具来访问虚拟机,我使用的是XShell,关于XShell操作服务器大家可以参考:http://blog.csdn.net/u012453843/article/details/54293774这篇博客进行学习。由于最小化安装的CentOS没有rz和sz命令,因此我们需要先安装rz和sz命令,安装命令是yum install lrzsz。

[html]  view plain  copy
  1. [root@zookeeper1 ~]# yum install lrzsz  
        

       最小化安装的虚拟机是没有vim命令的,我们需要安装一下

[html]  view plain  copy
  1. [root@zookeeper1 ~]# yum install vim-enhanced  

       下面我们我们在/usr/local目录下新建一个software目录,专门用于存放各种安装包(这是我个人习惯)

[html]  view plain  copy
  1. [root@zookeeper1 ~]# mkdir /usr/local/software  

        由于zookeeper的安装需要JDK的支持,因此需要先安装JDK,大家可以参考http://blog.csdn.net/u012453843/article/details/52422736这篇博客进行学习。  

       安装完JDK后,我们使用"rz"命令来上传zookeeper安装包到/usr/local/software目录下

[html]  view plain  copy
  1. [root@zookeeper1 software]# rz  
  2.   
  3. [root@zookeeper1 software]# ll  
  4. 总用量 16020  
  5. -rw-r--r--. 1 root root 16402010 10月 15 2016 zookeeper-3.4.5.tar.gz  
  6. [root@zookeeper1 software]#   

      下面我们解压开发包,将安装包解压到/usr/local目录下(这是我的个人习惯),我们使用的命令是:tar -zxvf zookeeper-3.4.5.tar.gz  -C /usr/local/,如下所示。

[html]  view plain  copy
  1. [root@zookeeper1 software]# tar -zxvf zookeeper-3.4.5.tar.gz -C /usr/local/  

       我们进入到zookeeper-3.4.5文件夹,如下所示。

[html]  view plain  copy
  1. [root@zookeeper1 software]# cd /usr/local/zookeeper-3.4.5/  
  2. [root@zookeeper1 zookeeper-3.4.5]# ll  
  3. 总用量 1512  
  4. drwxr-xr-x.  2 501 games    4096 4月  25 07:34 bin  
  5. -rw-r--r--.  1 501 games   75988 10月  1 2012 build.xml  
  6. -rw-r--r--.  1 501 games   70223 10月  1 2012 CHANGES.txt  
  7. drwxr-xr-x.  2 501 games    4096 4月  25 07:34 conf  
  8. drwxr-xr-x. 10 501 games    4096 4月  25 07:34 contrib  
  9. drwxr-xr-x.  2 501 games    4096 4月  25 07:34 dist-maven  
  10. drwxr-xr-x.  6 501 games    4096 4月  25 07:34 docs  
  11. -rw-r--r--.  1 501 games    1953 10月  1 2012 ivysettings.xml  
  12. -rw-r--r--.  1 501 games    3120 10月  1 2012 ivy.xml  
  13. drwxr-xr-x.  4 501 games    4096 4月  25 07:34 lib  
  14. -rw-r--r--.  1 501 games   11358 10月  1 2012 LICENSE.txt  
  15. -rw-r--r--.  1 501 games     170 10月  1 2012 NOTICE.txt  
  16. -rw-r--r--.  1 501 games    1770 10月  1 2012 README_packaging.txt  
  17. -rw-r--r--.  1 501 games    1585 10月  1 2012 README.txt  
  18. drwxr-xr-x.  5 501 games    4096 4月  25 07:34 recipes  
  19. drwxr-xr-x.  8 501 games    4096 4月  25 07:34 src  
  20. -rw-r--r--.  1 501 games 1315806 11月  5 2012 zookeeper-3.4.5.jar  
  21. -rw-r--r--.  1 501 games     833 11月  5 2012 zookeeper-3.4.5.jar.asc  
  22. -rw-r--r--.  1 501 games      33 11月  5 2012 zookeeper-3.4.5.jar.md5  
  23. -rw-r--r--.  1 501 games      41 11月  5 2012 zookeeper-3.4.5.jar.sha1  
  24. [root@zookeeper1 zookeeper-3.4.5]#   

       我们在zookeeper-3.4.5目录下新建一个data目录,如下图所示。

[html]  view plain  copy
  1. [root@zookeeper1 zookeeper-3.4.5]# mkdir data  
  2. [root@zookeeper1 zookeeper-3.4.5]# ll  
  3. 总用量 1516  
  4. drwxr-xr-x.  2  501 games    4096 4月  25 07:34 bin  
  5. -rw-r--r--.  1  501 games   75988 10月  1 2012 build.xml  
  6. -rw-r--r--.  1  501 games   70223 10月  1 2012 CHANGES.txt  
  7. drwxr-xr-x.  2  501 games    4096 4月  25 07:34 conf  
  8. drwxr-xr-x. 10  501 games    4096 4月  25 07:34 contrib  
  9. drwxr-xr-x.  2 root root     4096 4月  25 07:35 data  
  10. drwxr-xr-x.  2  501 games    4096 4月  25 07:34 dist-maven  
  11. drwxr-xr-x.  6  501 games    4096 4月  25 07:34 docs  
  12. -rw-r--r--.  1  501 games    1953 10月  1 2012 ivysettings.xml  
  13. -rw-r--r--.  1  501 games    3120 10月  1 2012 ivy.xml  
  14. drwxr-xr-x.  4  501 games    4096 4月  25 07:34 lib  
  15. -rw-r--r--.  1  501 games   11358 10月  1 2012 LICENSE.txt  
  16. -rw-r--r--.  1  501 games     170 10月  1 2012 NOTICE.txt  
  17. -rw-r--r--.  1  501 games    1770 10月  1 2012 README_packaging.txt  
  18. -rw-r--r--.  1  501 games    1585 10月  1 2012 README.txt  
  19. drwxr-xr-x.  5  501 games    4096 4月  25 07:34 recipes  
  20. drwxr-xr-x.  8  501 games    4096 4月  25 07:34 src  
  21. -rw-r--r--.  1  501 games 1315806 11月  5 2012 zookeeper-3.4.5.jar  
  22. -rw-r--r--.  1  501 games     833 11月  5 2012 zookeeper-3.4.5.jar.asc  
  23. -rw-r--r--.  1  501 games      33 11月  5 2012 zookeeper-3.4.5.jar.md5  
  24. -rw-r--r--.  1  501 games      41 11月  5 2012 zookeeper-3.4.5.jar.sha1  
  25. [root@zookeeper1 zookeeper-3.4.5]#  


      下面我们进入到conf目录下,可以看到该目录下有个zoo_sample.cfg文件。

[html]  view plain  copy
  1. [root@zookeeper1 zookeeper-3.4.5]# cd conf  
  2. [root@zookeeper1 conf]# ll  
  3. 总用量 12  
  4. -rw-r--r--. 1 501 games  535 10月  1 2012 configuration.xsl  
  5. -rw-r--r--. 1 501 games 2161 10月  1 2012 log4j.properties  
  6. -rw-r--r--. 1 501 games  808 10月  1 2012 zoo_sample.cfg  
  7. [root@zookeeper1 conf]#   

       我们需要将zoo_sample.cfg文件改下名字,如下图所示。

[html]  view plain  copy
  1. [root@zookeeper1 conf]# mv zoo_sample.cfg zoo.cfg  
  2. [root@zookeeper1 conf]# ll  
  3. 总用量 12  
  4. -rw-r--r--. 1 501 games  535 10月  1 2012 configuration.xsl  
  5. -rw-r--r--. 1 501 games 2161 10月  1 2012 log4j.properties  
  6. -rw-r--r--. 1 501 games  808 10月  1 2012 zoo.cfg  
  7. [root@zookeeper1 conf]#   

      下面我们来修改zoo.cfg文件,我们使用的命令是vi zoo.cfg,在打开的文件中修改"dataDir"的路径为我们上面创建的data的绝对路径。如下所示。

[html]  view plain  copy
  1. [root@zookeeper1 conf]# vi zoo.cfg   
  2.   
  3. # The number of milliseconds of each tick  
  4. tickTime=2000  
  5. # The number of ticks that the initial  
  6. # synchronization phase can take  
  7. initLimit=10  
  8. # The number of ticks that can pass between  
  9. # sending a request and getting an acknowledgement  
  10. syncLimit=5  
  11. # the directory where the snapshot is stored.  
  12. # do not use /tmp for storage, /tmp here is just  
  13. # example sakes.  
  14. dataDir=/usr/local/zookeeper-3.4.5/data  
  15. # the port at which the clients will connect  
  16. clientPort=2181  

     修改完zoo.cfg之后,按ESC退出编辑模式,然后按Shift+ZZ来保存并退出zoo.cfg,这样我们便配置好了。接下来我们便启动zookepper,我们进入到bin目录下,使用命令./zkServer.sh start来启动zookeeper,启动完之后,我们可以使用./zkServer.sh status来查看启动状态,如下图所示。

[html]  view plain  copy
  1. [root@zookeeper1 zookeeper-3.4.5]# cd bin  
  2. [root@zookeeper1 bin]# ls  
  3. README.txt  zkCleanup.sh  zkCli.cmd  zkCli.sh  zkEnv.cmd  zkEnv.sh  zkServer.cmd  zkServer.sh  
  4. [root@zookeeper1 bin]# ./zkServer.sh start  
  5. JMX enabled by default  
  6. Using config: /usr/local/zookeeper-3.4.5/bin/../conf/zoo.cfg  
  7. Starting zookeeper ... STARTED  
  8. [root@zookeeper1 bin]# ./zkServer.sh status  
  9. JMX enabled by default  
  10. Using config: /usr/local/zookeeper-3.4.5/bin/../conf/zoo.cfg  
  11. Mode: standalone  
  12. [root@zookeeper1 bin]#   

      如果想关闭zookeeper可以使用命令./zkServer.sh stop来关闭,这里就不演示了。启动完zookeeper,我们便有注册中心了。

      注:如果出现端口无法访问的情况,请关闭防火墙,并且设置开机也不启动

[html]  view plain  copy
  1. [root@zookeeper1 bin]# service iptables stop  
       设置开机不启动

[html]  view plain  copy
  1. [root@zookeeper1 bin]# chkconfig iptables off  
相关文章
相关标签/搜索