学习淘淘商城第十一课(dubbo入门及单机版zookeeper安装)

110 篇文章 383 订阅
6 篇文章 0 订阅

       由于淘淘商城是基于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。

[root@zookeeper1 ~]# yum install lrzsz
        

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

[root@zookeeper1 ~]# yum install vim-enhanced

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

[root@zookeeper1 ~]# mkdir /usr/local/software

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

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

[root@zookeeper1 software]# rz

[root@zookeeper1 software]# ll
总用量 16020
-rw-r--r--. 1 root root 16402010 10月 15 2016 zookeeper-3.4.5.tar.gz
[root@zookeeper1 software]# 

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

[root@zookeeper1 software]# tar -zxvf zookeeper-3.4.5.tar.gz -C /usr/local/

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

[root@zookeeper1 software]# cd /usr/local/zookeeper-3.4.5/
[root@zookeeper1 zookeeper-3.4.5]# ll
总用量 1512
drwxr-xr-x.  2 501 games    4096 4月  25 07:34 bin
-rw-r--r--.  1 501 games   75988 10月  1 2012 build.xml
-rw-r--r--.  1 501 games   70223 10月  1 2012 CHANGES.txt
drwxr-xr-x.  2 501 games    4096 4月  25 07:34 conf
drwxr-xr-x. 10 501 games    4096 4月  25 07:34 contrib
drwxr-xr-x.  2 501 games    4096 4月  25 07:34 dist-maven
drwxr-xr-x.  6 501 games    4096 4月  25 07:34 docs
-rw-r--r--.  1 501 games    1953 10月  1 2012 ivysettings.xml
-rw-r--r--.  1 501 games    3120 10月  1 2012 ivy.xml
drwxr-xr-x.  4 501 games    4096 4月  25 07:34 lib
-rw-r--r--.  1 501 games   11358 10月  1 2012 LICENSE.txt
-rw-r--r--.  1 501 games     170 10月  1 2012 NOTICE.txt
-rw-r--r--.  1 501 games    1770 10月  1 2012 README_packaging.txt
-rw-r--r--.  1 501 games    1585 10月  1 2012 README.txt
drwxr-xr-x.  5 501 games    4096 4月  25 07:34 recipes
drwxr-xr-x.  8 501 games    4096 4月  25 07:34 src
-rw-r--r--.  1 501 games 1315806 11月  5 2012 zookeeper-3.4.5.jar
-rw-r--r--.  1 501 games     833 11月  5 2012 zookeeper-3.4.5.jar.asc
-rw-r--r--.  1 501 games      33 11月  5 2012 zookeeper-3.4.5.jar.md5
-rw-r--r--.  1 501 games      41 11月  5 2012 zookeeper-3.4.5.jar.sha1
[root@zookeeper1 zookeeper-3.4.5]# 

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

[root@zookeeper1 zookeeper-3.4.5]# mkdir data
[root@zookeeper1 zookeeper-3.4.5]# ll
总用量 1516
drwxr-xr-x.  2  501 games    4096 4月  25 07:34 bin
-rw-r--r--.  1  501 games   75988 10月  1 2012 build.xml
-rw-r--r--.  1  501 games   70223 10月  1 2012 CHANGES.txt
drwxr-xr-x.  2  501 games    4096 4月  25 07:34 conf
drwxr-xr-x. 10  501 games    4096 4月  25 07:34 contrib
drwxr-xr-x.  2 root root     4096 4月  25 07:35 data
drwxr-xr-x.  2  501 games    4096 4月  25 07:34 dist-maven
drwxr-xr-x.  6  501 games    4096 4月  25 07:34 docs
-rw-r--r--.  1  501 games    1953 10月  1 2012 ivysettings.xml
-rw-r--r--.  1  501 games    3120 10月  1 2012 ivy.xml
drwxr-xr-x.  4  501 games    4096 4月  25 07:34 lib
-rw-r--r--.  1  501 games   11358 10月  1 2012 LICENSE.txt
-rw-r--r--.  1  501 games     170 10月  1 2012 NOTICE.txt
-rw-r--r--.  1  501 games    1770 10月  1 2012 README_packaging.txt
-rw-r--r--.  1  501 games    1585 10月  1 2012 README.txt
drwxr-xr-x.  5  501 games    4096 4月  25 07:34 recipes
drwxr-xr-x.  8  501 games    4096 4月  25 07:34 src
-rw-r--r--.  1  501 games 1315806 11月  5 2012 zookeeper-3.4.5.jar
-rw-r--r--.  1  501 games     833 11月  5 2012 zookeeper-3.4.5.jar.asc
-rw-r--r--.  1  501 games      33 11月  5 2012 zookeeper-3.4.5.jar.md5
-rw-r--r--.  1  501 games      41 11月  5 2012 zookeeper-3.4.5.jar.sha1
[root@zookeeper1 zookeeper-3.4.5]#


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

[root@zookeeper1 zookeeper-3.4.5]# cd conf
[root@zookeeper1 conf]# ll
总用量 12
-rw-r--r--. 1 501 games  535 10月  1 2012 configuration.xsl
-rw-r--r--. 1 501 games 2161 10月  1 2012 log4j.properties
-rw-r--r--. 1 501 games  808 10月  1 2012 zoo_sample.cfg
[root@zookeeper1 conf]# 

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

[root@zookeeper1 conf]# mv zoo_sample.cfg zoo.cfg
[root@zookeeper1 conf]# ll
总用量 12
-rw-r--r--. 1 501 games  535 10月  1 2012 configuration.xsl
-rw-r--r--. 1 501 games 2161 10月  1 2012 log4j.properties
-rw-r--r--. 1 501 games  808 10月  1 2012 zoo.cfg
[root@zookeeper1 conf]# 

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

[root@zookeeper1 conf]# vi zoo.cfg 

# The number of milliseconds of each tick
tickTime=2000
# The number of ticks that the initial
# synchronization phase can take
initLimit=10
# The number of ticks that can pass between
# sending a request and getting an acknowledgement
syncLimit=5
# the directory where the snapshot is stored.
# do not use /tmp for storage, /tmp here is just
# example sakes.
dataDir=/usr/local/zookeeper-3.4.5/data
# the port at which the clients will connect
clientPort=2181

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

[root@zookeeper1 zookeeper-3.4.5]# cd bin
[root@zookeeper1 bin]# ls
README.txt  zkCleanup.sh  zkCli.cmd  zkCli.sh  zkEnv.cmd  zkEnv.sh  zkServer.cmd  zkServer.sh
[root@zookeeper1 bin]# ./zkServer.sh start
JMX enabled by default
Using config: /usr/local/zookeeper-3.4.5/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED
[root@zookeeper1 bin]# ./zkServer.sh status
JMX enabled by default
Using config: /usr/local/zookeeper-3.4.5/bin/../conf/zoo.cfg
Mode: standalone
[root@zookeeper1 bin]# 

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

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

[root@zookeeper1 bin]# service iptables stop
       设置开机不启动

[root@zookeeper1 bin]# chkconfig iptables off




       


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值