Arganzheng's Blog

stay hungry, stay foolish

如何监控线上应用的运行状态

需求 通常我们对线上的运行状态有监控的需求。比如我们需要知道队列的大小和使用情况,缓存的命中率,链接池的大小和使用情况,每个请求的QPS、响应时间,等等。 解决方案 一般的做法如下: 对需要监控的点进行埋点做统计。可以使用AOP尽量做到对应用透明。 统计结果通过某种方式导出。比如最常见的是通过log打印出来,再去查看log。 其实上面的步骤明显的将这个过程进行了抽象: ...

配置MySQL Slave

需求 已经有一主一备,需要再增加一个只读备机。 步骤 1. 安装mysql 最好找个跟Master一样的MySQL版本(特别是主版本号)。基本不需要源码安装,到官网找到相应平台编译好的二进制包就可以了。 具体参考: 2.2 Installing MySQL on Unix/Linux Using Generic Binaries。可以不建立mysql组和用户。 shell>...

使用Redis做简单的消息队列

消息队列的好处直接,就是 1. 解耦;2. 削峰;3. 异步化。基本上和缓存一样是居家必备之良药。然而消息队列虽然重要,但是同时其实是蛮重的一个组件。 所以就想能不能先简单的通过Redis来实现消息队列呢?不考虑PubSub、分布式、持久化、事务等复杂的情况。就像JDK的各种Queue一样。答案当然是可以的,因为Redis提供的list数据结构就非常适合做消息队列。 List ...

Spring MVC国际化和本地化

在你的mvc-dispatcher-servlet.xml中配置如下: <!-- i18n && l10n --> <bean id="messageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource"> <prop...

log4j详细介绍

log4j核心概念 基本上所有的日志系统(库)对于日志记录的抽象都差不多,就是 日志记录者(Loggers)将message以某种格式(Layouts)写到某些日志文件(Appenders)中。 这里有三个关键的概念——Loggers,Layouts,Appenders,正是Log4J的三个核心概念。下面我们一一介绍一下。 一、Loggers——The ability to sel...

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...