0%

习惯了golang的net/http/pprof的便利,c++的性能分析就显得繁琐了一点。

不过大致上还是一致的。

安装

包管理安装

1
2
3
4
5
centos:
yum install google-perftools google-perftools-devel

ubuntu:
apt-get install google-perftools google-perftools-devel
阅读全文 »

两个因素想做开源项目:

1 主导开发中间件系统的心愿已经达成,虽然中间磕磕碰碰的踩了很多坑。

但毕竟最终结果是好的。

唯一的遗憾就是没有开源了。

2 之前做了一些小网站,也累积了不少用户,但是对技术的磨练还是太少了。

特别是用户的增长出现瓶颈以后,架构和细节已经没有必要在优化了。这就让人产生了惰性。

认真做一个开源项目,会有bug issue和功能的issue。会有人去推动你不断探究。

我认为这会收获巨大。

具体项目没想好,可能是基础库(偏网络高并发?又一个轮子?),也可能是比较擅长的存储系统。

阅读全文 »

过载保护初探

距离上一篇过载保护的文章已经快一年了

上一篇文章是上一个项目分布式文件系统使用的,这个项目因为一些架构上的缺陷,并没有让最大的云盘服务接入。

没有那么大的量级,因此思考的过载保护方案也没有全部去实现。

新的项目有比较大的量级,在实现新项目的过载保护机制时会更全面。

阅读全文 »

我对23种设计模式的理解:

类模式和对象模式

有些博文会把对象分为类模式和对象模式,在我看来这两种模式是可以相互转化的。类模式主要强调类的继承决定结构或者行为,是通过继承的延迟到子类去实现,来完成模式。而对象模式则主要强调对象的关联来完成模式(关联一个接口用桥接模式完成继承,关联一个对象用适配器模式完成调用)。所以所有的类模式都可以转化为对象模式,而对象模式则不一定可以转化为类模式。

对写golang的同学来说这一点很容易理解,因为golang只有关联没有继承。想要通过继承来延迟到子类去实现,实际上子类是通过关联一个实现了某个接口的对象以及父类,然后把关联的过程封装在创建过程中。这样不同的子类通过动态的组合不同的对象来完成继承。(实际就是桥接模式)

创建型(5种)

阅读全文 »

我认为,控制反转和模版模式以及框架的概念是类似的,而控制正转类同于策略模式,库。

反转的是依赖关系,对框架代码来说,实现的就是模版模式。使用框架的代码,其实被反转调用了。而库则是主动去调用的,是一种策略模式。

因为控制反转是一种设计模式,因此所有语言都存在。

例如C,JS是以回调函数实现。而Python作为一种动态语言,这方面的支持更为强大。

对于OOP的静态语言(Cpp,Java,Golang等等)来说,通过继承的实现更为自然(Golang通过桥接模式变相实现)。

阅读全文 »

概括

最近在做的项目设计到一些金钱交易方面的事情。涉及到一些分布式事务的逻辑。

参考了一些资料,做一些总结。

  • 一句话概括分布式事务:

一部分资源的数据更新以后,怎么保证另外一部分资源的数据也必须更新成功。

阅读全文 »

优酷

BidRequest.SiteObject

1
2
3
4
5
6
7
8
9
10
11
12
Name                媒体广告名称
Page 当前页面URL
Ref Referrer URL(从哪个页面链接到当前页面)
Content 视频的内容相关信息。只有视频贴片类型的广告位才会有这个字段
Title 视频标题名称
Keywords 视频标签关键字,如果是多个关键字,则使用英文竖线分隔
Ext
Channel 视频的频道ID
Cs 二级频道ID
Usr 视频上传者id,优酷里上传视频的用户ID
S 节目id
Vid 视频id

根据优酷提供的 >ADX频道列表 > >ADX二级频道列表

可以根据Channel和Cs分析属于哪一类节目

阅读全文 »

golang字符处理已经踩过好几个坑了,记录一下

emoji表情的处理

用的mysql版本比较老,不支持emoji,所以需要golang来去除emoji表情

判断思路是普通汉字utf8下都是3字节内,而emoji表情是4字节,如果大于4字节就过滤掉即可

1
2
3
4
5
6
7
8
9
10
11
12
import "unicode/utf8"

func FilterEmoji(content string) string {
new_content := ""
for _, value := range content {
_, size := utf8.DecodeRuneInString(string(value))
if size <= 3 {
new_content += string(value)
}
}
return new_content
}
阅读全文 »

之前用触发器做数据统计

然后还是一不小心踩坑了

触发器新建了一张fileinfo表,file表中增删查改的信息都会以触发器的形式去修改fileinfo表

后来发现由于mysql是行级锁,由于file表的操作QPS会很高,这个行级锁会造成很大的性能损失

所以需要把增删查改写入随机行。

阅读全文 »

双十一京东mac air 11寸(redis作者也是用的这个)促销,只要3999,于是买了一台试试水。

本意是通过上一篇博客的内网穿透,直连公司虚拟机用的。但是没想到双休日虚拟机居然连不上了,p2p和代理方式甚至teamview都不行,为了防止这种情况再发生,还是进行一下配置吧。

记录一下防止以后还要装0.0

通用配置

最基础的应该是homebrew安装了,毕竟没有这个连wget之类的都没有

阅读全文 »