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

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_38743494/article/details/79255451

由于淘淘商城是基于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。
第一步是进行注册,就是说服务提供者在服务发布之后,要在dubbo的注册管理中心进行注册,扮演Registry(注册中心的最好是zookeeper,其次可以选择redis),这样注册中心便知道有哪些服务可以供调用的。因此它先需要到注册中心进行询问,查询以下是否有自己想要调用的服务,注册中心查找之后发现有匹配的服务可供调用,便会想消费者返回可供调用的服务的IP和端口号之后,便不再需要经过注册中心,直接就可以访问服务了(这就是第4步),第5步是指dubbo想要监测都是哪些消费者调用了哪些服务,调用了多少次,这样便于管理。
这里写图片描述
上图节点角色说明:
Provider:暴露服务的服务提供方
Consumer:调用远程服务的服务消费方
Registry:服务注册与发现的注册中心。
Monitor:统计服务的调用次数和调用时间的监控中心
Container:服务运行容器
调用关系说明:
0.服务容器负责启动、加载和运行服务提供者
1.服务提供者在启动时,向注册中心注册自己提供的服务
2.服务消费者在启动时,想注册中心订阅自己所需的服务
3.注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
4.服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
5.服务消费者和服务提供者,在内存中累积调用时间和调用次数,定时每分钟发送一次统计数据到监控中心。
Zookeeper单机版安装
下面我们来说下zookeeper如何安装,在实际开发中,zookeeper都是运行在linux系统上的,因此,我们也把zookeeper安装到linux系统上,由于我们的电脑系统是windows系统,因此要想有linux环境就需要安装虚拟机,然后在虚拟机中进行安装。这里我们使用的是CentOS6虚拟机,而且是最小化安装的CentOS。安装完CentOS之后我们需要配置下静态IP而且要保证能上网,配置完之后,我们还需要zookeeper安装包。
做好准备条件后,我们需要使用连接工具来访问虚拟机,我使用的是XShell,由于最小化安装的CentOS没有rz和sz命令,因此我们需要先安装rz和sz命令,安装命令是yum install lrzsz。

[root@itcast ~]# yum install lrzsz

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

[root@itcast ~]# mkdir /usr/local/software
阅读更多

没有更多推荐了,返回首页