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

41 天前
 REDGroundwu

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

1296 次点击
所在节点    职场话题
12 条回复
RihcardLu
41 天前
依赖于经验或者看过相关的案例会好答一点,但这有个悖论,如果能提前遇见那大部分情况都能解决;遇到的基本上都是未考虑到或是考虑不完全的的。举个简单例子,比如在做一些排行榜的时候,就必然会有榜单更新的实时性、准确性、稳定性这几个因素的相互考虑。

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

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1031107

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX