October 3, 2013
ZeroMQ的模式-Pipeline[转]
"Pipeline pattern 管道模式。\n这种模式描述的场景是数据被散布到以管道方式组织的各个节点上。管道的每一步都连接一个或多个节点,连接多个节点时数据以RR方式往下流。\n注意是流,意味着数据跟发布模式一样是单向的。这个模式对应的socket是ZMQ_PUSH和ZMQ_PULL.\nZMQ_PUSH 用来向下游节点发消息。下游多个节点时采取RoundRobin分发,_zmq_recv()_对于这个socket也是无效的。\n与Pub不同的是,当下游节点达到高水位(HWM)或者根本没有下游节点时,_zmq_send()_就阻塞了,消息并不丢失。\nSummary of ZMQ_PUSH characteristics\nCompatible peer sockets ZMQ_PULL Direction\nUnidirectional\nSend/receive pattern\nSend only\nIncoming routing strategy\nN/A\nOutgoing routing strategy\nRound-robin\nZMQ_HWM option action\nBlock …"
October 2, 2013
gozmq的安装与使用教程(zeromq分布式消息队列+golang)
"实现功能:用go实现消息队列的写入与读取(打算用在发送邮件服务)\n环境工具: Centos 64X 6.4 zeromq 3.2.4: zeromq.org golang: http://golang.org/\n一.安装golang( http://golang.org/doc/install) 这一步很简单,只需要从 http://code.google.com/p/go/downloads 下载到服务器,解压到/usr/local/go目录,再设置一下系统变量就可以了.\nwget https://go.googlecode.com/files/go1.1.2.linux-amd64.tar.gz tar -C /usr/local -xzf go1.1.2.linux-amd64.tar.gz 设置系统变量GOROOT\nAdd /usr/local/go/bin to the PATH environment variable. You can do this by adding this line to your /etc/profile (for a system-wide …"
August 23, 2013
Git 常用命令详解(二)
"Git Community Book 中文版 Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如: linux kernel),管理私人的文档和源代码也有很多优势(如: wsi-lgame-pro)\nGit 的更多介绍,请参考我的上一篇博客: Git 版本管理工具\n一、 Git 命令初识\n在正式介绍Git命令之前,先介绍一下Git 的基本命令和操作,对Git命令有一个总体的认识\n示例:从Git 版本库的初始化,通常有两种方式:\n1)git clone:这是一种较为简单的初始化方式,当你已经有一个远程的Git版本库,只需要在本地克隆一份\n例如:git clone git://github.com/someone/some_project.git some_project\n上面的命令就是将’git://github.com/someone/some_project.git’这个URL地址的远程版本库,完全克隆到本地some_project目录下\n2)git init 和 git remote:这种方式稍微复杂一些,当你本地创建了一个工作目录,你可以进入这个目 …"
August 20, 2013
mysql中的表锁的优化
"一、获取锁等待情况 可以通过检查table_locks_waited和table_locks_immediate状态变量来分析系统上的表锁定争夺: mysql\u0026gt; show status like ‘Table%’; +—————————-+———-+ | Variable_name | Value | +—————————-+———-+ | Table_locks_immediate | 105 | | Table_locks_waited | 3 | +—————————-+———-+ 2 rows in set (0.00 sec)\nTable_locks_immediate 表示立即释放MySQL表锁数, Table_locks_waited 表示需要等待的MySQL表锁数\n如果Table_locks_waited的值比较高,则说明存在着较严重的表级锁争用情况。这时,需要我们对应用做进一步的检查,来确定问题所在。\n可以通过检查Innodb_row_lock状态变量来分析系统上的行锁的争夺情况: mysql\u0026gt; show status like …"
August 12, 2013
golang中结构体的初始化方法的不同用法(new方法)
"自定义一个结构体\ntype Rect struct { x, y float64 width, height float64 } 初始化方法:\nrect1 := new(Rect) rect2 := \u0026amp;Rect{} rect3 := \u0026amp;Rect{0, 0, 100, 200} rect4 := \u0026amp;Rect{width:100, height:200} 注意这几个变量全部为指向Rect结构的指针(指针变量),因为使用了new()函数和\u0026amp;操作符。\n而如果使用方法\na := Rect{} 则表示这个是一个Rect{}结构类型.两者是不一样的.参考代码:\nfunc main() { a := Rect{} a.x = 15 rect1 := \u0026amp;Rect{0, 0, 100, 200} rect1.x = 10 fmt.Printf(\u0026#34;%v\\n%T\\n\u0026#34;, a, a) fmt.Printf(\u0026#34;%v\\n%T\\n\u0026#34;, rect1, rect1) } 运行结果为:\n{15 0 0 0} main.Rect \u0026amp;{10 0 …"
August 11, 2013
golang中的文档管理
"foo.go\n// CopyRight 2013 The Go Author. All Right reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE fifle. /* Package foo implements a set of simple mathematical functions. These comments are for demonstration purpose only. Nothing more. If you have any questions,please don’t hesitate to add yourself to golang-uns@googlegroups.com. you can alse visit golang.org for full Go documentation."
August 11, 2013
golang中的map数据类型操作实例
"package main import ( \u0026#34;fmt\u0026#34; ) type stu struct { Name string Age int } func main() { // 声明一个map变量student,键名为string,值为stu var student map[string]stu // 给map变量创建值,同时指定最多可以存储5个stu值 student = make(map[string]stu, 5) // map元素赋值 student[\u0026#34;stu1\u0026#34;] = stu{\u0026#34;zhao\u0026#34;, 25} student[\u0026#34;stu2\u0026#34;] = stu{\u0026#34;zhang\u0026#34;, 28} student[\u0026#34;stu3\u0026#34;] = stu{\u0026#34;sun\u0026#34;, 32} student[\u0026#34;stu4\u0026#34;] = stu{\u0026#34;li\u0026#34;, 40} student[\u0026#34;stu5\u0026#34;] = stu{} //上面方式的简写方法 /* student := …"
August 9, 2013
go语言单元测试
"Go本身提供了一套轻量级的测试框架.符合规则的测试代码会在运行测试时被自动识别并执行.单元测试源文件的命名规则如平衡点:在需要测试的包下面创建以”_test”结尾的go文件,开如[^.]*_test.go\nGo单元测试函数分为两在类.功能测试函数和性能测试函数,分别以Test和Benchmark为函数名前缀并以*testing.T 和 *testing.B 为单一参数的函数。\nfunc TestAdd1(t *testing.T) func BenchmarkAdd1(t *testing.T) 测试工具会根据函数中的实际执行动作得到不同的测试结果。\n功能测试函数会根据测试代码执行过程中是否发生错误来反馈结果; 性能测试函数仅仅打印出来测试所花费时间,用来判断程序性能;\n准备 新建一个文件,命名为 go_test.go\npackage go_test import \u0026#34;testing\u0026#34; func Add(a, b int) int { return a + b } 功能测试 在go_test.go文件里添加以下代码\nfunc TestAdd1(t *testing.T) …"
August 8, 2013
Redis配置文件参数说明
"配置文件参数说明:\nRedis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程 daemonize no\n当Redis以守护进程方式运行时,Redis默认会把pid写入/var/run/redis.pid文件,可以通过pidfile指定 pidfile /var/run/redis.pid\n指定Redis监听端口,默认端口为6379,作者在自己的一篇博文中解释了为什么选用6379作为默认端口,因为6379在手机按键上MERZ对应的号码,而MERZ取自意大利歌女Alessia Merz的名字 ** port 6379**\n绑定的主机地址 bind 127.0.0.1\n5.当 客户端闲置多长时间后关闭连接,如果指定为0,表示关闭该功能\ntimeout 300\n指定日志记录级别,Redis总共支持四个级别:debug、verbose、notice、warning,默认为verbose loglevel verbose\n日志记录方式,默认为标准输出,如果配置Redis为守护进程方式运行,而这里又配置为日志记录方式为标准输出,则日志将会发送给/dev/null …"
August 7, 2013
安装hg命令
"在使用golang开发的时候,有些时间github.com上面的包需要执行hg命令(hg命令简介).这个时候就需要安装一下才可以.\nLinux下安装Mercurial(hg):\n安装Mercurial 在进行后面的操作之前需要安装Mercurial( 百科)版本管理系统(可以输出hg名词检测是否安装)。输入以下命令安装:\nsudo easy_install mercurial 对于 Ubuntu/Debian 系统,easy_install 命令可以用\napt-get install python-setuptools python-dev build-essential 安装。 如果上述命令安装失败的话,还可以尝试去官方网站 下载\nWindows下安装\n国内国度网盘下载(32位): http://pan.baidu.com/share/link?shareid=3528053518\u0026amp;uk=2365864479\n(64位): http://pan.baidu.com/share/link?shareid=3560201274\u0026amp;uk=2365864479"