学员分享丨十年架构师感悟:敢于“提出问题”

最近呢小誉收到了一位工作十年的学员投稿,这位学员是2011年从誉天学习HCIE课程并顺利拿证,先后在华为等大厂工作。他想把他这十年的工作经验分享给各位学弟学妹们。
这些经验并非来自于具体的技术实现,而是在架构设计和实施过程中所体会到的一些软性经验和领悟。希望通过这些分享,能够激发大家对于架构设计和技术实践的思考,帮助大家更好地理解和应用架构原则和方法。

敢于“提出问题”
在软件开发的日常工作中,我们往往习惯于沉浸在解决问题的模式中。无论是修复bug,还是优化性能,解决问题似乎成为了我们的核心任务。提出问题同样是一项至关重要的职责,甚至在某些情况下,它可能比解决问题更具挑战性。
从用户的角度出发去提出问题或需求,意味着我们需要跳出自己的技术思维框架,尝试站在非技术人员的角度去看待问题。这需要我们具备深厚的同理心,能够真正理解用户的需求和痛点。同时,我们还需要有足够的洞察力,能够从纷繁复杂的表象中提炼出核心问题,为团队指明方向。
当然,提出问题并不是一件容易的事。它需要我们具备丰富的经验和深厚的专业知识,还需要我们敢于挑战现状,勇于提出新的想法和观点。但正是这种挑战性和困难性,使得提出问题成为了一项更加有价值的工作。
因此,作为一名架构师,我们不仅要善于解决问题,更要勇于提出问题。通过不断地提出并解决问题,我们才能够推动技术的进步,为公司和团队创造更多的价值。同时,我们也需要在团队中倡导这种提出问题的文化,鼓励每个成员都敢于表达自己的观点和想法,共同推动团队的发展和创新。

学会“权衡与取舍”
在项目的推进过程中,我们往往会面临各种各样的需求和挑战,如何做出明智的决策,确定“不要什么”,比简单地列出“要做什么”更加困难。
在架构设计中,我们经常会遇到各种非功能性需求的冲突,如高可用性、高性能、高扩展性、高可维护性等。这些需求往往相互制约,难以同时满足。因此,作为架构师,我们需要根据项目的实际情况和业务需求,明确哪些需求是优先的,哪些需求是可以妥协的。这就需要我们有深厚的技术功底和敏锐的洞察力,能够准确把握项目的核心需求和痛点。
在分布式系统中,一致性、可用性和分区容忍性往往难以同时满足。我们需要根据项目的实际需求,在这三者之间做出权衡和取舍。这种权衡不仅体现在技术层面,更体现在业务层面。我们需要与产品经理、开发团队等各方密切沟通,共同确定项目的目标和优先级。

非功能性需求往往决定架构
非功能性需求涉及到系统的性能、伸缩性、可扩展性、可维护性等多个方面,这些都是决定系统质量和用户体验的重要因素。在架构设计中,我们需要根据非功能性需求来选择合适的技术、框架和模式,以确保系统能够满足业务的需求并具备良好的可维护性和可扩展性。
因此,在架构设计的初期,我们就应该充分考虑非功能性需求,并将其作为架构设计的核心考虑因素。通过与产品经理、开发团队等各方密切合作,明确非功能性需求的优先级和目标,并据此选择合适的架构方案和技术实现方式。
此外,随着技术的不断发展和业务的不断变化,非功能性需求也可能会发生变化。因此,我们还需要在架构设计的过程中保持灵活性和可扩展性,以便能够随时应对这些变化。
实际上在架构领域,大家对这点也是有共识的。比如下图中这个 Micro-Kernel 的架构模式来自《面向模式的软件架构》的第一卷,它一大特点就是有比较好的可扩展性,同时通过 Plugin 之间的隔离,能够提高系统的可用性。

“简单"并不“容易”
在架构设计中,追求简单并不意味着我们可以轻易地达成目标,反而需要付出更多的努力和深入思考。
简单和容易是两个不同的概念。简单是指设计、代码或解决方案的清晰、简洁和易于理解,而容易则是指实现、操作或维护的难易程度。很多时候,我们可能会为了追求实现的容易性而牺牲了设计的简单性,这是不正确的。我们应该始终将简单作为设计的目标,即使这意味着实现过程可能会更加复杂。
布隆过滤器是一个很好的例子,它用简单的数据结构解决了重复数据过滤的问题,但背后却蕴含着深入的思考和巧妙的设计。这种简单并非一蹴而就,而是经过大量深入工作后的结果。
举个例子,我们来回顾一下软件生命周期中各个阶段的成本消耗占比。可以看到,在整个软件生命周期中,成本消耗最高的并不是设计、编码这些阶段,而是维护阶段。也就是说,如果你让维护变得简单,这会是最有性价比的。

从“问题”开始,而不是“技术”
作为技术人员,我们往往对新技术充满热情,渴望将其应用到实际工作中。然而,我们必须时刻提醒自己,技术只是解决问题的手段,而不是目的本身。在面临问题时,我们应该首先从问题的本质出发,思考其背后的真实需求,然后再选择适合的技术来解决它。
此外,我们还需要警惕“技术驱动”的思维模式。有时候,我们可能会因为掌握了某项技术而想要将其应用到所有场景中,这种思维往往会导致我们忽略了问题的真实需求,从而做出错误的决策。因此,我们需要时刻保持清醒的头脑,以问题为导向,而不是被技术所驱动。
总之,从“问题”开始而不是“技术”,是我们在工作中需要时刻铭记的原则。只有真正理解了问题的本质和需求,才能选择出最适合的技术来解决它,从而实现项目的成功和团队的成长。

过度繁忙使你落后
在这个快速变化的时代,技术不断革新,业务需求也在不断演变,如果我们因为忙碌而忽视了学习和提升自己的能力,那么我们很快就会发现自己已经落后于他人。
很多程序员因为长时间的加班和工作压力,导致没有足够的时间和精力去学习和更新知识。他们可能对工作已经产生了疲劳感,对于新技术和新方法也缺乏兴趣和热情,这种状态会让他们逐渐失去竞争力,难以适应市场的变化。
然而,学习和提升自己并不一定要离开熟悉的领域,即使在同一个领域,也可以通过不断探索和尝试新的方法和技术来保持活力和竞争力。我们可以利用业余时间,通过阅读书籍、参加技术交流会、参与开源项目等方式来不断更新自己的知识体系,掌握最新的技术和工具,以适应不断变化的市场需求。

此外,我们也需要学会管理自己的时间和工作,避免过度忙碌和加班。我们可以制定合理的工作计划,合理安排时间,尽可能提高工作效率和质量。同时,我们也需要保持身心健康,注意工作与生活的平衡,避免因为过度忙碌而导致身体和心理上的问题。
通过持续学习和不断探索,我们可以在工作中保持活力,并不断地提升自己的竞争力。这种积极的学习态度和探索精神对于我的职业发展是非常重要的,它能够让我保持在一个不断成长的状态中。

更多精品优质课程
识别二维码即可预约试听

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/817492.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Github 2024-04-09 Python开源项目日报 Top10

根据Github Trendings的统计,今日(2024-04-09统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目10Vue项目1JavaScript项目1系统设计指南 创建周期:2507 天开发语言:Python协议类型:OtherStar数量:241693 个Fork数量:42010 次…

pandas 读取csv 数据 read_csv 参数详解

前言 Pandas 是一个开源的数据分析和数据处理库,它是基于 Python 编程语言的。 Pandas 提供了易于使用的数据结构和数据分析工具,特别适用于处理结构化数据,如表格型数据(类似于Excel表格)。 Pandas 主要引入了两种新…

C++生成动态库,C++和C#以及Java在windows和linux调用

Windows生成dllC库 1、创建动态链接库项目 源文件编写函数 // dllmain.cpp : 定义 DLL 应用程序的入口点。 #include "pch.h"int sum(int a, int b) {return a b; }BOOL APIENTRY DllMain( HMODULE hModule,DWORD ul_reason_for_call,LPVOID lpReserved) {switch…

【LAMMPS学习】八、基础知识(1.8)键的断裂

8. 基础知识 此部分描述了如何使用 LAMMPS 为用户和开发人员执行各种任务。术语表页面还列出了 MD 术语,以及相应 LAMMPS 手册页的链接。 LAMMPS 源代码分发的 examples 目录中包含的示例输入脚本以及示例脚本页面上突出显示的示例输入脚本还展示了如何设置和运行各…

【Linux】手搓shell

手搓shell 代码 #include <stdio.h> #include <stdlib.h> #include <string.h> #include <errno.h> #include <unistd.h> #include <sys/types.h> #include <sys/wait.h> #include <ctype.h> #include <sys/stat.h> #…

取出/var/log/secure中一小时内登录失败超过三次的IP

取出/var/log/secure中一小时内登录失败超过三次的IP 前两个字段是日期&#xff0c;第三个字段是小时&#xff0c;第四个字段是IP cat /var/log/secure | sort -i | awk -F [ :] /Failed/{a[$1" "$2" "$3" "$4" "$(NF-3)]}END{for(i …

使用 Python 实现复制粘贴的功能

pandas 里面有一个 pd.read_clipboard 函数&#xff0c;可以根据你复制的内容生成DataFrame。是的&#xff0c;就是我们平时选中&#xff0c;然后 CtrlC 时拷贝的内容。所以比较神奇&#xff0c;那么 pandas 到底是怎么做到的&#xff0c;它是怎么读出我们使用 Ctrl C 复制的内…

Python学习笔记(三)

一、使用朴素贝叶斯制作鸢尾花数据模型 from sklearn.preprocessing import StandardScaler from sklearn.naive_bayes import MultinomialNB from sklearn.datasets import load_iris from sklearn.model_selection import train_test_split from sklearn.feature_extraction…

【面试题】s += 1 和 s = s + 1的区别

文章目录 1.问题2.发现过程3.解析 1.问题 以下两个程序真的完全等同吗&#xff1f; short s 0; s 1; short s 0; s s 1; 2.发现过程 初看s 1 和 s s 1好像是等价的&#xff0c;没有什么区别。很长一段时间内我也是这么觉得&#xff0c;因为当时学习c语言的时候教科书…

更优性能与性价比,从自建 ELK 迁移到 SLS 开始

作者&#xff1a;荆磊 背景 ELK (Elasticsearch、Logstash、Kibana) 是当下开源领域主流的日志解决方案&#xff0c;在可观测场景下有比较广泛的应用。 随着数字化进程加速&#xff0c;机器数据日志增加&#xff0c;自建 ELK 在面临大规模数据、查询性能等方面有较多问题和挑…

【简单讲解如何安装与配置Composer】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

实时渲染 -- 流明(Lumen)

首先我们需要知道Lumen需要解决哪些问题。 很多人都会问&#xff0c;既然已经有了硬件的Raytracing &#xff0c;我们为什么还要Lumen呢。这是由于很多硬件并不支持 Realtime Raytracing&#xff0c;对于支持的那些硬件&#xff0c; N 卡还算是勉强可以&#xff0c;而 A 卡支持…

AI人工智能讲师叶梓 大模型推理能力提升: 方法与实践

在人工智能的领域中&#xff0c;推理能力是衡量模型智慧的关键指标之一。近年来&#xff0c;研究者们提出了多种方法来增强大模型的推理能力&#xff0c;这些方法在不同程度上模拟了人类的思考过程&#xff0c;提高了模型解决问题的准确性和效率。以下是对这些方法的深入探讨和…

算法练习第五十四天|392. 判断子序列、115. 不同的子序列

392. 判断子序列 115. 不同的子序列 判断子序列 class Solution {// public boolean isSubsequence(String s, String t) {// int spointer 0;// int tpointer 0;// while(spointer < s.length() && tpointer < t.length()){// if(s.char…

Python中的可变对象和不可变对象详解

文章目录 1. 对象可变性简介2. 不可变对象的特性2.1 字符串2.2 整数和浮点数2.3 元组 3. 可变对象的特性3.1 列表3.2 字典3.3 集合 4. 函数中的对象传递4.1 不可变对象的传递4.2 可变对象的传递 最近面试被问到了这个问题&#xff0c;写个帖子解释一下可变对象和不可变对象 1. …

震动Github榜!7K Star火爆的数字人竟然开源了,拿走不谢(文末福利免费领)

本号专注于分享Github和Gitee上的高质量开源项目&#xff0c;并致力于推动前沿技术的分享。 软件介绍 Fay数字人框架-带货版是一个用于构建数字人应用场景的开源项目&#xff0c;具有低耦合度的各功能模块。你可以轻松更换声音来源、语音识别、情绪分析、NLP处理、情绪语音合成…

ES6-2:Iterator、Proxy、Promise、生成器函数...

11-Iterator迭代器 打印出的是里面的内容&#xff0c;如果是for in打印出来的是索引&#xff0c;of不能遍历对象Symbol.iterator是js内置的&#xff0c;可以访问直接对象arr[Symbol.iterator]&#xff0c;()调用对象非线性一般不能迭代 后两个是伪数组&#xff0c;但是是真迭…

Android,AMS、WMS、PKMS添加动态控制debug开关功能

问题背景 在framework源码中有很多debug开关,通常我们想要看某个模块的日志,比如说广播,就需要去修改源码,把对应的debug值改为true,但是这种方法耗时耗力,比如说我想看sendBroadcast的流程,但是BroadcastQueue中有很多debug开关,如下: 这种就需要去修改对应的源码才…

K8s: 将一个节点移出集群和相关注意事项

前置步骤 在Kubernetes集群中&#xff0c;要移出一个节点&#xff0c;你需要执行以下步骤&#xff1a; 1 &#xff09;将节点标记为不可调度 首先&#xff0c;你需要将目标节点标记为不可调度&#xff0c;以确保Kubernetes不会在该节点上调度新的Pod这可以通过执行以下命令实…

腾讯客户端开发实习一面

听说腾讯25年5000offer&#xff0c;我就去了...投完简历&#xff0c;当天晚上做完测评&#xff0c;第二天下午打电话约了第三天面试&#xff0c;额流程很快&#xff0c;快到第三天就寄了... 写在这里做个记录&#xff0c;也可以给学习学妹们经验&#xff0c;文末也有大厂面经合…