从Web网站回退到从命令行:用领域驱动设计构建软件最关键的业务内核

摘要:本文分享一个后端工程师的实践:通过领域驱动设计(DDD)先抽象出 Chatbot 的核心领域模型,剥离 Flask、前端 JS 及移动平台 API 等"壳子",实现业务内核与技术实现解耦,为跨平台迁移奠定坚实基础。


从Web网站回退到从命令行:用领域驱动设计构建软件最关键的业务内核

背景:开发自用智能多模型对比的Chatbot,受挫并且收到启发。

起初:被"完整工程"拖垮的尝试

我最早想做一个能记住我说过的话、回答问题、帮我整理知识的 Chatbot。

作为后端开发者,我习惯性地搭了一个"标准项目":

  • 后端用 Python Flask
  • 前端用 原生 JavaScript(没用任何框架)
  • 甚至在前端自己实现了简单的 MVC:Model 管消息数据,View 渲染对话,Controller 处理输入

结果呢?

我花了大量时间处理 Flask 路由、JSON 序列化、DOM 更新、前后端联调......而真正关心的业务逻辑------对话理解、记忆存储、意图识别------几乎没动

更糟的是,代码越写越重,改一点就怕崩,进度严重受阻。

转折:回到命令行,只写核心

我果断停掉 Web 部分,新建一个 core.py,写下类似于以下的最朴素的类:

python 复制代码
class ChatSession:
    def __init__(self):
        self.memory = []

    def send_message(self, text: str) -> str:
        if "记住" in text:
            self.memory.append(text)
            return "已记住!"
        elif "回忆" in text:
            return "你让我记了:" + "; ".join(self.memory)
        return "我不太明白......"

再加个 while True 循环,在终端里直接交互。
几小时就跑通了核心功能

如果你感兴趣,你可以看我的开源项目 notfresh/multisource-chatbot: 自己做的chatbot,使用302.ai支持的后台服务,可以同时调用deepSeek和千问

那一刻我意识到:

Flask、JS、MVC,都是壳子;真正的智能,藏在这些类和方法里。

这正是 领域驱动设计(DDD)的核心思想
先聚焦领域模型(ChatSession、Memory、Intent),剥离技术实现细节(HTTP、DOM、框架)

延伸:从 Android 到 iOS 的迁移启示

后来,我又想到:我之前用 AI 辅助做过几个 Android 版工具 App ,现在想迁移到 iOS

如果直接让 AI "翻译" Kotlin 到 Swift,几乎注定失败------因为平台架构、API 设计差异太大。

但有了 Chatbot 的经验,我换了个思路:

第一步:提取与平台无关的核心实体

问自己:这个 App 到底在做什么?

比如一个笔记工具,核心是:

  • Note(标题、内容、标签)
  • NoteRepository(保存、查询)
  • SyncService(云端同步)

这些用伪代码或 Python 写出来,不依赖任何移动 SDK

第二步:明确核心业务流程

  • 创建笔记 → 本地存储 → 触发同步
  • 搜索关键词 → 返回匹配结果

这些流程在 Android 和 iOS 上应该一致。

第三步:分层隔离,核心独立

把上述模型组织成 纯领域层,它不关心:

  • 是用 Activity 还是 ViewController
  • 是用 Room 还是 Core Data
  • 是用 Retrofit 还是 URLSession

它只关心:数据怎么变,规则是什么

第四步:为每个平台编写适配器

在 iOS 侧,再分别实现:

  • 用 SwiftUI 构建 UI(View 层)
  • 用 Core Data 实现 NoteRepository
  • 用 URLSession 实现网络同步

平台 API 只是外壳,是可以替换的实现细节

总结:内核稳定,壳子可换

无论是做 Web、命令行,还是跨 Android/iOS,我都验证了一件事:

软件的可演进性和可迁移性,取决于你是否先把领域核心抽象清楚。

  • Flask 是壳子
  • 原生 JS 是壳子
  • Android SDK 是壳子
  • iOS UIKit 是壳子

只有那些表达业务本质的实体、聚合、服务,才是不可替代的内核

现在,我的 Chatbot 依然运行在 shell 里,每天帮我记事、问答。

未来如果需要 Web 或移动端,我只需套一层适配器------内核不动,天下不乱

对个人开发者而言,先让领域跑起来,比先让界面跑起来更重要

而 DDD,就是帮你守住那个"核心"的思维罗盘。

相关推荐
Nandeska2 小时前
1、全面理解MySQL的架构
架构
G31135422733 小时前
Linux 内核设计中的核心思想与架构原则
linux·架构·php
Xの哲學5 小时前
Linux VxLAN深度解析: 从数据平面到内核实现的全面剖析
linux·服务器·算法·架构·边缘计算
2301_768350235 小时前
MySQL架构长啥样?
架构
古城小栈6 小时前
微服务网格:Istio 流量管理实战
微服务·架构·istio
CloudWeGo8 小时前
Volo 新能力:面向易用性与性能的 HTTP & RPC 框架迭代
架构
^_scv_^8 小时前
QEMU-RISCV平台opensbi代码分析(2)
linux·架构·risc-v
狗哥哥8 小时前
企业级 HTTP 客户端架构演进与设计
前端·架构
前端阿森纳9 小时前
公司是否因为AI正在从“以人为本”走向“以核心数据集为本”?
架构·aigc