CODING DevOps 代码质量实战系列第一课:代码规范与 Git Flow - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
Coding.NET 轻量级社交
开源项目广场
使用帮助
意见反馈
CodingNET

CODING DevOps 代码质量实战系列第一课:代码规范与 Git Flow

  •  
  •   CodingNET Aug 24, 2020 3309 views
    This topic created in 2082 days ago, the information mentioned may be changed or developed.

    1

    讲师介绍

    杨周
    CODING DevOps 架构师
    CODING 布道师

    连续创业者、DIY/Linux 玩家、知乎小 V,曾在创新工场、百度担任后端开发。十余年一线研发和带队经验,经历了 ToB 、ToC 、O2O 、国内、出海各种项目,见证了云计算时代的诞生,擅长研发最佳实践:Code Review 、DevOps 、Git Workflow 、敏捷开发、架构、极客办公硬件。

    背景

    随着 ToB (企业服务)的兴起和 ToC (消费互联网)产品进入成熟期,线上故障带来的损失越来越大,代码质量越来越重要,而「质量内建」正是 DevOps 核心理念之一。而且提高代码质量的最佳实践,不只适合新项目,也为老项目提供完善的渐进式方案。

    常见代码质量问题

    • 英语拼写错误
    • 泄露密码
    • 无效注释
    • 魔法数字
    • hard code (写死)
    • 缩进等代码风格问题

    如何解决代码质量问题

    Code Review

    第一步是锁定主干,禁止直接提交,采用多分支开发。先拉取一个分支,修改代码并推送分支,然后发起一个合并请求,请同事进行代码评审了。比较高级的技巧是推代码时自动创建一个合并请求,合并后临时分支被自动删除。

    创建合并请求后,需要把链接发给同事进行评审,这也是敏捷开发倡导的一个理念高效沟通。一般选择直接通过企业聊天工具通知同事,如果不及时通知,可能同事好几天才会看到,耽误项目进度。收到合并请求后,请尽量做到当天评审,不要拖延。

    需要注意每次提交代码只提交最小粒度的一件事,即「原子性提交」,而不要把几件事做完一次性提交。比如有三件事,其中一件是修 Bug,结果修的有问题要回滚。如果三件事分三次提交,就可以轻松回滚有问题的,另外两个正确的不受影响;而一起提交的话就没法回滚。

    Code Review 一定是在每次代码合并进去之前进行评审,发现问题减少故障,如果错误的代码已经合并上线了,这个时候再看就叫「故障反思会」而不叫「 Code Review 」,就没有意义了。

    2

    Lint 代码规范的增量检查

    Lint 叫代码静态扫描程序,各种语言对应的 Lint 程序是不同的,对应的规范也不同:

    3

    • Lint 的使用时机

    1 、在 IDE 里实时运行,边写边检查,这样是最方便的,缺点是需要每个人都进行配置。

    2 、Git commit 提交代码时检查:每个 Git 项目都有 .git/hooks 目录,修改里面的 pre-commit 脚本,即可在提交代码时进行拦截检查。缺点是可被删除。

    3 、最可靠的就是服务端检查。当代码推送到服务器上时,进行持续集成检查,这种方式非常可靠且不会被删除,缺点就是不如本地那么及时。

    这三种方式一般结合使用。

    4

    • 增量检查

    老项目的规范问题往往很多,一次清理干净需要耗费大量人力,而且一次改动的代码越多,风险就越高,可能导致线上故障,尤其是缺乏自动化测试的项目。

    所以建议使用增量检查。如果同学们对 git 命令熟悉的话就很好理解,增量检查就是 git diff 。在本地提交时 git diff 可以拿到所有新增的、修改的和删除的文件,只要把删除的文件排除掉,把别的文件挑出来,传递给 lint 程序就可以了。同学们一定要熟悉 Linux 命令、git 命令,不要一直用 git 的图形界面,那你就很难掌握这些内容。

    访问 CODING 帮助文档( https://help.coding.net/ ),搜索「增量检查」,即可看到完整的配置代码。

    Git workflow

    5

    单兵作战的时代就如上图所示,一个人提交代码,不需要什么工作流,一直往主干里提交就可以。而现在多人协作做项目时,每个人都往主干里提交就会产生冲突。如下图所示,多分支开发,每个需求每个 Bug 都拉一个小分支,开发完毕再合并进主干里。

    有两种常用的工作流,第一种最简单叫:Feature branch workflow (需求分支工作流)。可以从下图中看到主分支里拉下来两个分支,一个做登录,一个做支付。登录做完就合并进去,后续有个短信的 bug 修复了,也合并进去后就发布了,但支付功能还在开发,这时就会出现问题。本来登录和支付要一起上线,表示同一时期同一阶段的两个功能相互有依赖,结果因为线上的短信 bug 修复,就把登录先带上线了,这就导致了问题,所以大项目不适合用这种模式,而是使用第二种。

    6

    简易 Git Flow 是双分支的开发模式,除主分支外还有一个 develop 分支。Develop 分支对应敏捷开发里的迭代,每次迭代都会创建一个 develop,这次迭代里的所有功能开发完都合并到 develop,而不会合到主干上。主干保持随时可发布的状态,有 Bug 就在主干上修,等这次迭代全部结束,再把 develop 合到主干上。

    Fork

    Fork 不是工作流,团队协作一定不要用 Fork 。Fork 是专门用于开源项目的。当我们试图修改开源项目时,由于没有创建分支的权限,只能把这个项目复刻(官方翻译)成为自己的项目,然后再在自己的项目里拉分支,修改代码,最后发起一个跨项目的合并请求,合并到作者的开源项目里,如果后面还想再开发的话,需要再同步过来。所以 Fork 仅仅用于开源协作,完全不适合团队协作,同学们千万不要搞错,具体的文档可以扫码进行查看。

    7

    结语

    最后总结一下代码质量的升级路线。从最原始的提交主干不检查代码,不检查规范,到锁定主干进行人工检查,然后人工检查累,希望能做自动检查,把尽量多的东西都做成自动检查。但有些东西是自动检查做不了的,比如代码里使用了拼音,语法没有报错;或者英文单词用错,比如用户的「积分」应该使用 points 而不是 integral 。所以不能看见自动化检查过了,就直接同意合并,这是不负责任的做法,一定要进行人工检查。

    经过这个流程,同学们的代码就会非常干净漂亮,团队协作的风格也一致了。一般会挑一个知名的业界大厂的代码规范,而不要自己发明规范,这样不仅不能服众,而且以后再参加开源项目的话,难以和业界保持一致。

    点击观看课程回放

    No Comments Yet
    About     Help     Advertise     Blog     API     FAQ     Solana     3466 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 77ms UTC 11:24 PVG 19:24 LAX 04:24 JFK 07:24
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86