草庐IT

Windows服务移植到linux

全部标签

go - 如何修复在 Windows 上压缩的 os.PathSeparator 解压缩文件?

我在Windows上压缩文件,在Linux上解压缩时,使用操作系统默认应用程序,它不会沿路径创建文件夹,而是创建一个名为“indexes\search.invcus\index_meta.json”的文件,例如:unzip2019-05-23_113735_data.zip-dxfolderArchive:2019-05-23_113735_data.zipinflating:xfolder/indexes\search.invcus\index_meta.jsoninflating:xfolder/indexes\search.invcus\storeinflating:xfolde

go - gRPC 到远程服务器的带宽较慢

我有一个gRPC服务,可以将文件从本地机器传输到远程服务器,我注意到一些严重的带宽问题。平均而言,它的下载速度约为1mb/s,一个连接共享多个流(通常约为8个)。服务器使用TLS加密,但这似乎不是瓶颈,因为关闭TLS对性能的影响可以忽略不计。我还尝试使用iperf3直接测试客户端和服务器之间的带宽,结果是10mb/s。Connectingtohost,port[7]local10.0.0.112port59651connectedtoport[ID]IntervalTransferBitrate[7]0.00-1.00sec1.28MBytes10.7Mbits/sec[7]1.00-

linux - 如果 block 设备已经格式化,则退出 mkfs 命令

我正在编写一个实用程序,它需要运行mkfs来格式化block设备。我使用go的exec包为每种文件系统类型运行正确的mkfs命令,例如在ext2的情况下:err:=exec.CommandContext(ctx,"mkfs.ext2","-F",path).Run()不幸的是,如果block设备已经格式化,mkfs将要求确认(并挂起)。这意味着我被迫传递危险的-F标志以跳过此检查,如果设备已经格式化则丢失数据。我无法为上下文添加超时,因为除此确认之外,格式化可能需要一段时间。我找不到一个mkfs标志,如果block设备已经格式化,它会返回错误而不是确认检查。我宁愿不依赖于解析mkfs命

转到/pkg/工具/linux_amd64/链接 : running gcc failed: exit status 1/usr/bin/ld: cannot find -lgdal

我正在尝试在我的源代码上运行gobuild。go/pkg/tool/linux_amd64/link:runninggccfailed:exitstatus1/usr/bin/ld:cannotfind-lgdalcollect2:error:ldreturned1exitstatus我的LD_LIBRARY_PATH变量包含/home/fzd/project/lib64,libgdal.so文件目录的路径。我的PKG_CONFIG_PATH包含指向具有以下内容的.pc文件目录的路径:prefix=/home/fzd/projectexec_prefix=${prefix}libdir

linux - golang 使用父进程命名空间在 linux 中读取文件

我在linux中使用setns系统调用来设置当前go进程的NET命名空间。这个命名空间改变了/sys/class/net对当前进程的显示方式。但是,如果我尝试使用golangapi查看这些文件,我只会看到父View(没有命名空间)。我认为这是因为go在没有继承父namespace的情况下fork。我如何使用go读取/sys/class/net中的文件,以便setns系统调用在正在读取文件的child中持续存在。 最佳答案 原来这是一个已知的“wontfix”问题:https://github.com/golang/go/issues

go - Windows API 错误 "The handle is invalid"

我正在尝试创建一个程序,利用MiniDumpWriteDumpWindowsAPI转储另一个进程的内存。但是,它一直返回一个错误,提示Thehandleisinvalid。我对我的进程句柄非常有信心,因为我以前使用过OpenProcessWindowsAPI,所以我认为这就是我使用CreateFileW的方式。我看过网上的例子,比如thisone但我什么也做不了。到目前为止,这是我的代码:packagemainimport("fmt""os""strconv""syscall""unsafe")varkernel32=syscall.NewLazyDLL("kernel32.dll")

linux - 捕获中断时抑制终端输出中的 '^C' 字符串

我正在拦截我的Go程序中的中断,并且我正在尝试在发生这种情况时打印出一条日志消息,例如:log.Printf("在终端中按下\rCtrl+C")问题是,这样log.Println的日期部分就丢失了。当没有回车时,像这样:log.Printf("在终端中按下Ctrl+C")然后日期被打印出来,但它被^C字符串前置。有没有办法抑制终端上的^C字符串输出,同时在日志字符串中包含日期? 最佳答案 fmt.Print("\r")log.Println("Ctrl+CpressedinTerminal")

c - Windows DLL 文件的正确构建模式是什么?

这两个步骤:gcc-cmain.cgcc-oa.exemain.oMyThing.dll非常适合制作可以调用MyThing.dll内部方法的Windowsexe。注意没有-c的gccmain.c会给出如下错误:未定义对MyThing_method的引用但是,当尝试使用cgo在Golang程序中使同一个系统工作时,我遇到了与使用没有-c的gcc时相同的undefinedreference错误。我读过:https://github.com/golang/go/wiki/WindowsDLLs并且很想尝试使用syscall.NewLazyDLL但我的问题是我的foo.go文件正在调用C.So

http - 解密后的反向代理服务文件

我需要将*os.File放入request.Body中,但我不知道如何处理文件描述符的关闭(以及临时文件的消除)。我无法使用http.ServeFile来提供文件。我有3个软件:A)用户界面(我无法编辑)B)提供文件的后端C)一个http反向代理,其作用是签署从A到B的请求,加密从A到B的文件,以及解密从B到A的文件。软件A期望收到解密文件内容的主体。我知道使用B解密目录中的文件然后让A打开它会更容易,但不幸的是我无法编辑需要请求正文中的文件的A。软件的工作流程如下:软件A向C发送请求,C签署请求并将其转发给B,然后C继续解密文件,并且必须在请求中将解密的内容提供给Abody。type

go - Web 服务器和同时监听 nats

我的代码从终端读取输入并将这些值发送到nats,同时它需要一个http端点。它单独工作,但当我将所有这些组合起来时,它不会从nats中读取。如果您能指出正确的方向,我将不胜感激。packagemainimport("bufio""fmt"nats"github.com/nats-io/nats.go""html/template""log""net/http""os")funcmain(){wd,err:=os.Getwd()iferr!=nil{log.Fatal(err)}tmpl:=template.Must(template.ParseFiles(wd+"/template/m