2014年

在这一年里,入职支付宝,成长许多,也遇到了一些问题,对于复杂问题的理解力稍微变强了一点.技术上也有了一定的长进.但不够让我自己满意.博客也更新缓慢,很多总结性的东西只是记录在了evernote中,不够完整.

和文哥也经历了很多事情.有一些问题,也多数都解决了,这一年项目紧急,加班较多,希望能够圆满的结束这个项目,未来总是充满了很多的变数.珍惜眼前人,眼前事,工作生活都是如此.

感谢文哥,家人,师傅,同事和阿里.谢谢大家在2014年的照顾和合作.总而言之,和大家在一起很开心.

2015年

新的一年里,希望在技术上有更多的长进.实实在在可以看的见的作品或产出.坚持写博客,能够打上个人更多的标签,而不仅仅是在支付宝或者阿里工作.

和文哥的相处上可以更加理解和体谅,希望文哥在自己喜欢的领域做出自己的事业.有梦想就要去行动.有目标才会实现.

2015年不会比2014年更加好过或者是难过,相信明年的这个时候.还能笑谈今日的一切.

最近博客越来越慢了.然后一直也有markdown写文章的想法.于是花了点时间把博客迁到了hexo+github+gitcafe的组合上.

安装Git

下载 msysgit 并执行即可完成安装。

安装Node.js

在 Windows 环境下安装 Node.js 非常简单,仅须下载安装文件并执行即可完成安装。

安装hexo

利用 npm 命令即可安装。(在任意位置点击鼠标右键,选择Git bash)

npm install -g hexo

安装完成后,找个目录,比如d:/blog下面.右键,git bash,然后执行
hexo init
这样就会自动生成所有的目录结构了然后在安装一下依赖包:
npm install
然后执行
hexo generate 用来根据md文件生成对应的html文件.执行
hexo server 则启动本地服务器.打开
127.0.0.1:4000端口查看

本地查看没啥问题.就需要部署到git上了.先配置一下.
在d:/blog下面的_config.xml中配置远程git的服务器.现在已经支持同时部署到github和gitcafe.在末尾添加

1
2
3
4
5
deploy:
type: git
repo:
github: git@github.com:yourname/yourname.github.io.git,master
gitcafe: git@gitcafe.com:yourname/yourname.git,gitcafe-pages

其中的yourname就是你的名字

然后执行
hexo deploy
即可.让输入啥就输入啥.
下面是命令的简写
hexo g == hexo generate
hexo d == hexo deploy
hexo s == hexo server
hexo n == hexo new

网站主题配置

同样的,在d:/blog下面执行
git clone https://github.com/wuchong/jacman.git themes/jacman
即可复制主题.
然后修改_config.xml文件.在里面找到theme 设置为
theme: jacman
注意冒号后面有空格

wordpress迁移

  1. 导出文章
    登录wordpress管理控制台,选择工具->导出,再选择文章。点击下载导出的文件,就可以得到一个名称类似wordpress.2015-01-12.xml的文件。
  2. 安装迁移插件
    npm install hexo-migrator-wordpress --save执行安装
  3. 导入文章
    hexo migrate wordpress source 这里source就是刚才那个文件的地址,绝对路径或者相对路径都行.导出的中文可能有编码.手动改一下,或者写个脚本简单转换一下.
  4. 导入图片
    经过上面的步骤,会发现图片还是原来的连接.这里看这个导入图片插件使用

其他问题

github连接出现Bad file number问题
使用GitHub来管理博客源文件
Hexo免输入密码部署到github
教程:github设置多账号

工作中有时候会切换jdk版本.有时候需要用个64位的.有时候需要用32位的.频繁手动很不方便,参考了一下,写了一个bat脚本,保存为bat,运行即可切换.同理可以改改,运来切换1.7,1.8这样的版本.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
@echo off
:init
set JAVA_HOME_32=D:\5.Program\Jdk32Home
set JAVA_HOME_64=D:\Software\JdkHome
:start
echo.
echo =============================================
echo jdk版本列表
echo 32 (%JAVA_HOME_32%)
echo 64 (%JAVA_HOME_64%)
echo =============================================
:select
set /p opt=请选择jdk版本:
if %opt%==32 (
start /I /WAIT /B wmic ENVIRONMENT where name='JAVA_HOME' set VariableValue="%JAVA_HOME_32%" >nul
rem reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v JAVA_HOME /t reg_sz /d "%JAVA_HOME_32%" /f
goto success
)
if %opt%==64 (
start /I /WAIT /B wmic ENVIRONMENT where name='JAVA_HOME' set VariableValue="%JAVA_HOME_64%" >nul
rem reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v JAVA_HOME /t reg_sz /d "%JAVA_HOME_64%" /f
goto success
)
echo 选择的版本错误,请重新选择!
PAUSE
goto start
:success
echo.
echo 设置环境变了成功.

jenkins相关资料

jenkins的前身是hudson,是为了做持续集成测试而诞生的框架.

简单说就是把代码流配置上去,然后该框架就能根据设定的时间或其他方式不间断的执行测试用例.并给出报告.这样就可以随时掌控代码质量.支持执行shell命令.支持短信通知等等.

jenkins,首先从http://jenkins-ci.org/官方下载war包,然后有两种方式可以本地部署,一种直接执行
java -jar hudson.war,然后在本地的8080端口访问就可以了.另一种是我们希望部署在容器上,那么可以部署到tomcat,jetty等等.直接拷贝war包到对应的目录即可.

部署成功后,可以新建job,然后配置svn流,配置build时间,配置一下build之前的动作,配置一下各种命令,执行完成后通知等等就可以了.

最近因为有个功能感觉通过开发jenkins插件的方式会更加方便,周末大量读了一些文档,能找到的都是helloworl.摸索了一下,已经写出一个小的demo了,后面改进一下,.就ok了.先简单把这个过程中收集的资料整理一下.基本都看过觉得还不错的,官方文档不给力.下周希望可以写完,然后分享出来.

  1. jenkins入门文档
  2. The hudson book
  3. Writing-first-hudson-plugin
  4. Hudson插件开发简介
  5. Hudson插件开发入门体验
  6. 插件界面设计设计的各种tag介绍
  7. 官方插件开发
  8. UI开发jelly介绍
  9. jenkins入门(itech)

一直听说蓝绿发布,不知道是怎么个过程.

thanks to blue-green-deployment

蓝绿发布的意义

整个发布过程,用户没有感受到任何宕机或者服务重启。

蓝绿发布的过程

第0步:部署以前的配置
Blue Green Deployment for Zero Downtime (8)

第1步: 把绿色集群的状态改为’备用’. 从负载均衡的池里把这些地址去掉,这样,绿色的集群就不再回接收到来自用户的请求了.转而进入备用负载均衡的池里.
Blue Green Deployment for Zero Downtime (9)

第2步:在绿色集群里部署新的代码,直到应用启动成功
Blue Green Deployment for Zero Downtime (3)

第3步:使用备用负载均衡简单测试一下备用集群的部署情况.理想状态下是全自动的.

第4步:把绿色备用集群的状态改成存货,于是进入了存活负载均衡的池里
Blue Green Deployment for Zero Downtime (4)

看到 蓝色运行v1版本,绿色运行v2版本,都连接的是相同的数据库.这意味着v2版本也要在老的数据模型上运行.如果数据库有变更,要等到所有的集群升级到新的代码上.

第5步: 对蓝色集群也进行同样的操作.
Blue Green Deployment for Zero Downtime (5)
Blue Green Deployment for Zero Downtime (6)
最终v2代码完成部署.
Blue Green Deployment for Zero Downtime (7)

第6步:根据情况.运行数据库迁移


 

 

鲁肃说建议去看Spring框架的代码,之前其实我想看来着,不过一看到还要gradlew,换jdk就好麻烦.这次各种折腾把代码fork下来,然后安装gradlew,然后转换成eclipse支持的,期间升级了eclipse版本和jdk版本到8.否则会有个方法不支持,

流程很简单,先fork一下代码,然后自己改好提交上去,再去Spring框架的pull request请求一下.等大牛合并就行了.

刚开始看测试用例,我当时看到这个方法调用了一个下线的方法.于是改了一下.提交上去之后,sbrannen 回复说:

while you’re at it, why don’t you go ahead fix the related deprecated issues in all of the test classes in spring-jdbc
于是我把spring-jbdc包下面的几个方法调用都改掉了.记得谁说过,任何事情都不是别人的事情,你发现了你就要去做,不要等着别人去做,不会就去学.于是再次修改提交,sbrannen 问我有没有签CLA,这个坑爹的网站挂了.等了几天,昨天终于ok了.今天代码已经合并.

截图留念:

spring

https://github.com/spring-projects/spring-framework/commits?author=leizhiyuan

今天要吃两个煎饼果子.

最近突然觉得需要学习一个轻便的语言,每次写个小工具啥的还要打开eclipse,很是不方便。于是学习了一下python,看看官方文档基本就可以上手了,剩下的就是多用了,个人用python写了个调用websevice的东西,suds这个库3.x已经不维护了,坑爹,需要使用http://pypi.python.org/pypi/suds-jurko 这个库代替,主要是为了批量测试mock的连通性的,

另外是python3.x和python2.x差异是在很大,我选了3…, 刚学习的人还是建议从2.x开始吧,否则很多源代码你下载回来基本运行不了。

本文是我在学习过程中看到的不错的文档,希望有所帮助。

先看官方文档,英文版觉得有难度看下中文版:Python3.4 入门指南

然后写写代码,小例子看看Python快速教程

遇到问题,可以去看看:stackoverflow python 百问

刚开始,你可能不知道module,package,这些都傻,先看看这篇文章python模块

如果你比较纳闷那个命名中的双下划线,但下划线都啥意思,看看单下划线和双下划线区别

之后,你可能想看看一个系统的组织,那么看看python最佳实践指南全版

如果你觉得上面的太多,看看中文的摘要版

后来我看到一个yield,不太明白,于是我看到了Python yield 使用浅析,只能说写的真是好,就是迭代器生成的

想看看正则?看看python正则表达式指南,非常全面

我只是想发个http请求,如果你用了python3.x,报错,Import error: No module name urllib,那么看看urllib这个坑,你可能要看看,你没有看错,他们合并了。。

Dive into Python 中文也看看,不要在意细节。

最后好像看看Expert Python Programming,因为我没看。

 鸟瞰Spring MVC

与其他请求驱动的Web框架思路类似。org.springframework.web.servlet.DispatcherServlet就是Spring mvC中的Front Controller。负责处理请求,但是不针对具体的处理逻辑。而是委派给下一级的控制器,也就是org.springframework.web.servlet.mvc.Controller去执行。

DispatcherServlet的处理流程如下:
1.HandlerMapping
DispathcherServlet是FrontController,所以他服务于一组Web请求,需要在web.xml中配置。
DispathcherServlet需要自己处理请求和处理之前的对应关系,比如根据参数对应到不同的Controller上。为了更加方便的处理映射的匹配,引入HandlerMapping用来获取需要处理请求的对应的Controller类。
2.Controller
对应于DispathcherServlet的次级控制器,本身实现了对应某个具体Web请求的处理逻辑,当HandlerMapping查到了Controller之后,DispathcherServlet获得了HandlerMapping的返回结果。然后调用Controller处理请求,处理完成后,返回一个ModelAndView实例,里面包含两部分内容
视图的逻辑名称,DispathcherServlet根据名称决定显示哪个视图
模型数据,渲染过程中需要将这些模型数据并入视图的显示中

ViewResolver和View
我们已经来到了最后一步,要转成最终的JSP视图文件。由于模板引擎很多,Spring提供了一套基于ViewResolver和View的抽象层。


来自为知笔记(Wiz)

Spring揭秘-22章,迈向Spring MVC的旅程


Servlet导致数据访问逻辑和业务处理逻辑和对应的视图渲染逻辑相互混杂。之后,JSP出现,通过将输出渲染以模板的形式抽取到jsp后缀的模板文件中,jsp开始繁盛,同时要注意,Servlet处理web请求的时候,要在web.xml中,注册相应的请求url和具体的Serlet的映射关系。于是,jsp有开始混合着写代码

于是,我们引入了JavaBean,来封装相关业务逻辑,经过一次升级后,


这个模型就比较清楚了。但是和MVC还是有点差别
一个典型的mvc模式应该是这样的


控制器处理请求,模型封装逻辑和状态,视图给用户,

Structs以请求/响应框架为基础。

Spring MVC属于请求渠道的WEb框架。框架引入Front Controller做分发之后,就更加好管理了。


来自为知笔记(Wiz)

Spring揭秘-第13章 统一的数据访问异常层次体系


DAO可以分离数据哭的访问和存储,屏蔽各种数据访问方式的差异性,下面以访问顾客信息为例,使用DAO模式

首先定义一个数据访问对象接口,如下




    public interrface ICustomerDao{
Customer findCustomerByPK(String customerId);
void updateCustomerStatus(Customer customer);

 


之后,所有的数据访问都通过该接口进行,不论底层存储机制如何改变,DAO的实现因此会扩展,但客户端代码不需要调整



客户端要用的时候这样使用即可。



    publicclassCustomerService
{
privateICustomerDao customerDao;
publicvoid disableCustomerCampain(String customerId)
{
Customer customer=getCustomerDao().findCustomerByPK(customerId);
customer.setCampainStatus(CampainStatus.DISABLE);
getCustomerDao().updateCustomerStatus(customer);
}
publicICustomerDao getCustomerDao()
{
return customerDao;
}
publicvoid setCustomerDao(ICustomerDao customerDao)
{
this.customerDao=customerDao;
}

 



我们只要针对不同的数据存储方式实现不同的Dao类即可。


我们开始实现具体的访问数据了。



    publicCustomer findCustomerByPK(String customerId)
{
Connection con=null;
try{
con=getDataSource().getConnection();
Customer cust=..;
return cust;
}
catch(SQLException e){
//这里咋办,直接抛出还是直接处理?
}
finally{
releaseConnection(con);
}
}
privatevoid releaseConnection(Connection con){
}

 



SQLException 是checked exception,如果在DAO的实现类里直接处理掉,那么客户端怎么知道发生了问题,


于是,只能处理,那么客户端的签名就要改了




1. <span class="typ">Customer</span><span class="pln"> findCustomerByPK</span><span class="pun">(</span><span class="typ">String</span><span class="pln"> customerId</span><span class="pun">)</span><span class="kwd">throws</span><span class="typ">SQLExcepiton</span><span class="pun">;</span>

ICustomerDao也要改了,可是这样的话


如果数据在其他方式存储,那么其他类型的异常捕获就要继续添加到方法签名。由于数据访问机制的不同,导致这个接口签名不断在变化。


那怎么办呢?DAO如此美好的远景。

直接抛出,的话,因此,可以根据发生的异常信息封装成不同的unchecked exception,然后抛出,这样方法签名不用改。因为unchecked不需要编译器检查。


要开始写了?Spring的数据访问异常层次体系已经给我们做完了


该体系下面所有的异常类型均以DataAccessException为统领,然后划分成不同的子类型



这些类是啥搜索一下,或者根据名字猜一下,之后我们就可以