V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
REDGroundwu
V2EX  ›  职场话题

做后端开发的时候如何预见问题的发生和解决潜在的问题?

  •  
  •   REDGroundwu · 246 天前 · 1562 次点击
    这是一个创建于 246 天前的主题,其中的信息可能已经有所发展或是发生改变。

    面试的时候遇到了,实在不知道怎么回答,特来请教一下各位。

    12 条回复    2024-04-10 15:02:46 +08:00
    RihcardLu
        1
    RihcardLu  
       246 天前
    依赖于经验或者看过相关的案例会好答一点,但这有个悖论,如果能提前遇见那大部分情况都能解决;遇到的基本上都是未考虑到或是考虑不完全的的。举个简单例子,比如在做一些排行榜的时候,就必然会有榜单更新的实时性、准确性、稳定性这几个因素的相互考虑。

    如果要求实时性高,必然会有缓存;有缓存也必然会影响准确性,怎么及时的更新缓存;如果引入缓存、主动更新机制,系统的复杂度增加,那就又会涉及到监控(这里指的更多是业务层面监控,比如缓存更新失败如何感知),巴拉巴拉……
    weimutter4
        2
    weimutter4  
       246 天前
    完全测试, 性能测试, 压测, 完整的监控! 好多公司不懂微服务。 以为搞个服务就完事了。 但是正因为是微服务。 向上还要考虑服务调用。 服务依赖 , 完整的服务监控。 等等
    xwwsxp
        3
    xwwsxp  
       246 天前
    别想了,君不见,大厂也是这个崩完那个崩,都是草班台子。
    uSy62nMkdH
        4
    uSy62nMkdH  
       246 天前
    1L 说的很好了,这种事一般就是出一次事长一次记性,如果公司技术氛围跟体量还可以,经常会有一些故障复盘,多听听没坏处
    iyiluo
        5
    iyiluo  
       246 天前
    做的多了就知道了,比如做一个带输入输出的接口,后面肯定会遇到 xss 攻击,所以前期一定要做好参数过滤
    whee
        6
    whee  
       246 天前
    这种事情就是经验积累的过程。听得多,遇到的多,写东西的时候就能直觉的遇见在什么样的阶段,目前这个方案会产生什么样的问题。
    BuffDog
        7
    BuffDog  
       246 天前
    可能性是无穷的
    一般都是经验问题吧,也得平衡下系统复杂度
    tianzx
        8
    tianzx  
       246 天前   ❤️ 1
    我举个例子:如何设计用户表?
    可能会有问题的设计: 所有数据都丢在一张表。很明显随着数据量的增大,这里会成为 Block 系统的点
    良好的设计:按照 userId or phone number 进行分库分表,然后数据聚合到 ES 或者其他系统方便进行模糊查询,最后将数据同步到 Hive 中,可以进行大数据分析。(问题:常见的分库分表算法有哪些?如何防止数据倾斜?如何保证数据一致性?如何保证数据安全?如何保证系统平滑的扩容、缩容?)
    根据业务的设计:主要访问来自于 C 端还是 B 端。未来是否需要支持单点登录、第三方登录。根据业务的不同,你又可以去做针对性的优化,比如数据库的反范式,多级缓存的设计 。
    最后,这只适用于面试。实际情况是:一个系统可能连 1w 个用户都没有,并发也都是个位数。
    hevi
        9
    hevi  
       246 天前
    根据历史经验多想和多测吧,然后出了问题就积累,然后循环
    yifangtongxing28
        10
    yifangtongxing28  
       246 天前
    你能预测这些的话,直接买股票,比上班实在
    gosky
        11
    gosky  
       246 天前 via Android
    预见问题的发生,应该靠经验吧?
    解决潜在的问题,我的理解是只能防御潜在的问题,比如留好日志,能最快分析出问题;比如防御型编程,控制问题的影响范围
    KC35
        12
    KC35  
       246 天前
    只能觉醒见闻色了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3435 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 20ms · UTC 10:23 · PVG 18:23 · LAX 02:23 · JFK 05:23
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.