0%

背景

学过java的朋友都知道,java成功的关键,除了生态、依赖管理也是一个很重要的点。
go如果不能解决包管理的问题,做业务系统开发,是比较难的事情。
之前没有大量投入时间在golang上面,很大的一个原因是:各种搭梯子的go get,拉取依赖包。各种痛苦

阅读全文 »

源码

package main

import (
"flag"
"fmt"
"net/http"
"reflect"
)
type GoService struct {

}
func (G *GoService) HttpServer(port string){
http.HandleFunc("/", func(responseWriter http.ResponseWriter, request *http.Request) {
responseWriter.Write([]byte("hello word"))
})
http.ListenAndServe(":"+port,nil)
}
func main(){
cmd:=flag.String("cmd","","cmd is a string indecated what server")
arg:=flag.String("args","","p is a string ,parameter for service")
flag.Parse()
if len(*cmd)==0 {
flag.Usage()
return
}
in :=make([]reflect.Value,0)
if len(*arg)!=0 {
in=append(in,reflect.ValueOf(*arg))
}
//指定类
service:=&GoService{}
f:=reflect.ValueOf(service).MethodByName(*cmd)
if !f.IsValid() {
return
}
f.Call(in)
//u:=User{1,"golang",12}
//Info(u)
}

编译

go build -o bin/runt.exe main.go

执行

cd bin
runt.exe -cmd=HttpServer -args=8091

第一阶段阅读Redis的数据结构部分,基本位于如下文件中:
内存分配 zmalloc.c和zmalloc.h动态字符串 sds.h和sds.c双端链表 adlist.c和adlist.h字典 dict.h和dict.c跳跃表 server.h文件里面关于zskiplist结构和zskiplistNode结构,以及t_zset.c中所有zsl开头的函数,比如 zslCreate、zslInsert、zslDeleteNode等等。基数统计 hyperloglog.c 中的 hllhdr 结构, 以及所有以 hll 开头的函数第二阶段 熟悉Redis的内存编码结构整数集合数据结构 intset.h和intset.c压缩列表数据结构 ziplist.h和ziplist.c第三阶段 熟悉Redis数据类型的实现对象系统 object.c字符串键 t_string.c列表建 t_list.c散列键 t_hash.c集合键 t_set.c有序集合键 t_zset.c中除 zsl 开头的函数之外的所有函数HyperLogLog键 hyperloglog.c中所有以pf开头的函数第四阶段 熟悉Redis数据库的实现数据库实现 redis.h文件中的redisDb结构,以及db.c文件通知功能 notify.cRDB持久化 rdb.cAOF持久化 aof.c以及一些独立功能模块的实现发布和订阅 redis.h文件的pubsubPattern结构,以及pubsub.c文件事务 redis.h文件的multiState结构以及multiCmd结构,multi.c文件第五阶段 熟悉客户端和服务器端的代码实现事件处理模块 ae.c/ae_epoll.c/ae_evport.c/ae_kqueue.c/ae_select.c网路链接库 anet.c和networking.c服务器端 redis.c客户端 redis-cli.c这个时候可以阅读下面的独立功能模块的代码实现lua脚本 scripting.c慢查询 slowlog.c监视 monitor.c第六阶段 这一阶段主要是熟悉Redis多机部分的代码实现复制功能 replication.cRedis Sentinel sentinel.c集群 cluster.c其他代码文件介绍关于测试方面的文件有:memtest.c 内存检测redis_benchmark.c 用于redis性能测试的实现。redis_check_aof.c 用于更新日志检查的实现。redis_check_dump.c 用于本地数据库检查的实现。testhelp.c 一个C风格的小型测试框架。一些工具类的文件如下:bitops.c GETBIT、SETBIT 等二进制位操作命令的实现debug.c 用于调试时使用endianconv.c 高低位转换,不同系统,高低位顺序不同help.h 辅助于命令的提示信息lzf_c.c 压缩算法系列lzf_d.c 压缩算法系列rand.c 用于产生随机数release.c 用于发布时使用sha1.c sha加密算法的实现util.c 通用工具方法crc64.c 循环冗余校验sort.c SORT命令的实现一些封装类的代码实现:bio.c background I/O的意思,开启后台线程用的latency.c 延迟类migrate.c 命令迁移类,包括命令的还原迁移等pqsort.c 排序算法类rio.c redis定义的一个I/O类syncio.c 用于同步Socket和文件I/O操作