基于事件的网关 Event­based Gateway

作者:Jesai

时间:2018年4月21日 21:19:30

什么是事件网关?

基于事件的网关,允许基于事件做选择。

事件网关的执行原理?

网关的每一条出口顺序流,都需要连接至一个捕获中间事件。当流程执行到达基于事件的网关时,网关类似等待状态地动作:执行被暂停。并且,为每一条出口顺序流,创建一个事件订阅。流程的走向完全是由于中间事件的选择。而由哪一个事件来决定流程的走向则是由最先触发的事件来决定的。

事件网关和其他网关的区别

请注意基于事件的网关,其出口顺序流与一般的顺序流不同。这些顺序流从不实际被执行。相反,它们允许流程引擎决定,当执行到达一个基于事件的网关时,需要订阅什么事件。

约束:

1)一个基于事件的网关,必须有两条或更多的出口顺序流。
2)基于事件的网关,只能连接至 intermediateCatchEvent(捕获中间事件) 类型的元素(Activiti不支持基于事件的网关后,连接接收任务,Receive Task)。
3)连接至基于事件的网关的 intermediateCatchEvent ,必须只有一个入口顺序流。

图标:

基于事件的网关,用内部带有特殊图标的网关(菱形)表示。

定义:

用于定义基于事件的网关的XML元素为

 eventBasedGateway 。

流程设计

我们设计一个有三个走向(分支)的事件网关。后面紧接着定时器事件、信号事件和消息事件。然后在分别跟着三个task任务。三个task任务可以告知我们流程是怎么走的。Task任务上面的监听器可以更加详细的让我们知道整个流程的执行过程。

流程配置

时间事件的CRON表达式配置

R4/2018-05-27T14:42/PT1M

这个表达式的意思是从2018-05-27日的14点42分开始,每分钟执行一次,一共执行4次。

设计流程表达式的时候设置CRON表达式。

在流程里面定义新增一个信号引用,并在信号事件里面引用。

在流程定义里面定义一个消息事件,并在消息事件里面去引用。

给时间事件增加一个执行监听器和任务监听器

给信号事件增加一个执行监听器和任务监听器

给消息事件增加一个执行监听器和任务监听器

在上面所示,每一个任务我们都配置了执行监听器和任务执行器。你会发现,我配置的类都是同一个类。你就往下看,你会发现,我这三个任务里面的执行监听器和任务监听器执行的代码都是一样的。唯一不同的是任务监听器实现的是TaskListener,执行监听器实现的是ExecutionListener。细心的就会发现,监听器实现的事件也不一样。任务监听器的事件是Create···,执行监听器的事件是:start···。后面我将会有一个环节专门介绍这两者的区别。

流程定义:

 <?xml version='1.0' encoding='UTF-8'?>

 <definitions xmlns="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:activiti="http://activiti.org/bpmn" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI" xmlns:omgdc="http://www.omg.org/spec/DD/20100524/DC" xmlns:omgdi="http://www.omg.org/spec/DD/20100524/DI" typeLanguage="http://www.w3.org/2001/XMLSchema" expressionLanguage="http://www.w3.org/1999/XPath" targetNamespace="http://activiti.org/test">

   <signal id="Singal" name="Singal" />

   <message id="Message" name="Message" />

   <process id="EventGateWay" name="事件网关" isExecutable="true">

     <startEvent id="sid-23B0551D-A771-4EE7-84D5-2FDE120C597F" />

     <endEvent id="sid-CFDD8A12-89F8-4114-8781-5506EC5F74D6" />

     <exclusiveGateway id="sid-5474F8B6-BDE6-4BCD-9792-9B06B283519C" />

     <intermediateCatchEvent id="sid-4F686F4E-C053-47EC-8FBF-028C8561B63B" name="定时器事件">

       <timerEventDefinition>

         <timeCycle>R4/2018-05-28T15:13/PT1M</timeCycle>

       </timerEventDefinition>

     </intermediateCatchEvent>

     <eventBasedGateway id="sid-3C4E8072-F03C-45B0-BF54-0842204B5984" />

     <intermediateCatchEvent id="Singals" name="信号事件">

       <signalEventDefinition signalRef="Singal" />

     </intermediateCatchEvent>

     <sequenceFlow id="sid-ADE687E7-F6C2-491D-A9DD-3A4274C2E67F" sourceRef="sid-3C4E8072-F03C-45B0-BF54-0842204B5984" targetRef="Singals" />

     <sequenceFlow id="sid-398D02FE-4E17-4683-A2AD-DFC2B834A674" sourceRef="sid-23B0551D-A771-4EE7-84D5-2FDE120C597F" targetRef="sid-3C4E8072-F03C-45B0-BF54-0842204B5984" />

     <intermediateCatchEvent id="Messages" name="消息事件">

       <messageEventDefinition messageRef="Message" />

     </intermediateCatchEvent>

     <userTask id="sid-C3D1F9C5-C11D-4A09-9EEC-F28FA2759449" name="定时器事件触发了" activiti:assignee="admin">

       <extensionElements>

         <activiti:executionListener event="start" class="light.mvc.workflow.taskListener.TimerListenerImpl" />

         <activiti:taskListener event="create" class="light.mvc.workflow.taskListener.TimerListenerImpl" />

       </extensionElements>

     </userTask>

     <userTask id="sid-88AF77E1-D75B-4085-A244-1A772C42893E" name="信号事件触发了" activiti:assignee="admin">

       <extensionElements>

         <activiti:executionListener event="start" class="light.mvc.workflow.taskListener.SingalListenerImpl" />

         <activiti:taskListener event="create" class="light.mvc.workflow.taskListener.SingalListenerImpl" />

       </extensionElements>

     </userTask>

     <userTask id="sid-881FDB4C-571D-4330-A753-7C1BC87C3130" name="消息事件触发了" activiti:assignee="admin">

       <extensionElements>

         <activiti:executionListener event="start" class="light.mvc.workflow.taskListener.MessageListenerImpl" />

         <activiti:taskListener event="create" class="light.mvc.workflow.taskListener.MessageListenerImpl" />

       </extensionElements>

     </userTask>

     <sequenceFlow id="sid-A96EE6F9-F2E8-4B0B-8128-0808651C69AC" sourceRef="sid-5474F8B6-BDE6-4BCD-9792-9B06B283519C" targetRef="sid-CFDD8A12-89F8-4114-8781-5506EC5F74D6" />

     <sequenceFlow id="sid-C4CD2E72-679C-4AB4-87EA-F364B033A8B6" sourceRef="sid-4F686F4E-C053-47EC-8FBF-028C8561B63B" targetRef="sid-C3D1F9C5-C11D-4A09-9EEC-F28FA2759449" />

     <sequenceFlow id="sid-F4CA6F5B-B634-4D59-9824-B4F98634C6A1" sourceRef="Singals" targetRef="sid-88AF77E1-D75B-4085-A244-1A772C42893E" />

     <sequenceFlow id="sid-2B33C971-D5F7-4CF9-85FF-F8264BA62600" sourceRef="sid-88AF77E1-D75B-4085-A244-1A772C42893E" targetRef="sid-5474F8B6-BDE6-4BCD-9792-9B06B283519C" />

     <sequenceFlow id="sid-6B3C1D12-6792-476E-ABFA-2EC780C20B5F" sourceRef="Messages" targetRef="sid-881FDB4C-571D-4330-A753-7C1BC87C3130" />

     <sequenceFlow id="sid-DDCEBFC5-7E85-4738-94D7-7D0E6A678C8C" sourceRef="sid-3C4E8072-F03C-45B0-BF54-0842204B5984" targetRef="sid-4F686F4E-C053-47EC-8FBF-028C8561B63B" />

     <sequenceFlow id="sid-ED0B6AA2-8677-4791-AD6B-637553A690F1" sourceRef="sid-3C4E8072-F03C-45B0-BF54-0842204B5984" targetRef="Messages" />

     <sequenceFlow id="sid-308B7959-1F2B-43A9-8237-893103EB7B7D" sourceRef="sid-C3D1F9C5-C11D-4A09-9EEC-F28FA2759449" targetRef="sid-5474F8B6-BDE6-4BCD-9792-9B06B283519C" />

     <sequenceFlow id="sid-E9416900-EBFC-4DB2-8A49-495BBE0C5B96" sourceRef="sid-881FDB4C-571D-4330-A753-7C1BC87C3130" targetRef="sid-5474F8B6-BDE6-4BCD-9792-9B06B283519C" />

   </process>

   <bpmndi:BPMNDiagram id="BPMNDiagram_EventGateWay">

     <bpmndi:BPMNPlane bpmnElement="EventGateWay" id="BPMNPlane_EventGateWay">

       <bpmndi:BPMNShape bpmnElement="sid-23B0551D-A771-4EE7-84D5-2FDE120C597F" id="BPMNShape_sid-23B0551D-A771-4EE7-84D5-2FDE120C597F">

         <omgdc:Bounds height="30.0" width="30.0" x="135.0" y="195.0" />

       </bpmndi:BPMNShape>

       <bpmndi:BPMNShape bpmnElement="sid-CFDD8A12-89F8-4114-8781-5506EC5F74D6" id="BPMNShape_sid-CFDD8A12-89F8-4114-8781-5506EC5F74D6">

         <omgdc:Bounds height="28.0" width="28.0" x="870.0" y="196.0" />

       </bpmndi:BPMNShape>

       <bpmndi:BPMNShape bpmnElement="sid-5474F8B6-BDE6-4BCD-9792-9B06B283519C" id="BPMNShape_sid-5474F8B6-BDE6-4BCD-9792-9B06B283519C">

         <omgdc:Bounds height="40.0" width="40.0" x="750.0" y="190.00000487674356" />

       </bpmndi:BPMNShape>

       <bpmndi:BPMNShape bpmnElement="sid-4F686F4E-C053-47EC-8FBF-028C8561B63B" id="BPMNShape_sid-4F686F4E-C053-47EC-8FBF-028C8561B63B">

         <omgdc:Bounds height="31.0" width="31.0" x="390.0" y="90.0" />

       </bpmndi:BPMNShape>

       <bpmndi:BPMNShape bpmnElement="sid-3C4E8072-F03C-45B0-BF54-0842204B5984" id="BPMNShape_sid-3C4E8072-F03C-45B0-BF54-0842204B5984">

         <omgdc:Bounds height="40.0" width="40.0" x="240.0" y="190.0" />

       </bpmndi:BPMNShape>

       <bpmndi:BPMNShape bpmnElement="Singals" id="BPMNShape_Singals">

         <omgdc:Bounds height="30.0" width="30.0" x="390.0" y="195.0" />

       </bpmndi:BPMNShape>

       <bpmndi:BPMNShape bpmnElement="Messages" id="BPMNShape_Messages">

         <omgdc:Bounds height="30.0" width="30.0" x="390.5" y="295.0" />

       </bpmndi:BPMNShape>

       <bpmndi:BPMNShape bpmnElement="sid-C3D1F9C5-C11D-4A09-9EEC-F28FA2759449" id="BPMNShape_sid-C3D1F9C5-C11D-4A09-9EEC-F28FA2759449">

         <omgdc:Bounds height="80.0" width="100.0" x="555.0" y="65.5" />

       </bpmndi:BPMNShape>

       <bpmndi:BPMNShape bpmnElement="sid-88AF77E1-D75B-4085-A244-1A772C42893E" id="BPMNShape_sid-88AF77E1-D75B-4085-A244-1A772C42893E">

         <omgdc:Bounds height="80.0" width="100.0" x="555.0" y="170.0" />

       </bpmndi:BPMNShape>

       <bpmndi:BPMNShape bpmnElement="sid-881FDB4C-571D-4330-A753-7C1BC87C3130" id="BPMNShape_sid-881FDB4C-571D-4330-A753-7C1BC87C3130">

         <omgdc:Bounds height="80.0" width="100.0" x="555.0" y="270.0" />

       </bpmndi:BPMNShape>

       <bpmndi:BPMNEdge bpmnElement="sid-398D02FE-4E17-4683-A2AD-DFC2B834A674" id="BPMNEdge_sid-398D02FE-4E17-4683-A2AD-DFC2B834A674">

         <omgdi:waypoint x="165.0" y="210.0000003694503" />

         <omgdi:waypoint x="240.0000022167019" y="210.0000022167019" />

       </bpmndi:BPMNEdge>

       <bpmndi:BPMNEdge bpmnElement="sid-2B33C971-D5F7-4CF9-85FF-F8264BA62600" id="BPMNEdge_sid-2B33C971-D5F7-4CF9-85FF-F8264BA62600">

         <omgdi:waypoint x="655.0" y="210.00000147780108" />

         <omgdi:waypoint x="750.0000005911204" y="210.00000428562313" />

       </bpmndi:BPMNEdge>

       <bpmndi:BPMNEdge bpmnElement="sid-A96EE6F9-F2E8-4B0B-8128-0808651C69AC" id="BPMNEdge_sid-A96EE6F9-F2E8-4B0B-8128-0808651C69AC">

         <omgdi:waypoint x="789.5840716200719" y="210.41593325667168" />

         <omgdi:waypoint x="870.0001358465071" y="210.06167401189862" />

       </bpmndi:BPMNEdge>

       <bpmndi:BPMNEdge bpmnElement="sid-F4CA6F5B-B634-4D59-9824-B4F98634C6A1" id="BPMNEdge_sid-F4CA6F5B-B634-4D59-9824-B4F98634C6A1">

         <omgdi:waypoint x="420.0" y="210.0" />

         <omgdi:waypoint x="555.0" y="210.0" />

       </bpmndi:BPMNEdge>

       <bpmndi:BPMNEdge bpmnElement="sid-ED0B6AA2-8677-4791-AD6B-637553A690F1" id="BPMNEdge_sid-ED0B6AA2-8677-4791-AD6B-637553A690F1">

         <omgdi:waypoint x="260.5" y="229.5" />

         <omgdi:waypoint x="260.5" y="310.0" />

         <omgdi:waypoint x="390.5" y="310.0" />

       </bpmndi:BPMNEdge>

       <bpmndi:BPMNEdge bpmnElement="sid-308B7959-1F2B-43A9-8237-893103EB7B7D" id="BPMNEdge_sid-308B7959-1F2B-43A9-8237-893103EB7B7D">

         <omgdi:waypoint x="655.0" y="105.5" />

         <omgdi:waypoint x="770.0" y="105.5" />

         <omgdi:waypoint x="770.0" y="190.00000487674356" />

       </bpmndi:BPMNEdge>

       <bpmndi:BPMNEdge bpmnElement="sid-ADE687E7-F6C2-491D-A9DD-3A4274C2E67F" id="BPMNEdge_sid-ADE687E7-F6C2-491D-A9DD-3A4274C2E67F">

         <omgdi:waypoint x="279.56597222222223" y="210.43402777777777" />

         <omgdi:waypoint x="390.00008979696906" y="210.0519028034707" />

       </bpmndi:BPMNEdge>

       <bpmndi:BPMNEdge bpmnElement="sid-DDCEBFC5-7E85-4738-94D7-7D0E6A678C8C" id="BPMNEdge_sid-DDCEBFC5-7E85-4738-94D7-7D0E6A678C8C">

         <omgdi:waypoint x="260.5" y="190.5" />

         <omgdi:waypoint x="260.5" y="106.0" />

         <omgdi:waypoint x="390.0" y="106.0" />

       </bpmndi:BPMNEdge>

       <bpmndi:BPMNEdge bpmnElement="sid-C4CD2E72-679C-4AB4-87EA-F364B033A8B6" id="BPMNEdge_sid-C4CD2E72-679C-4AB4-87EA-F364B033A8B6">

         <omgdi:waypoint x="421.99994949646396" y="105.95979912186817" />

         <omgdi:waypoint x="555.0" y="105.62562814070353" />

       </bpmndi:BPMNEdge>

       <bpmndi:BPMNEdge bpmnElement="sid-E9416900-EBFC-4DB2-8A49-495BBE0C5B96" id="BPMNEdge_sid-E9416900-EBFC-4DB2-8A49-495BBE0C5B96">

         <omgdi:waypoint x="655.0" y="310.0" />

         <omgdi:waypoint x="770.0" y="310.0" />

         <omgdi:waypoint x="770.0" y="230.00000487674356" />

       </bpmndi:BPMNEdge>

       <bpmndi:BPMNEdge bpmnElement="sid-6B3C1D12-6792-476E-ABFA-2EC780C20B5F" id="BPMNEdge_sid-6B3C1D12-6792-476E-ABFA-2EC780C20B5F">

         <omgdi:waypoint x="420.5" y="310.0" />

         <omgdi:waypoint x="555.0" y="310.0" />

       </bpmndi:BPMNEdge>

     </bpmndi:BPMNPlane>

   </bpmndi:BPMNDiagram>

 </definitions>

流程监听类

1.  MessageListenerImpl

 package light.mvc.workflow.taskListener;

 import org.activiti.engine.delegate.DelegateExecution;

 import org.activiti.engine.delegate.DelegateTask;

 import org.activiti.engine.delegate.ExecutionListener;

 import org.activiti.engine.delegate.JavaDelegate;

 import org.activiti.engine.delegate.TaskListener;

 public class MessageListenerImpl implements TaskListener,ExecutionListener {

 @Override

 public void notify(DelegateTask arg0) {

      System.out.println("Message Event Task Is Running");

 }

 @Override

 public void notify(DelegateExecution arg0) throws Exception {

      // TODO Auto-generated method stub

      System.out.println("Message Event Execution Is Running");

 }

 }

2.  SingalListenerImpl

 package light.mvc.workflow.taskListener;

 import org.activiti.engine.delegate.DelegateExecution;

 import org.activiti.engine.delegate.DelegateTask;

 import org.activiti.engine.delegate.ExecutionListener;

 import org.activiti.engine.delegate.JavaDelegate;

 import org.activiti.engine.delegate.TaskListener;

 public class SingalListenerImpl implements  TaskListener,ExecutionListener  {

     @Override

     public void notify(DelegateTask arg0) {

         System.out.println("Singal Event Task Is Running");

     }

     @Override

     public void notify(DelegateExecution arg0) throws Exception {

         // TODO Auto-generated method stub

         System.out.println("Singal Event Execution Is Running");

     }

 }

3.  TimerListenerImpl

 package light.mvc.workflow.taskListener;

 import org.activiti.engine.delegate.DelegateExecution;

 import org.activiti.engine.delegate.DelegateTask;

 import org.activiti.engine.delegate.ExecutionListener;

 import org.activiti.engine.delegate.JavaDelegate;

 import org.activiti.engine.delegate.TaskListener;

 public class TimerListenerImpl implements TaskListener,ExecutionListener {

 @Override

 public void notify(DelegateTask arg0) {

      System.out.println("Timer Event Task Is Running");

 }

 @Override

 public void notify(DelegateExecution arg0) throws Exception {

      // TODO Auto-generated method stub

      System.out.println("Timer Event Execution Is Running");

 }

 }

通过以上代码,我们会发现,其实代码都很简单,只是往控制台打印一句话,告诉我们,这个网关事件是怎么走的。

我们启动流程,稍微等待时间,就会发现流程自动往下执行了。此时,定时事件已经触发。

通过执行的顺序,你会发现是先执行Execution ,再执行Task。由此可见。执行监听器比任务监听器更早触发。

执行结果:

1.定时器(时间)事件触发

待办任务告诉我们,定时器事件触发了。

流程跟踪图也告诉我们定时器事件触发。

这时,完成定时器事件触发了的任务,该流程实例就全部结束。

2信号事件触发(需要重新启动流程,因为上一个流程已经结束)

我们通过一个单元测试模拟信号,让信号事件触发。

 /**触发信号事件*/

     @Test

     public void completeSingal(){

         ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();

         List<Execution> executions =  processEngine.getRuntimeService().createExecutionQuery()

            .signalEventSubscriptionName("Singal")

            .list();

         for(Execution e:executions){

             processEngine.getRuntimeService().signalEventReceived("Singal", e.getId());

         }

     }

通过控制台打印消息,告诉我们信号事件已经触发。

待办任务告诉我们信号事件触发了。

流程跟踪图告诉我们信号事件触发了。

3.  消息事件触发

单元测试模拟消息事件触发。

   /**触发消息事件*/

     @Test

     public void completeMessage(){

         ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();

         List<Execution> executions =  processEngine.getRuntimeService().createExecutionQuery()

            .messageEventSubscriptionName("Message")

            .list();

         for(Execution e:executions){

             processEngine.getRuntimeService().messageEventReceived("Message", e.getId());

         }

 }

控制台打印的消息告诉我们消息事件已经触发了。

待办任务告诉我们消息事件已经触发

流程跟踪图告诉我们消息事件已经触发

Activiti交流QQ群:634320089

基于事件的网关 Event­based Gateway的更多相关文章

  1. 微服务中的 API 网关(API Gateway)

    API 网关(API Gateway)提供高性能.高可用的 API 托管服务,帮助用户对外开放其部署在 ECS.容器服务等云产品上的应用,提供完整的 API 发布.管理.维护生命周期管理.用户只需进行 ...

  2. 基于“事件”驱动的领域驱动设计(DDD)框架分析

    摘抄自 从去年10月份开始,学了几个月的领域驱动设计(Domain Driven Design,简称DDD).主要是学习领域驱动设计之父Eric Evans的名著:<Domain-driven ...

  3. 一个在 Java VM 上使用可观测的序列来组成异步的、基于事件的程序的库 RxJava,相当好

    https://github.com/ReactiveX/RxJava https://github.com/ReactiveX/RxAndroid RX (Reactive Extensions,响 ...

  4. Event-based Asynchronous Pattern Overview基于事件的异步模式概览

    https://msdn.microsoft.com/zh-cn/library/wewwczdw(v=vs.110).aspx Applications that perform many task ...

  5. 第一章、C#委托和事件(Delegate、Event、EventHandler、EventArgs)

    第一章.C#委托和事件(Delegate.Event.EventHandler.EventArgs) 分类: 学习笔记-C#网络编程2012-12-08 14:10 7417人阅读 评论(3) 收藏  ...

  6. ORACLE调度之基于事件的调度(二)【weber出品】

    一.回顾 调度分基于时间的调度和基于事件的调度. 稍微复习一下前面的只是请浏览:<ORACLE调度之基于时间的调度(一)[weber出品]> 二.知识补充 1.队列:一种数据结构,就像一根 ...

  7. 深入理解JavaScript的事件循环(Event Loop)

    一.什么是事件循环 JS的代码执行是基于一种事件循环的机制,之所以称作事件循环,MDN给出的解释为 因为它经常被用于类似如下的方式来实现 while (queue.waitForMessage()) ...

  8. C#中的异步调用及异步设计模式(三)——基于事件的异步模式

    四.基于事件的异步模式(设计层面) 基于事件的C#异步编程模式是比IAsyncResult模式更高级的一种异步编程模式,也被用在更多的场合.该异步模式具有以下优点: ·                 ...

  9. 【温故知新】C#基于事件的异步模式(EAP)

    在开发winform和调用asp.net的web service引用的时候,会出现许多命名为 MethodNameAsync 的方法. 例如: winform的按钮点击 this.button1.Cl ...

随机推荐

  1. UVa 1354 Mobile Computing[暴力枚举]

    **1354 Mobile Computing** There is a mysterious planet called Yaen, whose space is 2-dimensional. Th ...

  2. P1088 上台阶

    题目描述 楼梯有 \(n(1 \le n \le 50)\) 阶台阶,上楼时可以一步上 \(1\) 阶,也可以一步上 \(2\) 阶,也可以一步上 \(3\) 阶,编程计算共有多少种不同的走法. 输入 ...

  3. H3C MSTP

  4. Python2_实现文件中特定内容的获取

    ===================================================== 参考链接 Python 文本文件内容批量抽取:https://blog.csdn.net/q ...

  5. 异步加载css 和 谷歌浏览器各实用小工具介绍

    异步加载css资源 加开页面首屏显示速度使我们前端一直在追求的目标,而css资源在这些优化中同样也是不可或缺的. 一个网站可能有一部分css资源是必须的,他需要在页面渲染完之前就被加载完,并和html ...

  6. 大数据基石——Hadoop与MapReduce

    本文始发于个人公众号:TechFlow 近两年AI成了最火热领域的代名词,各大高校纷纷推出了人工智能专业.但其实,人工智能也好,还是前两年的深度学习或者是机器学习也罢,都离不开底层的数据支持.对于动辄 ...

  7. 浅谈月薪3万 iOS程序员 的职业规划与成长!(进阶篇)

    前言: 干了这么多年的iOS,虽然接触了许多七七八八的东西.技术,但是感觉本身iOS却没有什么质的飞越,可能跟自己接触的项目深度有关,于是决定在学习其他技术的同时,加强自己在iOS方面的学习,提高自己 ...

  8. ELK学习实验002:Elasticsearch介绍及单机安装

    一 简介 ElasticSearch是一个基于Luncene的搜索服务器.它提供了一个分布式多用户能力全文搜索引擎,基于RESTful web接口,ElsticSearch使用Java开发的,并作为A ...

  9. mysql主从之配置基本环境

    实验环境 master  192.168.132.121 主库 slave     192.168.132.122 从库 一 mysql的使用介绍 1.1 mysql单台服务器特点 缺点 单台服务器如 ...

  10. 【一起学源码-微服务】Nexflix Eureka 源码十一:EurekaServer自我保护机制竟然有这么多Bug?

    前言 前情回顾 上一讲主要讲了服务下线,已经注册中心自动感知宕机的服务. 其实上一讲已经包含了很多EurekaServer自我保护的代码,其中还发现了1.7.x(1.9.x)包含的一些bug,但这些问 ...