为谁而生

一个企业,首先要知道的是为谁而生。企业的直接客户是谁,潜在客户是谁,客户的特征是什么,这是否是一块盐碱地,还是一片蓝海?

即使是传统成熟行业,作为一个新入者,如果他还有所追求,为谁而生这个问题一定是淌出来的,而不是想出来的。

不怕路远,路难,方向要对。为谁而生这个问题想对了,路就走对了,企业的价值观也会依附于它。而这个问题想错了,企业之路必然会更加崎岖不平。

X毕业一流大学,光学专业,从事的是照明行业。他的企业之路颇有意思。2年前他想做一件照明领域的工具产品,提供给别人用。却又发现如果做出来了,用户在哪里却不知道。于是转型,借着微信的东风专注于创建照明领域的内容开发,主要就是通过微信公众号,结合志愿者模式做内容传播,前半年主要靠自己,后来逐步有了影响力,开始有大量志愿者通过公众号平台聚集到一起,从事更多翻译和创造性的工作。有了这个基础,事业开始步入正轨。
照明行业,聚集了众多中小企业,从上游芯片厂商到中游设计到下游施工队,整体比较浮躁浅薄,国内产业以抄袭为主。鲜有人静心想为行业做点什么,内容贡献就更不用提。这便是X的机会。
建立行业影响力后,这些中小企业就增加了一个媒体渠道,这时候公司就能够有一些基本的现金流。但是,仅仅是媒体渠道,还不足以让体现一个公司的理想,一个有理想的公司,应该是能够变革行业的。下一步怎么走?玩法很多。

[转] 免费的编程中文书籍索引


免费的编程中文书籍索引

来源:http://www.v2ex.com/t/143671
我在github上fork了一个分支:https://github.com/raywill/free-programming-books-zh_CN

OceanBase0.5中RPC的层次

在OceanBase0.5开源版本中,RPC其实是有一个层次的。自底向上,分别是:
Network Framework — libeasy,负责底层网络框架,packet级别
Client Manager — 负责跟libeasy交互,封装了回调逻辑、异步/同步逻辑
Rpc Stub — 封装了请求的序列化、反序列化逻辑,是应用代码与网络代码的粘合剂

应用代码直接使用Rpc Stub来使用网络最方便,跟调用本地函数区别不大。不需要关心序列化、反序列化过程中的内存问题。但是,应用层如果希望获得一些更为复杂的网络交互逻辑时Rpc Stub则不能提供。比如,希望在A函数post一个请求,然后希望在B函数里wait这个请求的返回值,rpc stub无能为力。

应用代码也可以直接用Client Manager,可以获得很大的灵活性。上一个例子中Rpc Stub搞不定的情况,Client Manager可以搞定。但是直接使用Client Manager会增加一些代码复杂度,例如:需要自己分配DataBuffer,如果追求高性能,还需要自己管理Thread Specific Buffer。

当业务逻辑的对网络需求的复杂度超过Client Manager能力范围时,可以直接用libeasy来解决问题。这是终极方案。在0.5中的SQL模块里用到了该方法,但使用经验证明这种方法可维护性很差,必须对其进行一定的封装。

需要传递哪些参数到远端的自问自答

思考是技术进步的阶梯

A向B机器发送一个plan执行的时候,随着plan本身还需要发送哪些结构?

分析:

OB0.5开源版中发送了SimpleScanParam,但这个参数并不是单独发送的,而是包装在了一个ObHuskTabletScan运算符中,在CS端根据运算符中的参数重新构造子Plan。

答案:

只需要发送plan本身即可。其余要发送的内容都应该封装到operator内部。

进一步发问:

operator内部要封装什么呢?

答案:

比如,读数据超时时间。在运行时用户可以通过命令修改读超时时间,需要将新的时间让plan知晓,以便序列化到B端。
再比如,读数据的版本号。随着时间流逝plan被反复执行,plan需要携带的版本号应该要随时间变化。
这些内容的变化,都应该封装到operator内部。具体做法可以是设置一个IParamProvider()给operator,operator可以随时通过IParamProvider获得最新的数据。IParamProvider的实现比较简单,它持有整个SQL Plan运行时环境的引用,可以随时从中获得最新的参数提供给operator。

这个细节不需要scheduler关心。

结论:

  1. 需要发送plan到B端,而不是自己裸发operator tree到远端。因为plan里面提供了一套遍历op tree(序列化)、分配operator(反序列化)的机制。相当于是一个query的管理器。
  2. 发送到B端的plan并不是一个全功能的plan,有精简的空间。
  3. plan之外并不需要传额外的东西到B端。

Hello!Nepal!

从尼泊尔归来已经快一个月了。我和raywill都没有撰文记录一下,实为可惜,在尼泊尔发生了几件有意思的事儿,记录在此:

1、在加德满都经历了第一次停电,后来才知道尼泊尔并没有自己的电力系统。这个国家的电能由印度供给,基本属于印度一拉闸,这里就完蛋的状态。尼泊尔每个区都会在每个时段定点停电。尼泊尔的每个旅馆都会在贴上旅客须知告知大家:抓紧时间充电哦~

2、尼泊尔所有的路都没有红绿灯和指示牌,那么是否会出现交通堵塞呢?当然了!想什么呢你,当然会堵塞,可是有意思的是,不管路上怎么赌,我都不曾见过一个尼泊尔人生气,骂街,吵架的。大家永远乐呵呵的在灰尘漫天,拥挤不堪的路上奔驰。

3、在加德满都逛猴庙的时候我遭遇了惊醒一幕,被一个猴子狠狠的抓了一把背,导致直到现在背部还留着一道特别醒目的大抓痕。因为这件事,我和老余还体验了一把尼泊尔的医院。被抓的当下老余猴子身上带有病毒,坚持让我去医院给医生看看,我们在好心肠的旅馆前台小哥的带领下,杀到了一个看上去像烂尾楼的建筑门口。我和老余面面相觑:这能是医院?Bingo!这里就是如假包换的医院了,我心里一阵嘀咕,这个烂尾楼一样的地方能给看好么,事实证明,花了不到5块钱人民币买了一针疫苗,在众目睽睽之下,医生充满鄙视的给我打了一阵,她心里一定在想:不就给猴挠了一下么,有什么好来医院的!小题大做!后来我们才知道,尼泊尔的医疗条件很差,医疗系统还处在十分不健全的时代,这个被我瞧不起的烂尾楼已经是加德满都很不错的公立医院了。医院里没有一个人会说英语哦~感谢当地热情的大爷大妈帮我和老余翻译。

4、在博卡拉登山经历了毕生最狼狈的时刻,在大暴雨中浑身湿透手脚并用的爬山,我都很奇怪我们居然都没有滑下悬崖摔死。一众人都冷得浑身哆嗦,老余买了一瓶威士忌,每个人都猛灌了几大口,活过来了。

5、头一次尝试在海拔3000米洗冷水澡,绝对的清新亮,透心凉。最后都不知道在干嘛了,听着自己上下牙齿的磕巴声,面色发白的冲出洗澡间,居然也就没有感冒,不知道是不是那针猴疫苗的功能呢?

6、在博卡拉的lakeside遭遇了一大群中国人,导致我一直有错觉我是不是在颐和园泛舟。

自我节奏的调整

最近在做OceanBase RootServer重构后的测试,主要测试工具是用我们牛逼QA开发出的obtest神器。

测试结果总是不太稳定,各种细节错误且不完全复现,很耗人。导致积极性下降。

调整策略:测试期间给自己安排一些优化/重构的活儿,穿插着做事情。

自主做事最精彩

写了两年半的OceanBase,知识体系却依然没有完善,思考原因:缺乏实践。OceanBase中大家都是螺丝钉,各自负责一亩三分地,别人地里种了什么虽然能看个大致,比如施的什么肥,打的什么桩,搭的什么架子,种的哪种秧,但若问为何是这种肥,怎么非得打个桩,架子斜着搭,却又种南瓜秧,则是问着我了。知其然,不知其所以然,是学习OceanBase的最大的难题。

企图从分析源码的角度来体会作者意图的方式失败了。总是不得要领,收益甚浅。

还是祭出老办法:好记性不如烂笔头。动手写码,写一个简单一些的NoSQL系统出来。俗话说,麻雀虽小五脏俱全,只要这个系统能完整做下来,一定会受益甚丰。

于是,MacrayKV诞生。取这个名字是因为这个项目带上了Macduan学弟一起做,我的id是Raywill,俩名字一凑,macray,读起来还蛮上口的。KV则表示key-value存储的意思。就这样了。

没多少天就发现,自主做事最精彩!创新的激情在自主做事的情况下能得到最大激发。比如今天:

基于tcmalloc写了一个线程安全的全局内存分配器,写完之后必须测试一下。为了测试线程安全的特性,必须使用多线程编程。淘宝多隆写的tbsys系统库提供了比较好的多线程封装,用起来已经比较方便了,但在测试代码中多处用多线程时则会发现有大量的冗余代码。每一个需要并发的代码片段都需要创建一个类和一个回调方法,把并发的代码填在回调方法里面。这么做有两个坏处:(1)打乱了测试代码的连贯性。 (2)代码冗余不易维护。(3)还得记忆多线程封装库的用法,我记性太差,每次都要查。

今天早上突发奇想,能不能有一种类似intel #progrm parallel这样的directive呢?这种想法很大程度上是受了前不久coolshell上《数据即代码:元驱动编程》这篇文章的影响。摸索了三十分钟,一个C++的宏方案出台,相当好用:

TEST_F(ObTCFactoryTest, mt_basic_test)
{
  // 第一次并发测试
  BEGIN_THREAD_CODE(my_run, 50)
  {
    for (int i = 0; i < 1000000; ++i)
    {
      Base *b1 = base_tc_factory_t::get_instance()->get(0);
      ASSERT_TRUE(NULL != b1);
    }
    base_tc_factory_t::get_instance()->stat();
  } END_THREAD_CODE(my_run);


  // 一些同步测试代码
  // put your code here


  // 第二次并发测试
  BEGIN_THREAD_CODE(my_run2, 50)
  {
    for (int i = 0; i < 1000000; ++i)
    {
      Base *b1 = base_tc_factory_t::get_instance()->get(0);
      ASSERT_TRUE(NULL != b1);
    }
    base_tc_factory_t::get_instance()->stat();
  } END_THREAD_CODE(my_run2);

}

其实现也是极简的:

#define BEGIN_THREAD_CODE(class_name, thread_count) \
  class _##class_name : public tbsys::CDefaultRunnable \
  { \
    public: \
    _##class_name() { _threadCount = thread_count; } \
  void run(tbsys::CThread *thread, void *arg) { \
    UNUSED(thread); UNUSED(arg); \

#define END_THREAD_CODE(class_name) \
  }};\
  _##class_name my_##class_name; \
  my_##class_name.start();  my_##class_name.wait();

 

more code details here

然后,我就把这个方案移植到了OceanBase,得到了@郁白 的大力赞扬。OceanBase UpdateServer模块的单元测试对于并发测试的需求非常旺盛,希望以后能在代码中处处看到它的使用。

希望自己坚持下去,马上做,做精彩。

我的第一次线上授课感受

在TMT沙龙邮件组上无意看到一个叫做“多贝”的网络课堂,为所有人提供了一个在线的学习交流环境。一直和Jasimin说要试水一下在线教育,何不参与一把呢?正好YangJie同学希望学习OceanBase的编码规范,不如我就在这里开一次在线课程吧。跟YangJie说了一下,他十分乐意,那就干吧!

开课时间最初定在8点,因为下班迟了,改成了8:20。

8:20开课,YangJie同学还给我另喊了一个学员过来。一堂只有2个学生的课开始了。

说一下对这个平台的感受。

缺点:

1. 讲起来很不习惯,因为没有交互,我只对着一个白板说呀说呀。感觉像是给空气讲课。

2. 平台对pdf的支持很不好,字太小了。

3. 旁边的聊天窗口太简单了,对于编程授课,希望加入一个实时代码同步编辑窗口(还记得google wave吗?),有利于同步演示。

优点:

1. 课件展示的同步功能很赞

2. 画笔功能很赞

 

 

 

个人/产品可以改进的点:

1. 习惯对着白板讲课

2. 素材要准备好

3. 当一次听众,感受一下

4. 讲课的过程也是录制的过程,就好了

单双号

2013年10月18日起的3天,北京实行更为严格的机动车限号规则:单双号。雾霾已经来临,就在外面。200米对面的央视大楼轮廓若隐若现,如梦如幻。

9.16日到10.7日都是在家度过的,嗓子不适问题基本消失。如今,雾霾笼罩了北京,我的嗓子又逐渐开始不适起来。这是体质问题,也是体制问题。格局一旦形成,它带来的后果是必然的。所以,对于我们年轻人来说,“布局”才是最重要的。它耗费不了多少时间,却能影响一生。然而,如何布局?眼见利益、长远利益平衡博弈而已。

号外:团队进入备战状态已经1月有余,每年一次的双十一大考,何时从容应对?大约是因为有需求才有动力吧。平日里做功能,临考前做性能,跟高中时候的考试有几分相似呢。不过,高中时候的优等生临考前却总是最轻松的。