草庐IT

系统高并发

全部标签

git - 如何在系统中没有安装git的情况下安装golang包?

我正在尝试在我的项目中使用命令goget-ugithub.com/ramya-rao-a/go-outline安装一个go包,但它不会安装。这是我遇到的错误。go:缺少Git命令。请参阅https://golang.org/s/gogetcmd包github.com/ramya-rao-a/go-outline:exec:"git":%PATH%中找不到可执行文件我在文档中查找了goget命令,它说Thegogetfetchingofsourcecodeisdonebyusingoneofthefollowingtoolsexpectedtobefoundonyoursystem:sv

go - 需要帮助理解 goroutine、select 和 channel 并发背后的逻辑

我试图理解goroutine、select和channel并发背后的逻辑。示例代码如下。基本代码来自tourgo。我添加了一些Printf来帮助我更好地理解。packagemainimport"fmt"funcfibonacci(c,quitchanint){x,y:=0,1for{select{casec输出是00frommain(0,1)(1,1)(1,1)(1,2)11frommain12frommain(1,2)(2,3)(2,3)(3,5)23frommainquitgoroutine和channel操作背后都有并发。我的问题是为什么输出不是00frommain(0,1)(1

go - 与列表的数据竞争。使用互斥锁列出并发访问

我正在进行数据竞赛,但我不太明白为什么。使用-race命令运行我的测试我已将其缩小到尝试访问list.List并从中读取它,但我的互斥体似乎没有这样做任何事物。我在一个数组中有许多*list.Lists:typeMyListstruct{mutexsync.Mutex*list.List}typeSomeObjstruct{datastring}varmyListOfLists[10]MyList我正在像这样从列表中读取和写入:list:=myListOfLists[someIndex]list.mutex.Lock()fore:=list.Front();e!=nil;e=e.Nex

go - 实现并发的失败尝试

我很难让go并发正常工作。我正在处理从XML数据源加载的数据。将数据加载到内存后,我循环遍历XML元素并执行操作。加并发前的代码已经过测试,可以正常使用,我认为不会对加并发有任何影响。我有2次失败的并发实现尝试,两次都具有不同的输出。我使用锁定是因为我不想进入竞争状态。对于这个实现,它永远不会进入goroutine。varmusync.Mutex//lengthis197Kfori:=0;i对于此使用waitGroups的实现,发生运行时内存不足varmusync.Mutexvarwgsync.WaitGroup//lengthis197Kfori:=0;i我不太确定发生了什么,需要一

go - stackdriver 是否可以识别来自 k8s 的系统日志输入?

无法让堆栈驱动程序识别系统日志级别。尽管指定了DEBUG,但一切都显示为错误logwriter,e:=syslog.New(syslog.LOG_DEBUG,"myprog")ife==nil{log.SetOutput(logwriter)}log.Print("logme")我知道格式requirements如果我输出正确的格式作为json有效负载,stackdriver会神奇地拾取它并且它对我有用。但为什么即使我对json有效负载进行syslog,stackdriver也无法识别syslog输入? 最佳答案 Syslog是一种

go http.Request.Conn.ActiveConn是一个map,那么会不会有并发map的问题呢?

去http.Request.Context.ActiveConn是一个map,会不会有并发map问题?如果有很多连接,我打印包含ActiveConn(map)的request.Context,会不会有并发读写map的问题?packagemainimport("fmt""net/http")funcmain(){http.HandleFunc("/",func(whttp.ResponseWriter,r*http.Request){fmt.Fprintf(w,"r.ctx:%#v,%+v",r.Context(),r.Context())})http.ListenAndServe(":

concurrency - 为什么并发写入的boolean值设置为false后还是true?

我正在用Go编写哲学家用餐解决方案。我的解决方案很简单:检查两个fork是否可用。如果是这样,请同时选择两者。如果不是,请保留两者。但是,我遇到了一个奇怪的并发错误,即使在明确设置为false之后,fork的可用性仍然是true。我的Fork声明如下:typeForkstruct{musync.Mutexavailbool}func(f*Fork)PickUp()bool{f.mu.Lock()iff.avail==false{f.mu.Unlock()returnfalse}f.avail=falsefmt.Println("setfalse")f.mu.Unlock()return

golang 系统日志故障 : Unix syslog delivery error

我在运行Mavericks10.9.2的OSX上。我正在尝试让我的Revel应用程序记录到系统日志。我的代码在此行失败:sysLog,err:=syslog.New(syslog.LOG_NOTICE|syslog.LOG_LOCAL0,"myApp")出现此错误:Unixsyslogdeliveryerror系统日志肯定在我的机器上运行。可能是什么问题? 最佳答案 验证系统日志是否正在运行或启用它。$ps-aux|grepsyslogroot117030.00.4144241992-IsJ9:17AM0:00.01/usr/sbi

concurrency - 使用并发的 Golang 流水线

Go新手。我正在尝试编写一个“流水线”,其中多个函数像worker一样工作,并在流水线中将一些数据结构传递给彼此,每个函数都对数据结构做一些事情。typeorderStructstruct{orderNum,capacityintorderCodeuint64box[9]int}funcposition0(inchanorderStruct){order:=>63==1){order.box[order.capacity]=1order.capacity+=1}fmt.Println("fillingbox{",order.orderNum,order.orderCode,order.

shell - 流式操作系统/exec.Command

我想构建一个类似于unix工具time的基准测试工具。我目前拥有的是:packagemainimport("fmt""os""os/exec""time")funcmain(){command:=os.Args[1]args:=os.Args[2:]cmd:=exec.Command(command,args...)start_time:=time.Now().UnixNano()stdout,err:=cmd.Output()iferr!=nil{println(err.Error())return}print(string(stdout))total_time:=int64(tim