草庐IT

系统高并发

全部标签

linux - 为什么多个克隆系统调用调用单个 go 子程序?

我创建了一个小示例程序来检查子例程系统调用。packagemainfuncprint(){}funcmain(){goprint()}go子程序的stracesclone(child_stack=0xc000044000,flags=CLONE_VM|CLONE_FS|CLONE_FILES|CLONE_SIGHAND|CLONE_THREAD|CLONE_SYSVSEM)=27010clone(child_stack=0xc000046000,flags=CLONE_VM|CLONE_FS|CLONE_FILES|CLONE_SIGHAND|CLONE_THREAD|CLONE_SY

go - Redigo 并发集导致数据竞争

我正在针对我的redigo函数运行这个测试,看看它是否支持大量并发写入,这是代码import("github.com/gomodule/redigo/redis""log""os")//RedisconnectionpoolvarRedisPool*redis.PoolfuncInitPool(){RedisPool=&redis.Pool{MaxIdle:80,MaxActive:12000,Dial:func()(redis.Conn,error){conn,err:=redis.Dial("tcp","127.0.0.1:6379")iferr!=nil{log.Printf("

concurrency - Golang并发下载死锁

我想在go中并行下载文件,但我的代码永远不会退出:packagemainimport("fmt""io""net/http""os""path/filepath""sync")funcdownload_file(file_pathstring,wgsync.WaitGroup){deferwg.Done()resp,_:=http.Get(file_path)deferresp.Body.Close()filename:=filepath.Base(file_path)file,_:=os.Create(filename)deferfile.Close()size,_:=io.Copy

Golang 类型系统不一致(http包)

我正在努力研究GoLang类型系统,但有些事情让我感到困惑。所以我一直在研究http库以试图理解这一点,但我遇到了以下毫无意义的内容。packagemainimport("net/http""fmt""io/ioutil""io")funcconvert(closerio.Closer)([]byte){body,_:=ioutil.ReadAll(closer);returnbody}funcmain(){client:=&http.Client{}req,_:=http.NewRequest("GET","https://www.google.com",nil)response,_

go - 关于goroutine并发的问题

我在goroutine并发方面遇到了一些麻烦。在我的期望中,它应该异步运行并几乎同时打印出来,但它真正做的是等待运行我的测试代码packagemaintypebatchD[]stringvarcBD=make(chanbatchD,6)funcmain(){runtime.GOMAXPROCS(runtime.NumCPU())data:=[][]string{}data=append(data,[]string{"71","40348270","6","win888e","6","1","N","127.0.0.1"})data=append(data,[]string{"71","

go - 初始化/管理并发 SSH 连接

我进行了高低搜索,但我不确定我是否使用了错误的关键字,但我无法理解这一点。我正在构建一个应用程序,它接收主机名列表并通过SSH连接到这些主机名。它旨在维护这些连接(并在断开连接时重新连接)。定期地,我的程序将接受指令并向部分/所有这些主机执行命令。我目前的问题是,我知道你不能初始化一个变量而不使用它,我必须为这些SSH连接动态创建变量,这样我就可以独立监控/管理它们(读/写,必要时重新连接等).由于我对go的了解有限,而且倾向于不小心使事情过于复杂,到目前为止,我想到的最好的方法是使用一个结构并为每个连接及其参数(主机名、用户名、密码、SSH配置详细信息、日志文件)附加位置等)。目前我

go - 为什么并发不能加速我的斐波那契函数?

这是Go之旅中的以下并发示例packagemainimport("fmt")funcfibonacci(nint,cchanint){x,y:=0,1fori:=0;i我将其修改为不使用goroutines:packagemainimport("fmt")funcfibonacci(nint)int{if(n==0||n==1){return1}x:=1y:=1fori:=0;i然而,在n=100000时,它所花费的时间几乎都是瞬间的。有没有人有goroutines加速计算的例子?我想知道是否有一些编译器设置限制了我的程序可以使用的内核数量。为什么goroutines不能加速计算?

go - golang 使并发更容易的关键原因

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭7年前。Improvethisquestion我的理解大概在下面吗?go可以大部分在编译时检测死锁。go可以使用chan来最小化racecondition是因为只有单个发送者或接收者goroutine一次可以访问任何特定的chan。

Go,可扩展的文件分类系统

我想创建一个“脚本”,它将遍历目录树以对文件进行分类并采取行动(如果是照片,上传到Flickr。如果是视频,移动到文件夹,..).我不了解Go,但想改变它。文件发现和分类似乎不是主要部分。routines和channels似乎足以拥有一个非阻塞系统。我主要关心的是要采取的行动。我肯定会编写一些操作代码,例如“FlickrUpload”或“Shell”(对于mv、cp,..)。但我想要一个可配置的系统,我可以在其中将Action附加到mime类型。我认为Xml结构可以很好地配置它并且看起来很容易解析。mv${file}/some/absolute/path/但我不知道如何将操作及其参数(

go - 系统休眠后 time.Time.Sub() 计算错误

我创建了一个timerapplication在终端窗口中运行。我在time.Time.Sub()中目睹了一些奇怪的行为当我启动终端计时器并通过关闭它让运行它的macOS笔记本电脑进入休眠状态时。当我重新打开笔记本电脑时,突然该功能似乎无法正常工作,正如thisblockofcode所跟踪的那样,在这个复制的输出中可以看出计算错误,除非我误解了time.Time值:==615aTimer==20m59snow:2018-04-2705:58:20.440440541-0700PDTm=+310.234277006exactLeft:20m59.142673336st.end:2018-0