摘要:在實際的企業開發中,不可能所有情況都是從頭到尾的按狀態流程來,會有很多意外,比如歷史數據,故障重啟后的遺留流程,所以這種可以任意調節狀態的才是我們需要的狀態機。
1、偽持久化和中間段的狀態機
我們設想一個業務場景,就比如訂單吧,我們一般的設計都會把訂單狀態存到訂單表里面,其他的業務信息也都有表保存,而狀態機的主要作用其實是規范整個訂單業務流程的狀態和事件,所以狀態機要不要保存真的不重要,我們只需要從訂單表里面把狀態取出來,知道當前是什么狀態,然后伴隨著業務繼續流浪到下一個狀態節點就好了(流浪遠方,流~浪~~)。
我們先實現一個StateMachinePersist,因為我不想真的持久化,所以就敷衍一下,持久化是什么,啥也不干。
import org.springframework.statemachine.StateMachineContext;
import org.springframework.statemachine.StateMachinePersist;
import org.springframework.statemachine.support.DefaultStateMachineContext;
import org.springframework.stereotype.Component;
@Component
public class OrderStateMachinePersist implements StateMachinePersist
@Override public void write(StateMachineContextcontext, Order contextObj) throws Exception { //這里不做任何持久化工作 } @Override public StateMachineContext read(Order contextObj) throws Exception { StateMachineContext result = new DefaultStateMachineContext (OrderStates.valueOf(contextObj.getState()), null, null, null, null, "orderMachine"); return result; }
}
然后在PersistConfig里面轉換成StateMachinePersister
@Configuration
public class PersistConfig {
@Autowired
private OrderStateMachinePersist orderStateMachinePersist;
@Bean(name="orderPersister")
public StateMachinePersisterorderPersister() { return new DefaultStateMachinePersister (orderStateMachinePersist); }
}
現在問題來了,不持久化的持久化類是為啥呢,主要就是為了取一個任何狀態節點的狀態機,方便繼續往下執行,請看controller
@RestController
@RequestMapping("/statemachine")
public class StateMachineController {
@Resource(name="orderPersister") private StateMachinePersisterpersister; @RequestMapping("/testOrderRestore") public void testOrderRestore(String id) throws Exception { StateMachine stateMachine = orderStateMachineBuilder.build(beanFactory); //訂單 Order order = new Order(); order.setId(id); order.setState(OrderStates.WAITING_FOR_RECEIVE.toString()); //恢復 persister.restore(stateMachine, order); //查看恢復后狀態機的狀態 System.out.println("恢復后的狀態:" + stateMachine.getState().getId()); }
}
看到沒有,用builder建了一個新的狀態機,用restore過了一手,就已經是一個到達order指定狀態的老司機狀態機了,在這里,持久化不是本意,讓狀態機能夠隨時抓換到任意狀態節點才是目的。在實際的企業開發中,不可能所有情況都是從頭到尾的按狀態流程來,會有很多意外,比如歷史數據,故障重啟后的遺留流程......,所以這種可以任意調節狀態的才是我們需要的狀態機。
2、廢話時間
這篇文章內容比較少,所以決定說點廢話,湊點字數。從上面可以看到,狀態機的本身數據其實沒啥價值,有價值的業務數據比如訂單其實都存庫表,狀態值一般也是伴隨訂單一起保存就行了。那么狀態機最核心的價值在哪呢?在第一章的時候其實就講過了,spring statemachine框架的作用在于提供一個軟件項目業務切入的視角,我們的關注點不在于具體的業務數據,而是狀態流程,這個作為主線,我們必須要清楚,但是企業開發是很復雜的,情況叢生,比如我們一直舉例的流程,都是一條直線的流程:
簡單的令人發指,實際的情況顯然比這個復雜,會有分支選擇,會有回到上一個狀態的情況。下一章我們來弄一個復雜的狀態機流程圖來描述一下,試一下spring statemachine 在企業真實環境下的表現力。
源代碼地址
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/75269.html
摘要:目前為止,我們都是從狀態流程的開始階段創建一個狀態機,然后一路走下去。然后就可以愉快的在里面看怎么用了發送事件持久化恢復狀態機后的狀態為執行完保存后,大家可以自己在客戶端查看以下,是不是有內容保存進去了。 目前為止,我們都是從狀態流程的開始階段創建一個狀態機,然后一路走下去。但在實際業務中,狀態機可能需要在某個環節停留,等待其他業務的觸發,然后再繼續下面的流程。比如訂單,可能在支付環節...
摘要:創建了后,狀態機就可以不只是傳一個,可以組合和數據內容一起發送給狀態機變化的處理類了。到這里為止,狀態機通過對象就和其他的業務代碼做到了數據連接。 在企業開發中,數據在不同的業務間傳輸是最常見的工作,所以雖然我們的主架構是用的狀態機,也就是從流程狀態的角度來看待這個項目,但在具體業務中,每個狀態的轉變中會牽涉到各類業務,這些業務有些需要收到狀態機變化的通知,需要把狀態值傳遞給業務類和業...
摘要:雖然多個狀態機的問題解決了,但是對于實際的企業應用而言,還是有問題。這個問題就用到了狀態機的持久化,我們下一章就談談持久化問題。 1、多個狀態機的搞法在實際的企業應用中,基本不可能只有一個狀態機流程在跑,比如訂單,肯定是很多個訂單在運行,每個訂單都有自己的訂單狀態機流程,但上一章的例子,大家可以試一下,當執行到一個狀態時,再次刷新頁面,不會有任何日志出現,當一個狀態流程執行到某個狀態,...
摘要:先來一個,它的主要作用就告訴狀態機的初始狀態應該啥樣,然后把整個狀態流程都用代碼配置出來。繼承了類,表明身份,我就是來配置狀態機的初始狀態,并描繪一下狀態流程的全過程。 上一篇說了很多廢話,這一篇就不嘮叨,先跑起來 1、來個spring boot去start.spring.io新建一個springboot的項目,雖然我對spirngboot也有不少的牢騷,但作為demo的開始,還是一個...
摘要:目前為止,多個狀態機和多種狀態機都可以在里面實現了,下一章我們來解決下狀態機和實際業務間的數據傳輸問題,畢竟我們不是為了讓狀態機自個獨自玩耍,和業務數據互通有無才是企業開發的正道。 在上一章的例子中,我們實現了多個狀態機并存執行,不同的訂單有各自的狀態機運行,但只有一種狀態機,這顯然不能滿足實際業務的要求,比如我就遇到了訂單流程和公文審批流程在同一個項目的情況,所以我們這一章講怎么讓多...
閱讀 3163·2023-04-25 18:22
閱讀 2404·2021-11-17 09:33
閱讀 3324·2021-10-11 10:59
閱讀 3244·2021-09-22 15:50
閱讀 2821·2021-09-10 10:50
閱讀 867·2019-08-30 15:53
閱讀 456·2019-08-29 11:21
閱讀 2923·2019-08-26 13:58