草庐IT

最近关于工作的几点思考

sherlockyb 2023-03-28 原文

吾日三省吾身,记录一下近期关于工作的几点思考。

  1. 好记性不如烂笔头,随手记录的习惯永不过时。

举几个例子。

  • 在项目管理时,通过 Microsoft Excel 或 Google Sheet 制作完整的进度表。表的内容主要涵盖关键目标,对应的 owner 以及指标,可采取总分的方式;可以日或周为单位定期更新,更新频率取决于项目的不同阶段。比如在前期,以日为单位可更及时地暴露问题并解决,到中后期,项目已趋于稳定,调整为以周为单位降低频次,也有助于提高效率,毕竟频繁的同步会也是需要时间成本的。
  • 在用 Jira 的 story/task 追踪任务时,可利用其 comment 功能,每一个阶段性的进展都可以通过追加 comment 的方式来记录,这样,通过 comment 列表就可以一目了然的看出任务的完整进展情况。
  • 当长期处理一个问题时,如 dive deep API 的 spike issue、接入 SEAuth 等,用 wiki 等阶段性地及时记录遇到的问题或新发现是个不错的习惯,也便于后续总结时有信手拈来的素材。
  1. 以目标为导向,Try any way。

上栗子,

  • 在做属性抽取时,抽取方法不停地迭代,先后经历了 Dictionary、OCR、NumberType、Machine Learning、Kencyclo、Regex 等,其最终目的都是为了提高抽取的 coverage 和 precision。
  • 还是属性抽取,有 A 和 B 两个表示长度的属性,仅仅是单位类型不同,但 A 的 coverage 要远大于 B,此时借助单位转换,用 A 抽取的结果,通过单位转换来抽取 B,最终将 B 的coverage 提升 50%,这是在原有的属性抽取框架下很难做到的。这个方法也衍生出后来的通过 metric 比较好的属性来抽取其他属性的新思路。
  1. 在项目初期,定期的小组内部 dive deep 会议,及时交换想法,同步发现的问题并讨论如何解决,不仅能规避重走弯路,也能提高生产效率,集思广益,最大化团队力量。

比如最近在做的 AWS cost saving,每周一次的 dive deep 会议,除了更新进展,更多的是交流分享各自在做的过程中产生的困难、启发、最佳实践等,提升整体的效率。

  1. 切勿眼高手低,要有匠心精神,即便是小的功能点,也是可以做到极致。

很欣赏组里的一位前辈,很小的功能点,也能站在使用者角度仔细打磨,最终实现的版本堪称 perfect。

  1. 多从用户角度出发,简单易用,磨炼产品思维。

例如系统中 offline job 的UI,经组里一同事优化后,排版紧凑明了,体验感一下就上来了。

  1. 自测很重要,盲目的自信是危险的,即便是很小的改动,也需要测试验证,往往能发现意想不到的问题。

这个道理人人都懂,可是能严格执行的少之又少,真的毫不夸张,工作中遇到的各种盲目自信的人太多了,包括笔者自己,偶尔也会犯这样的错误,又该反省了……

  1. 对已有代码的改动时,修改和 review 都要谨慎,核心代码更不用说了,即便是一行代码也存在风险。

对已有的老逻辑要抱有敬畏之心,在吐槽写的如何如何烂的同时,也要思考当初为何会这样写,有什么特殊考量的地方。

  1. 效率的提升应该是一直在路上,没有最快,只有更快。用系统自动化代替一切费时费力的重复性人工操作。

比如我们做属性抽取时需要定期追踪 metric,最初都是每周由 owner 手动更新一次,后来用自动化的 job 来定期生成 metric 并在系统中可视化展示,省事多了。

  1. 当遇到比较耗时的或重试多次都不行的问题时,不要继续重复忍受或直接放弃,而是换个思路,积极想新的办法解决。

比如最近遇到的一个问题,使用 GitHub 时,网页访问正常,但通过 ssh 合并代码时,要么就很慢,要么就因为 SSL_ERROR_SYSCALL 错误而部署失败,重试了不下 20 次,最后还是通过 Google 找到答案,大概率是域名遭到 DNS 污染,可以通过修改 host,将 GitHub 域名指向真实的 IP(从 ipaddress 获取),并刷新本地 DNS 缓存,一下就顺畅了。

  1. 对未知或不熟悉的事物有畏惧感是人之常情,总觉得挺复杂,很难。其实接触后就会发现并不难,再进一步了解后会发现还是你所熟悉的配方,所以要勇于迈出第一步!

工作中难免会不停地接触新的东西,对于一项对你来说新的技术,先从它的官网 user guide 开始,是一个不错的选择。其实生活中也是一样的,敢于尝试新的事物,跳出舒适区,能让你收获新的东西。

  1. 写文档对于程序员来说是最大的挑战。越是不想写,越拖延,恶性循环中。俗话说,万事开头难,先把标题搞定,然后再把大纲搞定,确定要写哪些内容,整体框架出来了,然后再逐个往里填就是了。

说写文档这个事儿是最大挑战一点也不夸张,有时候可能憋一上午都挤不出几个字儿,比写代码难多了……

  1. 个人优秀是一回事儿,如果能激发队友潜能,让整个 team 更高效,才是更牛逼的。

放手,鼓励并相信队友。举个栗子,系统在本地启动时遇到 https 服务无法访问的问题,让小伙伴自己尝试解决,并给出相关的参考链接,最终他成功解决问题并还整理出简洁明了的 guide wiki,挺好的。

本文作者:sherlockyb
首发链接:https://www.yangbing.club/2022/05/31/Some-thoughts-on-work-recently/
许可协议:本博文采用 CC BY-NC-SA 3.0 CN 许可协议,转载请注明出处!

有关最近关于工作的几点思考的更多相关文章

  1. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  2. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  3. ruby - 无法让 RSpec 工作—— 'require' : cannot load such file - 2

    我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳

  4. ruby-on-rails - rspec should have_select ('cars' , :options => ['volvo' , 'saab' ] 不工作 - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request

  5. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  6. ruby - JetBrains RubyMine 3.2.4 调试器不工作 - 2

    使用Ruby1.9.2运行IDE提示说需要gemruby​​-debug-base19x并提供安装它。但是,在尝试安装它时会显示消息Failedtoinstallgems.Followinggemswerenotinstalled:C:/ProgramFiles(x86)/JetBrains/RubyMine3.2.4/rb/gems/ruby-debug-base19x-0.11.30.pre2.gem:Errorinstallingruby-debug-base19x-0.11.30.pre2.gem:The'linecache19'nativegemrequiresinstall

  7. ruby - `rescue $!` 是如何工作的? - 2

    我知道全局变量$!包含最新的异常对象,但我对下面的语法感到困惑。谁能帮助我理解以下语法?rescue$! 最佳答案 此构造可防止异常停止您的程序并使堆栈跟踪冒泡。它还会将该异常作为值返回,这很有用。a=get_me_datarescue$!在此行之后,a将保存请求的数据或异常。然后您可以分析该异常并采取相应措施。defget_me_dataraise'Nodataforyou'enda=get_me_datarescue$!puts"Executioncarrieson"pa#>>Executioncarrieson#>>#更现实的

  8. ruby - File.read ("| echo mystring") 是如何工作的? - 2

    我在我正在处理的一些代码中发现了这一点。它旨在解决从磁盘读取key文件的要求。在生产环境中,key文件的内容位于环境变量中。旧代码:key=File.read('path/to/key.pem')新代码:key=File.read('|echo$KEY_VARIABLE')这是如何工作的? 最佳答案 来自IOdocs:Astringstartingwith“|”indicatesasubprocess.Theremainderofthestringfollowingthe“|”isinvokedasaprocesswithappro

  9. ruby - 这个 ruby​​ 注入(inject)魔术是如何工作的? - 2

    我今天看到了一个ruby​​代码片段。[1,2,3,4,5,6,7].inject(:+)=>28[1,2,3,4,5,6,7].inject(:*)=>5040这里的注入(inject)和之前看到的完全不一样,比如[1,2,3,4,5,6,7].inject{|sum,x|sum+x}请解释一下它是如何工作的? 最佳答案 没有魔法,符号(方法)只是可能的参数之一。这是来自文档:#enum.inject(initial,sym)=>obj#enum.inject(sym)=>obj#enum.inject(initial){|mem

  10. ruby-on-rails - attr_accessible 在 Rails 中如何工作? - 2

    我刚刚有一个关于RubyonRails和模型(Rails3)中的attr_accessible属性的一般性问题。有人可以解释应该在那里定义哪些模型属性吗?我记得一些关于批量分配风险的事情,虽然我在这方面不太了解......谢谢:) 最佳答案 想象一个带有一些字段的订单类:Order.new({:type=>'Corn',:quantity=>6})现在假设订单也有折扣代码,比如:price_off。您不想将:price_off标记为attr_accessible。这会阻止恶意代码制作最终会执行如下操作的帖子:Order.new({:

随机推荐