草庐IT

Creating-and-configuring-log-stre

全部标签

logging - 是否可以修改其他包中定义的类型的方法集?

内置的log和log.Logger不提供Error或Warning方法,例如Python.所以我想用下面的代码为内置的Logger类型写一个:func(l*Logger)Error(vinterface{}){info:=fmt.Sprintf("ERROR:%v",v)l.Println(info)}然后我将上面的代码放在GOPATH/src/log下的文件morelog.go中。在main.go中我写道:logger:=log.New(os.Stdout,"Test",1)logger.Error("Errorinmain.")当我运行gobuild时,我得到:./main.go:

google-app-engine - 应用引擎 : Multiple configurations/environments

我有一个GoogleAppEngine应用程序(Golang,如果重要的话)我想多次部署,但设置略有不同。思考生产与QA。app.yaml中的env_variables似乎很有希望,但似乎我只能拥有一个这样的文件。例如,我看不到使用app-qa.yaml调用“goappdeploy”的方法。如何调整部署配置?如果没有将文件复制到目录并操作app.yaml的自定义脚本,是否可以拥有多个app.yaml?还有其他配置方法吗? 最佳答案 我的偏好是在VCS(在我的例子中是git)中反射(reflect)(并通过其控制)暂存/QA和生产之间

戈朗 : declaring maps and slices with iota values

我有这个Go代码:packagemainimport"fmt"typebaseGroupintconst(fooGroupbaseGroup=iota+1barGroup)vargroups=[...]string{fooGroup:"foo",barGroup:"bar",}varxGroups=map[baseGroup]string{fooGroup:"foo",barGroup:"bar",}funcmain(){fmt.Println("groups")fork,v:=rangegroups{fmt.Println(k,v)}fmt.Println("xGroups")for

google-app-engine - golang 数据存储结构 : keeping field unique and required

我想知道如何最好地保证一个字段是唯一的,如果不是,则不会保存到数据存储中。另外,它应该是必需的。我将此字段用作stringID并需要它是唯一的。我知道我可以简单地尝试通过该字段获取实体并查看它是否存在并围绕它构建逻辑。但是有没有更简单的方法,比如在您的结构中声明该字段应该是唯一的和/或必需的?就像下面的模型。typeCarstruct{Regnrstring"required""unique"}谢谢! 最佳答案 来自数据存储API:Bydefault,forstructpointers,allpropertiesarepotenti

http - 转到 http : difference between serving/static and/static/

我对http.FileServer和斜杠感到非常困惑。我需要为html页面提供脚本。在我工作的目录中,我有页面index.html并且我有一个static目录,里面有myscript.js。第一个问题:这样写对不对?我也看到了src="static/myscript.js"我不知道是否有理由使用其中一个(但我猜它会影响我们必须编写的处理程序服务器)。假设我们满足于第一个版本。第二个问题:在服务器端,我想为目录static注册处理程序。灵感来自thisexample,我这样做:fs:=http.FileServer(http.Dir("./static"))http.Handle("/s

Go logging struct 实例化实用方法的 Goroutine 线程安全

我正在使用一个新的go服务,我有一个SetupLogger实用函数,它创建一个新的go-kit日志结构实例log.Logger。从在单独的go-routines中处理请求的代码调用此方法是否安全?packageutilsimport("fmt""github.com/go-kit/kit/log""io""os""path/filepath")//Iftheenvironment-specifieddirectoryforwritinglogfilesexists,opentheexistinglogfile//ifitalreadyexistsorcreatealogfileifno

logging - 我应该在生产代码中使用 fmt 吗?

我看到很多Go代码看起来像这样:funcmain(){response,_,err:=http.Get("http://golang.org/")iferr!=nil{fmt.Printf("%s",err)os.Exit(1)}deferresponse.Body.Close()contents,err:=ioutil.ReadAll(response.Body)iferr!=nil{fmt.Printf("%s",err)os.Exit(1)}fmt.Printf("%s\n",string(contents))}我的问题是:在生产中,我应该保留这些fmt.Printf语句吗?愚蠢

go - 调用 log.Fatalln 时是否调用延迟函数?

db,err:=sql.Open("postgres","…")iferr!=nil{log.Fatalln(err)}deferdb.Close()tpl,err:=template.ParseGlob("")iferr!=nil{log.Fatalln(err)}如果template.ParseGlob("")返回错误,db.Close()是否仍在调用? 最佳答案 不,延迟函数没有运行。这是对log.Fatal的描述:FatalisequivalenttoPrint()followedbyacalltoos.Exit(1).lo

arrays - 戈朗 : calculate diff between two array of bytes and patch an array

我试图找到两个字节数组之间的差异并存储增量。我已阅读此文档https://golang.org/pkg/bytes/但我没有找到任何说明如何找到差异的内容。谢谢。 最佳答案 听起来您只需要一个函数,该函数接受两个字节slice并返回一个新slice,其中包含输入slice中每个元素的差异。下面的示例函数断言输入slice都是非零的并且具有相同的长度。它还返回一个int16slice,因为字节差异范围是[-255,255]。packagemainimport"fmt"funcmain(){bs1:=[]byte{0,2,255,0}b

go - Rethinkdb,去 : Ensure Table and Index in one ReQL statement

我需要确保在应用程序启动时存在表。如果表不存在需要创建,我还想在表上创建二级索引。这在Go中很容易完成,但我想在ReQL中用一条语句完成。所以我想到了这个:funcensureTableIndex(ses*r.Session,namestring,indexstring)(errerror){err=r.TableList().Contains(name).Do(r.Branch(r.Row,r.Expr(nil),r.Do(func()r.Term{returnr.TableCreate(name).Do(func()r.Term{returnr.Table(name).IndexC