花钱的年华

江南白衣,公众号:春天的旁边

Netty高性能编程备忘录(上)

| Filed under 技术

网上赞扬Netty高性能的文章不要太多,但如何利用Netty写出高性能网络应用的文章却甚少,此文权当抛砖引玉。
另外,不来唯品会的基础架构部的话,我可能永远不会这么关注性能,本文其他同事亦有贡献,简历请砸 calvin.xiao@vipshop.com [...] (阅读全文……)

从dstat理解Linux性能监控体系

| Filed under 技术

聪明的同学在性能测试时,一边盯着监控一边自己在想:

“如果有200毫秒的CPU瞬时高峰,会被抓住么?”
“我再加上这个监控项,或者我让采样间隔再密一点,会影响性能么”

dstat用地球人都看得懂的python来写,而且只有寥寥数行,很适合从它入手,了解所有top, vmstat,pidstat们的工作原理,回答上面的问题。
[...] (阅读全文……)

StringBuilder在高性能场景下的正确用法

| Filed under 技术

关于StringBuilder,一般同学只简单记住了,字符串拼接要用StringBuilder,不要用+,也不要用StringBuffer,然后性能就是最好的了,真的吗吗吗?

还有些同学,还听过三句似是而非的经验:

1. Java编译优化后+和StringBuilder的效果一样;

2. StringBuilder不是线程安全的,为了“安全”起见最好还是用StringBuffer;

3. 永远不要自己拼接日志信息的字符串,交给slf4j来。

[...] (阅读全文……)

Java ThreadPool的正确打开方式

| Filed under 技术

线程池应对于突然增大、来不及处理的请求,无非两种应对方式:
  1. 将未完成的请求放在队列里等待
  2. 临时增加处理线程,等高峰回落后再结束临时线程
JDK的Executors.newFixedPool() 和newCachedPool(),分别使用了这两种方式。 不过,这俩函数在方便之余,也屏蔽了ThreadPool原本多样的配置,对一些不求甚解的码农来说,就错过了一些更适合自己项目的选择。 [...] (阅读全文……)

AWK处理日志入门

| Filed under 技术

这两天自己挽起袖子处理日志,终于把AWK给入门了。其实AWK的基本使用,学起来也就半天的时间,之前总是靠同事代劳,惰性呀。

此文仅为菜鸟入门,运维们请勿围观。 [...] (阅读全文……)
by calvin | tags : | 2