Arganzheng's Blog

stay hungry, stay foolish

log4j日志路径问题

问题 原来的log4j.properties配置文件中配置日志文件路径如下: ## File output... log4j.appender.system=org.apache.log4j.RollingFileAppender log4j.appender.system.File=../logs/system.log log4j.appender.defaultLogger.Date...

使用拦截器做简单的性能监控

需求 监控所有的Controller Handler Method,对处理时间超过阈值的邮件报警。 实现 Spring MVC提供了interceptor的机制,可以方便的进行对handler method进行AOP。具体实现如下。 首先在Spring MVC配置文件配置一下interceptor: <!-- Configures Handler Interceptors -...

Andriod平台推送系统设计

背景 移动互联网带来一个结果就是实时性,而消息推送就是实时性的一个重要原因。服务器经常会推送各种消息给终端,比如最新的新闻,微博,评论,等等。可以说,主动消息推送是一个越来越基本的功能了。那么怎么实现呢? 常见的实现方案有如下几种: 1. 轮询方式(PULL) 应用程序周期性的与服务器进行连接并查询是否有新的消息。你必须自己实现和服务器之前的通信,例如消息队列。 主要要考虑轮询的效率...

Spring各种依赖注入注解的区别

Spring对于Bean的依赖注入,支持多种注解方式: @Resource javax.annotation JSR250 (Common Annotations for Java) @Inject javax.inject JSR330 (Dependency Injection for Jav...

一个简单分页查询组件实现

背景 分页查询是非常常见的需求。所以有必要做成一个比较公用的组件,避免大家重复实现分页功能。 实现 分页组件分为前台部门和后台部分。这里先前台说起。 前台分页组件 因为我们的网站用的是bootstrap的样式,所以找了一个基于bootstrap的前台分页组件——bootstrap-paginator。使用非常简单,这里关键是用velocity的宏把它定义成一个组件: #macro...

优雅的Builder模式

Builder模式是GoF中的创建型设计模式中的一种。原来的意图是将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。不过现在基本主要都是用于流水接口进行优雅构建。另外,在Groovy这样的动态语言中,是一种简单方便的DSL。下面分别介绍这两种场景。 流水接口 这个例子来源于笔者在做动态页面缓存需求时的一个实现。具体可以参见笔者的另一篇博文:动态页面缓存方案。其中应...

动态页面缓存方案

背景 像新闻等这样的比较少变化的页面,提供一个静态页面缓存机制,避免每次都动态拉取数据渲染生成HTML。 解决方案 总体原则 应用服务器(这里是tomcat)不处理静态资源的缓存,由前端nginx、CDN和browser来处理。应用通过HTTP头控制前端静态资源缓存的缓存时间和机制。应用服务器这边缓存的是数据(redis等cache),而不是静态页面。这样的好处是系统的边界和职责更加...

小议Android手机隐私数据的存储安全

WhatsApp引出的隐私泄漏风险 刚被Facebook收购的WhatsApp最近可谓是不太平。安全服务厂商DoubleThink公司3月13号称,Android版WhatsApp中存在加密漏洞,允许另一应用访问并读取所有用户的聊天记录。尽管WhatsApp对Android版本进行了大的更新,但该漏洞仍然存在。导致漏洞的是因为Android版的WhatsApp聊天记录被存储在手机上的SD卡...

使用zookeeper实现分布式锁

大家也许都很熟悉了多个线程或者多个进程间的共享锁的实现方式了,但是在分布式场景中我们会面临多个Server之间的锁的问题,实现的复杂度比较高。利用基于google chubby原理开发的开源的zookeeper,可以使得这个问题变得简单很多。下面介绍几种可能的实现方式,并且对比每种实现方式的优缺点。 1. 利用节点名称的唯一性来实现共享锁 ZooKeeper抽象出来的节点结构是一个和un...

ZooKeeper简介

Zookeeper的简介 ZooKeeper是一个构建在Paxos算法上的高可用的分布式数据管理与系统协调框架,提供了一系列原语集,更上层的应用可以用它来实现同步,配置管理,名称服务,Master选举,分布式锁,分布式队列等。 zookeeper提供如下服务保证 顺序一致性: client的updates请求都会根据它发出的顺序被顺序的处理 原子性: 一个update操作要么...