由于淘淘商城是基于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]#
[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