单体架构如何独立出统一公共的用户中心?

本贴最后更新于 2238 天前,其中的信息可能已经渤澥桑田

传统的单体架构,目前用户登陆注册,用户数据全部都是在一个系统中。目前公司业务扩展,需要再加两个系统,由其他团队来做,和之前系统不是一种业务,但是要使用原来用户名帐号来登录,用户是一套,需要我方独立出一个公共的用户中心,提供相关接口给其他团队对接。需要把用户表,企业表,部门表,需要独立出来。

目前能想到的方案就是:用户中心的用户表存放公共的字段,比如用户名、手机号、密码。并提供登陆接口,各子系统的前端页面提交用户名密码到子系统服务端后由子系统的服务端调用用户中心的登陆接口,登录成功后返回统一的用户 ID,各子系统有自己的用户表,表中有一个字段来存放这个 ID,其他字段为子系统独有的用户字段。实现子系统的用户与用户中心的用户一对一,登陆状态由各子系统来维持。

但是这个方案目前存在几个问题:

1、子系统每次想获取这个用户公共字段都要去调用用户中心查询吗?

2、各子系统的后台都需要实现用户管理的功能,肯定要涉及到后台分页,但是要显示公共字段,如果是本地的两张表 join 就可以了,但是现在是子系统的用户表和用户中心的用户表 通过统一的用户 ID 关联起来查询,还要分页,这个难道要每次在后台查询完本地表后 循环中通过接口带上用户 ID 去用户中心查询后手动拼接上去吗?

以上问题如何解决,或者有什么其他比较成熟的实现方案吗?之前没接触过分布式的东西,最近也在了解微服务,但是换成微服务不太现实。

  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    143 引用 • 442 回帖
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    9703 引用 • 44133 回帖 • 91 关注

相关帖子

被采纳的回答
  • 88250

    我怎么感觉很合理的样子 😂 循环用批量接口调用一次就行,返回值也是个列表,然后按 global uid 合并一下,stream API 在这个时候就很好用了。

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 88250

    这个方案基本就是 OAuth,只是少了 access token,因为内部系统间其实也不需要。查询方面用户服务提供一个按 id 或者字段条件的列表接口,其他系统内部分页或者按条件查。

    1 回复
  • CoderShen
    作者

    好的,那假如我的后台列表既要展示用户服务中的公共字段,比如 姓名,头像。也要展示子系统自己用户表的字段,那么这时候我先在子系统查询本地用户表的列表,然后再循环列表,根据公共的用户 ID 去调用用户服务的接口获取 姓名和头像字段,最后在手动组装成 VO 对象吗,这样感觉不是太不合理啊

    1 回复
  • 88250

    我怎么感觉很合理的样子 😂 循环用批量接口调用一次就行,返回值也是个列表,然后按 global uid 合并一下,stream API 在这个时候就很好用了。

    2 回复
  • CoderShen
    作者

    比如说,用户服务提供一个接口,接口的参数的 ids,这样我一次获取多个,就不会出现频繁调用接口了

  • CoderShen
    作者

    stream API 还没听说过,我先了解下,先实现看看吧,感谢!🙏

  • wlfeng

    可以考虑从数据库入手啊,建一个报表库,把用户表数据库包含进去,需要做用户数据查询的时候直接调用报表库就行了啊,而且还不会影响用户数据库的数据和性能,多数据源了解一下

请输入回帖内容 ...
CoderShen
编程破万行,下指如有神! 昆明

推荐标签 标签

  • React

    React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。

    192 引用 • 291 回帖 • 375 关注
  • Logseq

    Logseq 是一个隐私优先、开源的知识库工具。

    Logseq is a joyful, open-source outliner that works on top of local plain-text Markdown and Org-mode files. Use it to write, organize and share your thoughts, keep your to-do list, and build your own digital garden.

    7 引用 • 69 回帖
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    22 引用 • 148 回帖 • 16 关注
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    29 引用 • 201 回帖 • 31 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 6 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 726 关注
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    5 引用 • 18 回帖 • 181 关注
  • 创业

    你比 99% 的人都优秀么?

    82 引用 • 1395 回帖
  • 自由行
    1 关注
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖 • 5 关注
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 92 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    174 引用 • 3851 回帖
  • wolai

    我来 wolai:不仅仅是未来的云端笔记!

    2 引用 • 14 回帖 • 2 关注
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    7 引用 • 30 回帖 • 384 关注
  • Follow
    4 引用 • 12 回帖 • 13 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 2 关注
  • 分享

    有什么新发现就分享给大家吧!

    248 引用 • 1794 回帖
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 676 关注
  • Outlook
    1 引用 • 5 回帖 • 4 关注
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    6 引用 • 15 回帖 • 17 关注
  • Sphinx

    Sphinx 是一个基于 SQL 的全文检索引擎,可以结合 MySQL、PostgreSQL 做全文搜索,它可以提供比数据库本身更专业的搜索功能,使得应用程序更容易实现专业化的全文检索。

    1 引用 • 224 关注
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    35 引用 • 468 回帖 • 762 关注
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖 • 1 关注
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 116 关注
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 556 关注
  • 996
    13 引用 • 200 回帖 • 6 关注
  • OpenShift

    红帽提供的 PaaS 云,支持多种编程语言,为开发人员提供了更为灵活的框架、存储选择。

    14 引用 • 20 回帖 • 657 关注