公司现状
1. 技术人员水平限制: 基础研发人员技术细节,性能处理能力不足,技术视野不够开阔;甚至一些高可用,高性能方案的概念都未听闻,更别提发展方向和思路了,令人痛心。
2. 技术反馈渠道限制: 公司业务线暂不多,基础服务的应用面尚属狭窄;基础服务和镜像各种环境的适应性和性能不足以及时凸显暴露出来,框架bug和问题使用反馈周期太长,不足以快速跟进和改善基础框架。
3. 人员招聘渠道限制: 高技术人才未中长期储备, 各招聘渠道未能招募到合适的技术人员。临时招聘也不能在中短期内补充恰好求职的合适人员。(.net 行业大环境下人员本身也很紧缺)
4. 人员成本预算限制: 因公司业务的发展与现实情况,基础研发人员数量有限,人员成本预算有限;(即便遇到非常合适者,薪资情况仍需各方努力达成。)
5. 基础开发人员培养: 基础研发不同于业务线研发, 难以通过业务发展提升自身满意度,技术成就感,对性能和技术的追求。需要通过内在和外在的压力,才能推动研发人员不断讨论,不断汲取学习,思考和沉淀技术,微创新,将基础服务真正用心做好。

解决方向
在考虑公司各方面的资源限制和现状,以及人员的限制和培养,基础服务的性能要求和稳定性等综合的考虑,采用开源战略方向,形成开源->反馈->交流->改进的生态圈有利于缓解以上公司的现状问题。
若能形成开源生态圈,则可以促进开源项目稳定性,优化开源代码,根据反馈不断的提升自身的基础服务产品,吸引相关的高级技术人才维护检验项目,减少项目的开发维护成本,同时提升公司在技术领域的影响力,提升开发人员的成就感。(目前淘宝,当当网,蘑菇街,大众点评,携程,小米,58同城等都有部分项目开源)


目标原则
融入开源社区,借助开源的生态能力,在有限资源条件下更有效率验证基础服务的性能,稳定性,推动其发展。

组织形式
公司开源技术委员会(虚拟)


开源生态孵化规划
1. 开源计划
基础服务开源计划: @车江毅【开发细节收集,改进】 @孙明【开发细节收集,改进】 @徐龙【安装咨询】 @陈虎伯【安装咨询】
1)分布式任务调度平台 (已开源,开源版本未更新最新) @车江毅 @徐龙  @陈虎伯
2)分布式消息队列平台 (已开源,开源版本未更新最新) @车江毅 @徐龙  @陈虎伯
3)OpenApi开放平台 (已开源,开源版本未更新最新) @车江毅 @徐龙  @陈虎伯
4)BSF.EntityFramework  (待整理开源) @孙明 @徐龙  @陈虎伯
5)分布式配置中心 (已开源,开源版本未更新最新) @车江毅 @徐龙  @陈虎伯
6)分布式消息推送平台(待整理开源) @孙明 @徐龙  @陈虎伯
7)分布式缓存中间件 (已开源,开源版本未更新最新) @车江毅 @徐龙  @陈虎伯
8)分布式Tcp服务中心(待研发)@孙明 @徐龙  @陈虎伯
9)分布式文件系统 (功能暂不足以推进开源)
10)分布式监控中心 (已开源,开源版本未更新最新)@车江毅 @徐龙  @陈虎伯

执行步骤
1)上传代码(新版本须建立新分支),整理文档(需求+demo+压测报告等),相关安装包(+安装文档等),readme简介。
      至git: http://git.oschina.net/chejiangyi (后期以公司形式开源,前期避免行业商业竞争)
2)撰写博文介绍项目的功能,demo和使用等,发布到公司知识库,发布到开源群,发布到开源社区。

开源QQ群
.net 开源基础服务 238543768

开源基金
设立一定的开源基金和开源任务发布计划等。(未来较长期的发展方向,部分核心技术外包形式【部分高级核心技术人员无法招募,就通过外包技术合作等形式】)

2. 开放计划
基础服务镜像开放计划: @陈虎伯 【安装咨询,使用问题收集,改进】 @徐龙【安装咨询,使用问题收集,改进】
1)基础服务镜像1.0版(内部测试版本->开放测试版本->正式稳定版)
2)基础服务镜像2.0版(内部测试版本->开放测试版本->正式稳定版) 

执行步骤
1)发布基础服务镜像内部测试版本,通过一定的业务功能验证其稳定性。(验证周期约一个月)
2)发布基础服务镜像开放测试版本,通过收集开源的反馈问题,验证其稳定性。(验证周期约三个月)
3)发布基础服务镜像正式稳定版本,仅对内提供,一般不对外公开。(产品发布的镜像版本须为稳定版镜像,并记录版本更新信息)

总体原则
1)稳定版镜像不对外公开,对外开放仅为最新开放测试的基础服务版本和跟进反馈。
      基础服务镜像暂不对外允许商业使用权利,仅用于学习测试使用。(避免同行业商业竞争)

3. 反馈计划
交流QQ群: net 开源基础服务 238543768
交流社区: oschina,博客园,csdn,51cto等
源码开源: git.oschina.net,github等

通过线上qq群,社区,源码分享等多种渠道(还有线下的交流渠道),分享基础服务设计的成果和思路,汇聚志同道合或者同样需求的人才,一起探讨总体方向,细节,性能优化,同类产品建议等。
(根据经验: 一般至少80%的交流都是一些基础和废话,约20%的交流是值得思考的,10%的交流是值得改进和有价值的; 10%当中结合公司实际业务和具体问题,5%的建议可以形成一轮小版本迭代需求)

4. 线下计划
方向: 打通线上和线下交流,汇聚行业精英人才,打开技术交流渠道
形式: 以QQ群和微信群为交流汇聚点,通过策划线下圆桌会议,1对多小型技术分享会议,技术专家邀请分享,技术沙龙交流等交流会议
间隔: 一季度一次,不限人数,不限大小
人员: 公司内部人员推荐的(其他公司)人才,QQ技术交流群的高级人才,业内知名技术人才等
资金: 公司预算支持
场地: 咖啡馆,小会议室等安静休闲场所
效果: 拓宽技术眼界,了解行业技术动向,反馈一些价值的技术建议, 吸纳技术精英。

5. 人才计划
方向: 以基础服务开源为核心,宣传并推广开源技术为手段,高级技术人才人脉互相传递(人才)特性,打通线上反馈交流和线下会议分享,吸引并聚拢相关类型的技术人才(同时提高公司的技术影响力),形成一定规模的开源技术圈子。
目标: 以开源吸引形成技术互补,互动,培养,并到合适时机招聘入职;且适用于用于长期技术人才储备。
形式: 反馈计划,线下计划,人才储备关注(高级人才招聘时推荐公司开源社区并加入),公司内部员工推荐(曾经认为不错的技术同事),开源社区人才推荐(人脉传递)。
资金: 开源基金支持(未来考虑开源基金计划,如部分高级核心技术人员无法招募,就通过外包技术合作,发布开源任务模式等形式)

6. 培养计划
方向:为公司技术开发人员打开技术交流另一扇窗口,有交流才会有进步。(除了公司内部培训,交流外)
目标:以外部技术人才与内部开发在开源社区的互动交流,了解实时的行业技术动态(行业技术新闻和咨询,相关技术框架和更新等),打开开发人员的技术视野和思考,提升技术能力。
形式:在线社区(QQ,git技术反馈,开源社区)等沟通交流。
举例:一些技术难点,一些技术疑难问题,一些压测的性能指标等都可以在开源社区提出并咨询讨论。

开源规划总结
开源社区和生态的发展,如同公司业务的发展一样,是逐步形成的;虽然以目前公司的各方面现状,想法真正各方面切实落地为时尚早;
但是做为技术长期规划和发展展望,我们仍然需要时刻提醒自己的目标和方向,并严格要求自己代码和文档等各方面的质量要求,并不断完善且逐步推进。


(为了解并清晰未来公司开源技术的目标和方向,本规划文档需保留以作备忘。文档分不同时段完成,未校验文字,不足之处须见谅)

.net 基础服务开源战略规划备忘录的更多相关文章

  1. .Net 大型分布式基础服务架构横向演变概述

    一. 业务背景 构建具备高可用,高扩展性,高性能,能承载高并发,大流量的分布式电子商务平台,支持用户,订单,采购,物流,配送,财务等多个项目的协作,便于后续运营报表,分析,便于运维及监控. 二. 基础 ...

  2. .Net 大型分布式基础服务架构横向演变概述(转)

    一. 业务背景 构建具备高可用,高扩展性,高性能,能承载高并发,大流量的分布式电子商务平台,支持用户,订单,采购,物流,配送,财务等多个项目的协作,便于后续运营报表,分析,便于运维及监控. 二. 基础 ...

  3. 【转载】.Net 大型分布式基础服务架构横向演变概述

    原文:https://www.cnblogs.com/chejiangyi/p/5220217.html 一. 业务背景 构建具备高可用,高扩展性,高性能,能承载高并发,大流量的分布式电子商务平台,支 ...

  4. 开源项目 AllJoyn 基础服务

    AllJoyn 基础服务主要包含 Onboarding,Notification 和 Control Panel三个大项. 这三个也是编写App的最基础的,最经常使用的部分. Onboarding 提 ...

  5. .Net 分布式云平台基础服务建设说明概要

    1)  背景 建设云平台的基础框架,用于支持各类云服务的业务的构建及发展. 2)  基础服务 根据目前对业务的理解和发展方向,总结抽象出以下几个基础服务,如图所示 3)  概要说明 基础服务的发展会根 ...

  6. Asp.net 面向接口可扩展框架之使用“类型转化基础服务”测试四种Mapper(AutoMapper、EmitMapper、NLiteMapper及TinyMapper)

    Asp.net 面向接口可扩展框架的“类型转化基础服务”是我认为除了“核心容器”之外最为重要的组成部分 但是前面博文一出,争议很多,为此我再写一篇类型转化基础服务和各种Mapper结合的例子,顺便对各 ...

  7. Asp.net 面向接口可扩展框架之类型转化基础服务

    新框架正在逐步完善,可喜可贺的是基础服务部分初具模样了,给大家分享一下 由于基础服务涉及面太广,也没开发完,这篇只介绍其中的类型转化部分,命名为类型转化基础服务,其实就是基础服务模块的类型转化子模块 ...

  8. 阿里云内网和公网NTP服务器和其他互联网基础服务时间同步服务器

    阿里云为云服务器ECS提供了内网NTP服务器,对于阿里云以外的设备,阿里云同时提供了 公网NTP服务器,供互联网上的设备使用. 内网和公网NTP服务器 以下为阿里云提供的内网和公网NTP服务器列表. ...

  9. 朱晔的互联网架构实践心得S2E7:漫谈平台架构的工作(基础架构、基础服务、基础平台、基础中间件等等)

    前言 程序开发毕竟还不是搬砖这种无脑体力劳动,需要事先有标准,有架构,有设计,绝对不是新公司今天创立,明天就可以开始编码的.其实很多公司在起步的时候没有财力和资源建设独立的基础架构或平台架构部门,甚至 ...

随机推荐

  1. redis sentinel 集群监控 配置

    环境: ip  172.16.1.31 26379  redis sentinel ip  172.16.1.30 6379   主 1 ip  172.16.1.31 6380   从 1 ip   ...

  2. Javascript隔离方法

    1.常用的隔离方法: (function() { })(); 2.query的隔离方法: 需要引入jquery: <script type="text/javascript" ...

  3. Linux 分区和目录

    [1. 分区与目录概念理解]  Linux的分区是物理上的概念,就像我们把一块硬盘分成C:,D:,E:三个区一样,物理上将存储空间分开 Linux的目录是逻辑上的概念,Linux的目录树实际上是一个分 ...

  4. MySQL的mysql_insert_id和LAST_INSERT_ID

    摘要:mysql_insert_id和LAST_INSERT_ID二者作用一样,均是返回最后插入值的ID 值 1 mysql_insert_id 一.PHP获取MYSQL新插入数据的ID  mysql ...

  5. Android面试题随笔1

    1.如何让一个应用在手机上产生两个或多个图标? 在清单文件中的activity节点下配置如下:[5,7行代码] <activity android:name=".MainActivit ...

  6. mysql 隔离级别与锁

    1.什么是事务 事务是一条或多条数据库操作语句的组合,具备ACID,4个特点. 原子性:要不全部成功,要不全部撤销 隔离性:事务之间相互独立,互不干扰 一致性:数据库正确地改变状态后,数据库的一致性约 ...

  7. iOS强制切换横屏、竖屏

    切换横竖屏最直接的方式是调用device的setOrientation方法.但是从sdk3.0以后,这个方法转为似有API,如果要上AppStore的话,要慎用! if ([[UIDevice cur ...

  8. Android Studio文件目录介绍

    一.安装的时候并不理解很多东西的用处,只是根据教程来做,所以想整理一下思路: android sdk里的各目录作用: 1.AVD Manager.exe:虚拟机管理工具,用于建立和管理虚拟机. 2.S ...

  9. DOMContentLoaded

    setTimeout(function(){ alert("settimeout"); },0); EventUtil.addHandler(window, "DOMCo ...

  10. Core Data需求

    大家都在讨论怎么使用Core Data,但是什么时候用到Core Data,这好像是大家很少讨论的问题 我们使用Core Data ,主要用来存储两种类型的数据:固定的数据,和 可能变化的数据. 1. ...