微博工作半年记(2012.2.27-2012.8.27)

本文分享了微博短链系统优化的过程与心得。面对10亿PV及2000+QPS的数据挑战,作者通过引入HBase等技术,解决了性能瓶颈,并积累了高并发处理经验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

代码patch +行:  10958

上线次数:总计27次,每周一次的频率

工作内容:微博短链,短链统计项目。  10亿+pv,后台进程2000+qps 数据流处理。没完没了的第三方接入,苦逼的性能优化,mysql批处理,hbase数据库方案,倒库,双写,下双写。。。

应用技术:memcache redis mysql HBase分布式系统架构,vanish,concurrent多线程用法,jvm内存模型、内存分配调优和内存状况跟踪

工作收获:

  1. 减少无聊重复工作占用的时间:刚开始三个月都被耗了,自己也瞎玩浪费时间。现在有规则库后台,省得走改两行代码测试上线的苦逼费劲流程了
  2. 开始懂得做事考虑成本,估算资源消耗,考虑带宽,考虑怎么省机器
  3. 搞清楚问题所在,了解整个系统再去做优化:刚开始说是系统负载问题,改批处理减少IO,后来发现数据库容量也有问题,改hbase,探索,减少往后的开发维护。所以数据库容量,缓存消耗命中率,访问量统计,错误状况都要做了解才好动手。
  4. 搞清楚当前系统状况再去改代码:log你熟悉了吗就去改?改完了读数据源有延时也不清楚之前是不是也有,苦逼搞了一个月才蠔。jvm状况你清楚吗?改完发现内存溢出,查查查改改改,最后发现还是写数据库慢导致的对象不能销毁。当前系统是否有坑你知道吗?自以为是获取全量list,最后发现一个key对应的list之前系统根本没有删到500,一下取出几十万,把HBase给卡死。熟悉再动手,而不是像《cube》一样,转了一圈,死了大半,其实出口就在原点。
  5. 引进新技术充分考虑风险,问清楚目前应用状况。 已经应用但没有上线的项目,宣称很稳定使用的hbase,在你没熟悉它时去应用,会导致很多问题,引进新技术充分学习掌握它再动手,考虑学习时间,考虑好它的优缺点。
  6.  遇事淡定,技术人员,关注自己能控制的东西,遇到问题解决问题(这条by军伟);从每天纠结苦逼的要死,被电话和不稳定因素折腾得快疯掉到最近的平稳无事,一路走来,心态心态!

技术收获:

  1. 高并发经验,培养上亿pv的感觉
  2. 多线程实战
  3. HBase源码学习阅读,看别人怎么写的,自己模仿写写,算是有点起步深入的味道;HBase问题解决,每天和DBA一起分析日志,快速上线迭代,慢慢解决掉各种误用和本身HBase的参数设置问题

其他收获:

  1. 学会了游泳,每周两次,坚持生活节奏
  2. 20公里暴走雾灵山,35公里暴走五台山,不禁感慨团队生命力之旺盛。。。
  3. 认识各种疯子技术狂人

转载于:https://www.cnblogs.com/shenguanpu/archive/2012/08/27/2658717.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值