坚信科学,分享技术

2018全新版本,未来在blog.54chen.com更新博客!

>>>尝试更加利于阅读的2014版科学院,以后都在新版上写。

Yearly Archives: 2012

丰宁坝上草原自驾游

秋高气爽,正直周末,我米东方时尚小分队一行十一人三辆车,浩浩荡荡二次出行。 目标: 一出门在八高小堵: 出了北京,一路都是这样的感觉: 当时有两个小时的土路它是这个样子的: 七小时后到达目的地,马不停蹄,开骑: 当地的养马的农民在山顶上休闲地抽烟: 马到成功: 农民家看马的大黄,一只耳朵总是耷拉着: 第二天,自行活动时摄影师拍摄: 随便都是桌面一张: 期待下次出行!

Continue reading

Posted in 生活备份 | Tagged | Leave a comment

54chen Twitter memo 2012-09-16

cloud foundry之warden代码解读-part1 http://t.co/AooK63AE # 在yahoo呆过的朋友一定了解yroot,在cgroup这么不平易近人的情况下,很多人直接去了虚拟机,说明开源项目的用户体验也是多么的关键啊。 # 54chen Twitter memo 2012-09-09 http://t.co/Dae6V5DX #

Continue reading

Posted in 生活备份 | Tagged | Leave a comment

cloud foundry之warden代码解读-part1

简介 cloudfoundry是vmvare推出来的开源PaaS平台,warden是其核心部分的资源管理容器,完成了各种资源分配的事情。 代码位置在: https://github.com/cloudfoundry/warden 这一部分也是我最想了解细节的地方,因为在一个paas平台中,资源的隔离才是最有价值的部分。 基础知识 rv = unshare(CLONE_NEWNS); unshare这个调用,可以把挂载的文件系统设置成只在新的挂载命名空间(mount namespace)中可见。 execvp(argv[0], argv); execvp()会从PATH 环境变量所指的目录中查找符合参数file 的文件名,找到后便执行该文件,然后将第二个参数argv传给该欲执行的文件。 shopt -s nullglob 设置shell环境变量nullglob的值为on,nullglob为on时对于通配符匹配时,若匹配不到时为空(相对应的为通配符本身)。 int stat(const char *restrict pathname, struct stat *restrict buf); 提供文件名字,获取文件对应属性。 build-essential软件包 作用是提供编译程序必须软件包的列表信息,也就是说编译程序有了这个软件包,它才知道 头文件在哪,才知道库函数在哪,还会下载依赖的软件包,最后才组成一个开发环境。 工具debootstrap 可以用于在系统的某个目录中安装一套基本系统,这个基本系统除了一些配置项外,与ubuntu安装程序在安装的第一阶段安装的内容基本相同。

Continue reading

Posted in 架构研究 | Tagged , | Leave a comment

54chen Twitter memo 2012-09-09

cloud foundry之dea代码解读 http://t.co/wr5cdwWA # 在深入cf之后,感觉cloud foundry的不好的几点:1.模块间内网通讯基本全用http; 2.NATS严重的单点依赖; 3.低效的nginx router机制不能承载大应用。 # cloud foundry之router代码解读 http://t.co/ICavjNUs # 今天继续阅读cf代码,ruby的代码虽然简单,可惜不是虚拟机形式的,效率差了点。 #

Continue reading

Posted in 生活备份 | Tagged | Leave a comment

cloud foundry之dea代码解读

简介 cloudfoundry是vmvare推出来的开源PaaS平台,dea(DropletExecution Agent)是其应用运行的环境,一个DEA可以启动多个应用。 代码位置在: https://github.com/cloudfoundry/dea 这一部分也是我最想了解细节的地方,因为在一个paas平台中,资源的隔离才是最有价值的部分。 历史 初始版的dea基本不控制系统资源,然后基于cgroup搞了一个warden(真正的资源隔离是它,下节再述),程序运行容器。cf希望warden运行在多个平台上,所以没有直接使用LXC。 代码 代码入口在lib/dea.rb: EM.epoll EM.run { agent = DEA::Agent.new(config) agent.run() } EM是ruby有名的eventmachine,是一个事件驱动网络框架,从java程序员的角度,可以理解有点像mina,也可以认为有点像erlang的gen_server。 然后进到lib/dea/agent.rb: NATS.start(:uri => @nats_uri) do ... 里面注册了各种各样的收到对应消息干什么活的定义,我们来看其中几条线: 1. 收到update: NATS.subscribe('dea.update') { |msg| process_dea_update(msg) } 上一句是说收到update的指令, process_dea_update里面关键的一句: register_instance_with_router

Continue reading

Posted in 架构研究 | Tagged | Leave a comment

cloud foundry之router代码解读

简介 cloudfoundry是vmvare推出来的开源PaaS平台,router是其所有请求的入口路由,其与nginx进行配合完成各种情况情况下的转发。 代码位置在:https://github.com/cloudfoundry/router 历史 第一版的router直接通过unix sock将http request通过nginx的proxy 发到了router.rb中处理,第二版的时候,因为ruby直接处理请求性能不行,换成了lua脚本来接收请求,再由ruby程序将结果返回。 目录结构 router代码不多,共有下面的一些主要目录。 . ├── bin │ └── router (启用router server的脚本) ├── config │ ├── router2.yml │ └── router.yml (配置文件,指定了服务的端口和消息队列pid等) ├── ext │ └── nginx │ ├── tablesave.lua │ └── uls.lua (这两个lua脚本供nginx conf使用,实现用户第一次访问时生成一个cookies,lua让其去同一个地方) …

Continue reading

Posted in 架构研究 | Tagged | Leave a comment

54chen Twitter memo 2012-09-02

在小米写服务端java代码,你只需要知道java语法,其他maven呀、nginx配置呀、高可用呀、负载均衡呀,统统都可以忽略,天然就是支持的,嗯,我说的是下一年的事情。 # cloud foundry之cloud_controller代码解读 http://t.co/5um7YuL8 # 随着gfw越来越凶残,后来的再搞技术的朋友啊,你们将会连eclipse插件都下不全,所以说,趁早改行吧。 # @hongqn 两个显示双屏也是一种重构思路。 # 谁知道为什么cloud foundry采用了大量的ruby,而不是其他什么语言? # cloud foundry之vmc代码解读 http://t.co/fm1U34u0 # clound foundry之vmc代码解读 http://t.co/9fx5HaQS # ruby快速学习手记(ubuntu) http://t.co/Aas2KH3J # ruby得用一天时间学一下,看看有没有实际用处。 # 54chen Twitter memo 2012-08-26 http://t.co/J16AmMdc #

Continue reading

Posted in 生活备份 | Tagged | Leave a comment

cloud foundry之cloud_controller代码解读

简介 cloudfoundry是vmvare推出来的开源PaaS平台,cloud_controller是其管理界面的http rest api入口。 补课 rails Rails基于MVC(模型- 视图- 控制器)设计模式。从视图中的Ajax应用,到控制器中的访问请求和反馈,到封装数据库的模型,Rails 为你提供一个纯Ruby的开发环境。 习惯约定大于配置: model类位置app/models/xxx.rb controller位置app/controllers/xxx_controller.rc help位置app/helpers/xxx_helpers.rb view位置app/views/xxx 对应布局app/views/layouts/xxx.rhtml xxx.rxml 开始cloud_controller https://github.com/cloudfoundry/cloud_controller 里面有两个项目,一个是cloud controller另一个是health_manager,今天要研究的是前者,下节说后者。 入口 bin/cloud_controller -> config/boot.rb cloud_controller必需要求ruby1.9以上,因为其中有一个fiber需要ruby支持(传说中的Coroutine)。 如果没有配置 cloud_controller使用nginx,则会启用Thin去启动Rack。(Thin是ruby内置的network server,Rack: a Ruby Webserver Interface) a

Continue reading

Posted in 架构研究 | Tagged , | Leave a comment

cloud foundry之vmc代码解读

简介 cloudfoundry是vmvare推出来的开源PaaS平台,vmc全称是The VMware Cloud CLI,是vmware的应用平台命令行接口。 ubuntu安装vmc sudo gem install vmc 常见的用法 vmc target api.paas.n.xiaomi.net vmc add-user vmc login vmc push vmc其实是使用ruby来实现的一整套的cli命令转化为http restful请求的对应工具。 其代码位于:https://github.com/cloudfoundry/vmc git clone回来代码之后,下面对代码进行半瓶水解析法解析。 入口 bin/vmc 引用了 $github/vmc/lib/cli 直接运行VMC::Cli::Runner.run 位于:lib/cli/runner.rb 看上去run会被执行。 进入到parse_command!方法中 以push为例: when 'push' usage('vmc push [appname] [--path …

Continue reading

Posted in 架构研究 | Tagged , | Leave a comment

ruby快速学习手记(ubuntu)

ruby 1993年诞生于日本。rails是用ruby写的web framework,所谓的ROR正是这一搭档。 ruby安装 ubuntu 10.04很简单,安装ruby和rails: sudo apt-get install ruby sudo apt-get install rails 小试牛刀 rails first_rails cd first_rails/ ruby script/server 浏览器打开127.0.0.1:3000 it's works! IDE:eclipse 语法特点 解释型 适合文本处理,类似perl 完全面向对象 无分号 方法定义关键字:def+end 木有大括号({}) 无需指定类型 局部变量用小写字母或下划线开头即可 全局变量用美元符作为前缀 $;而实例变量用 @ 开头;类变量用 @@ 开头;类名、模块名和常量应该用大写字母开头 …

Continue reading

Posted in WEB相关 | Tagged , | 1 Comment
Page 2 of 812345...Last »