数据库管理-第176期 浅析代码团队建设(20240425)

数据库管理176期 2024-04-25

  • 数据库管理-第176期 浅析代码团队建设(20240425)
    • 1 国内现状
    • 2 需求管控
    • 3 竞争与迭代
    • 总结

数据库管理-第176期 浅析代码团队建设(20240425)

作者:胖头鱼的鱼缸(尹海文)
Oracle ACE Associate: Database(Oracle与MySQL)
PostgreSQL ACE Partner
10年数据库行业经验,现主要从事数据库服务工作
拥有OCM 11g/12c/19c、MySQL 8.0 OCP、Exadata、CDP等认证
墨天轮MVP、认证技术专家、年度墨力之星,ITPUB认证专家、专家百人团成员,OCM讲师,PolarDB开源社区技术顾问,OceanBase观察团成员
圈内拥有“总监”、“保安”、“国产数据库最大敌人”等称号,非著名社恐(社交恐怖分子)
公众号:胖头鱼的鱼缸;CSDN:胖头鱼的鱼缸(尹海文);墨天轮:胖头鱼的鱼缸;ITPUB:yhw1809。
除授权转载并标明出处外,均为“非法”抄袭

其实本篇的内容,是上次在广州SACC,与崖山团队一朋友线下面基时plus我一个做Linux、K8s的老大哥一起聊天的时候,听我老大哥讲起的,即应该如何合理的去维护一个代码团队,让产品健康的迭代下去。

1 国内现状

下面的一些例子,都是道听途说,如有雷同,纯属不幸

  • 在与某国产数据库私下沟通的时候,我们很疑惑,为什么产品体系结构会如此复杂,对面大佬一声叹气:因为政治斗争和团队利益。
  • 预测某个功能需要投入50W,10个人,经过老板“审核”,只给30W,但是必须配置两个10人团队竞争。
  • 在技术主管之上总会找一个不懂技术or不是技术出身的来管理团队,美其名曰把控团队,其实是“外行领导内行”,后面干脆CTO都换成这样的人了。
  • 某数据库功能规划,是各个分支团队开会“吵架”争取,然后CTO拍板决定的,最后有一部分功能脱离了实际生产需求。
  • 版本迭代,升级过后以前好不容易解决了的BUG顺利“迎回”。

为什么会出现上面这些问题,其实还是代码团队管控和代码项目管理的问题。

2 需求管控

其实很多时候,我们去看某个产品,会发现不少让人“眼前一亮”但又丝毫没有落地可能性的“新功能”,为什么会出现这一现象,我认为,归根结底还是需求来源的问题。需求收集往往都不是根据实际可能面向的生产而来,很多是从“全量”(来源不明)的列表中一拍脑袋决定的。
其实很多时候,数据库并不需要太多“颠覆性”的玩意儿,有些地方连最基础的CRUD和ACID都有些吃力就去卷“高大上”的东西了,是不是算是本末倒置(当然没有亮点就没有机会)。
我认为,就目前的实际发展情况来看,咱们远远没有达到“不止领先,全面超越”,与国际上优秀数据库产品之间还有很大的差距,因此闭门造车是万万不可的,我们还需要去学习别家的先进经验,结合自身特色(发展程度、业务适配、广度深度等)来选择合适的路线发展自己的数据库产品。当然更多的需求是需要去聆听实际客户的心声。

3 竞争与迭代

在一个产品发展中,肯定会存在内部竞争和迭代的现象。就很多场景的竞争来说,简言而之就是在内耗,因为从整体角度来看,就是一场你死我活的斗争,干不过对方就可能面临着失势甚至是失业,这个却是管理者希望看到,他们认为下面人越卷,发展会越好。而在产品迭代之中,也会因为版本间、团队间的很多不良竞争因素,导致一些问题的出现。
这里说一个我看到的一个我认为比较合理的基于版本迭代的团队配置,首先我们需要了解,大多数的产品迭代,不是1.0彻底结束后才做2.0,而是1.0内部发展甚至还没有进入维护周期的时候就会启动2.0相关工作。在这个时候,A、B团队就倾向于各自对应1.0和2.0版本:
image.png

  • 在各自版本的设计&开发周期内,从整体角度以本版本优先,人员向本团队倾斜,优先解决本的研发需求
  • 在版本相对稳定之后开启新版本研发工作,人员逐步向新版本倾斜,而老版本从功能扩展逐渐向稳定维护转变
  • 新老版本交替过程中,老版本的创新可以向新版本输出,新版本的增强可以向老版本回迁
  • 由于团队间人员存在复用与交替,因此创新下移和功能回迁的难度不会太大
  • 版本内不同周期,版本之间也存在一定的竞争关系,也有合作关系

我认为这样的团队假设是相对合理,但是也需要管理者好好理顺发展路线,让所有团队为了相同的目标努力而不是各自为战。

总结

说真的最后我完全不知道写了些啥。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

安卓Activity的setContentView()流程分析

目录 前言一、Activity的视图加载过程1.1 视图结构1.2 流程分析1.2.1 Activity.java -->setContentView()1.2.2 Activity.java -->getWindow()1.2.3 PhoneWindow.java -->setContentView()1.2.4 PhoneWindow.java --->installDecor()1.2.4.1 PhoneWindow.java ---&…

Yolov5 export.py实现onnx模型的导出

查了很多资料,很多用python代码写的,只需要这个库那个库的,最后都没成功。 不如直接使用Yolov5里面的 export.py实现模型的转换。 一:安装依赖 因为yolov5里面的requirments.txt是将这些转换模型的都注释掉了 所以需要解除注释…

SpringCloud alibaba整合OpenFeign

目录 一、为什么使用OpenFeign 二、准备两个服务 三、最简单使用- 返回字符串 ①引入openfeign依赖 ②调用端在启动类上添加EnableFeignClients注解 ③在被调用端写一个简单的接口 ④在调用端新建一个service类 专门用于远程调用 ​编辑 ⑤ 在调用端写一个conteoller …

翻译《The Old New Thing》 - What does SHGFI_USEFILEATTRIBUTES mean?

What does SHGFI_USEFILEATTRIBUTES mean? - The Old New Thing (microsoft.com)https://devblogs.microsoft.com/oldnewthing/20040601-00/?p39073 Raymond Chen 2004年06月01日 在使用 SHGetFileInfo 函数时,你可以设置一个名为 SHGFI_USEFILEATTRIBUTES 的标志…

绿联搭建rustdesk服务器

绿联搭建rustdesk服务器,不再使用向日葵 注意:本服务器需要有动态公网IP以及自己的域名,ipv6未测试。 1. 拉取镜像 rustdesk/rustdesk-server-s6:latest 注意是这个-s6的镜像。 2. 部署镜像 2.1 内存配置 本服务器比较省内存&#xff0…

区块链安全应用-------压力测试

基于已有的链进行测试(build_chain默认建的链 四个节 点): 第一步:搭链 1. 安装依赖 在ubuntu操作系统中,操作步骤如下: sudo apt install -y openssl curl 2. 创建操作目录, 下载安装脚本 ## 创建操作…

力扣数据库题库学习(4.22日)

577. 员工奖金 问题链接 思路分析 Employee表与Bonus表通过empId字段可以连接,需求是查出奖金少于1000的员工名和奖金值。 这里奖金少于1000的情况就是没有奖金有奖金但少于1000 这里我给出的解决方案就是使用左连接,将Employee表作为左表&#xff…

js的算法-交换排序(冒泡)

交换排序 所谓交换排序,是指根据序列中两个元素关键字的比较结果来对换这两个记录在序列中的位置。基于交换的排序算法很多,本次介绍冒泡排序和快速排序。 冒泡 基本思想 从后往前(或从前往后)两两比较相邻元素的值&#xff0…

Nginx第3篇-使用ngx_http_proxy_connect_module配置https正向代理

场景 我使用python爬虫,然后需要个代理,所以就用Nginx搭了一个代理服务器。对Nginx也不太熟,慢慢摸索,搭建完之后发现只能代理http的请求,无法穿透https。几经折腾和摸索发现一个强大的HTTP代理模块:ngx_h…

泛微OA对接北森HR系统场景解析

随着企业信息化建设的深入推进,跨系统集成已成为提升管理效率、实现数据一体化的关键举措。详细阐述其如何通过泛微OA(Office Automation)系统与北森HR(Human Resource)系统的深度对接,实现人员信息、员工请…

RIP最短路实验(思科)

华为设备参考:RIP最短路实验(华为) 一,技术简介 RIP(Routing Information Protocol,路由信息协议)是一种基于距离矢量的内部网关协议,工作原理是每个路由器周期性地向邻居路由器发…

深度解析 Spring 源码:揭秘BeanFactory 之谜

文章目录 一、认识BeanFactory1.1 BeanFactory的概述1.2 BeanFactory与 ApplicationContext的区别 二、BeanFactory源码解读2.1 BeanFactory 接口2.1.1 getBean()2.1.2 containsBean()2.1.3 isSingleton() 2.2 DefaultListableBeanFactory 类2.2.1 registerBeanDefinition()2.2…

游戏行业干货科普 | 各个诚实都有哪些游戏公司?

本文主要列举上海、北京、广州、深圳、成都、杭州等城市游戏公司名称,大家可以码住,慢慢看~ 上海 米哈游 游戏势力新一极,近十年唯一一家打破腾讯、网易二强局面的公司莉莉丝 卡牌自研头部,SLG发行头部,最懂商业化的…

创建Maven项目的时候让选择maven模板

创建Maven项目的时候让选择maven模板 心得 工欲利其事 必先利其器。如果你想要干成一件事 那么必须先要精通对应的工具使用。之前我不太注重工具 我觉得只要代码写的好就可以了 但是当我们了解了产品经理的一些思想之后,我才明白一个好的产品是可以给用户提供多大…

文件上传方式三(若伊版本)

1.准备配置类 package com.ruoyi.screen.core;public class MimeTypeUtils {public static final String IMAGE_PNG "image/png";public static final String IMAGE_JPG "image/jpg";public static final String IMAGE_JPEG "image/jpeg";pu…

Stable Diffusion中的embedding

Stable Diffusion中的embedding 嵌入,也称为文本反转,是在 Stable Diffusion 中控制图像样式的另一种方法。在这篇文章中,我们将学习什么是嵌入,在哪里可以找到它们,以及如何使用它们。 什么是嵌入embedding&#xf…

Axure设计美观友好的后台框架页

使用Axure设计后台框架页 优点介绍: **1、使用中继器灵活配置菜单项; 2、二级菜单面板跟随一级菜单位置显示; 3、菜单链接打开后,联动添加tab标签; 4、标签页与iframe内容联动,可关闭; 5、左侧…

SpringBoot集成Sharding-JDBC实现主从同步

SpringBoot集成Sharding-JDBC实现主从同步 1.mysql主从配置2.application.properties文件配置3.测试3.1 查询数据3.2 添加数据 1.mysql主从配置 详细内容请参考上一篇文章:MySQL8.0以上实现主从同步配置 2.application.properties文件配置 # ShardingSphere conf…

通过本机端口映射VMware中虚拟机应用(例如同一局域网别人想远程连接你虚拟机中的数据库)

需要 虚拟机中安装一下达梦数据库,并且以后大家都连接你虚拟机中达梦数据库进行开发。。。。。。在不改动自己虚拟机配置,以及本地网卡任何配置的情况下如何解决?本虚拟机网络一直使用的NAT模式。 解决 找到NAT设置添加端口转发即可解决。…

Git for Windows 下载与安装

当前环境:Windows 8.1 x64 1 打开网站 https://git-scm.com/ ,点击 Downloads 。 2 点击 Windows 。 3 选择合适的版本,这里选择了 32-bit Git for Windows Portable。 4 解压下载后的 PortableGit-2.44.0-32-bit.7z.exe ,并将 P…