草庐IT

ne-app-and-server

全部标签

google-app-engine - Go Appengine 端点测试的问题

我正在尝试在使用appengine时创建端点测试。不幸的是,由于在创建测试*Request结构时使用的url中缺少模式(和主机),测试一直失败。运行应用引擎测试时,会为在半随机端口号上运行的特定测试生成一个服务器,这使得似乎无法定义完整的url来执行测试。像这样运行测试的officialdocs非常稀疏,只给出了一半的例子,所以我一直在摸索如何让它发挥作用。这是我从代码片段中标记的行得到的错误错误:收到意外错误“发布/auth:不支持的协议(protocol)方案\”\“”测试代码funcTestEndpoints_Auth(t*testing.T){//inputdataaccoun

google-app-engine - 在命令行构建但无法构建为 gae 应用程序

在命令行构建没有问题:Darians-MacBook-Pro:gdrivewebdarianhickman$gobuildhelloworld/hello.goDarians-MacBook-Pro:gdrivewebdarianhickman$本地主机错误:8080/TheGoapplicationcouldnotbebuilt.(Executedcommand:/Users/darianhickman/go_appengine/goroot/bin/go-app-builder-app_base/Users/darianhickman/gowork/src/bitbucket.or

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

mysql - 在灵活的环境中将 Google App Engine 与 Google Cloud Storage 连接起来

我想从我的GAE应用程序连接到我的GoogleCloudMySQL实例。我正在使用github.com/go-sql-driver/mysql驱动程序并且我遵循了tutorial中指定的步骤.显然我可以无误地连接到数据库,但是当我想发出请求时,我得到了driver:badconnection和packets.go:33:unexpectedEOF。我授权我的本地IP地址和GAE应用程序访问我的数据库,我可以毫无问题地从我的本地机器和mysql客户端连接到它。我已经尝试在标准环境中设置我的应用程序并遵循建议here但它也没有用。这是我连接到数据库的Go代码:host:=os.Getenv

unit-testing - 使用 Gorilla MUX 对 App Engine 进行单元测试

我想为GoogleAppEngine中的处理程序编写测试,这些处理程序使用Gorillamux从请求URL读取变量。我从documentation了解到您可以创建一个虚假的上下文并请求用于测试。我在测试中直接调用处理程序,但处理程序没有按预期看到路径参数。funcTestRouter(t*testing.T){inst,_:=aetest.NewInstance(nil)//ignoringerrorforbrevitydeferinst.Close()//triedaddingthislinebecausethetestwouldnotworkwithorwithoutithttpt

sql-server - 使用并行插入语句在 SQL Server 上连接耗尽

我的应用程序:我用Go编写了一个脚本,通过FTP获取大量(>10k)JSON文件,并将内容写入本地SQLServer2016实例中的表。导入一个文件夹后,它会触发一个T-SQL过程来处理进一步的数据处理。总的来说,这个解决方案似乎工作得很好。但是,我需要高度的并行操作才能有足够的性能。通常,每个文件大约有2,000个条目,我需要为每个文件夹导入大约5,000个文件。SQLServer在本地运行,语句的性能不是问题。执行结构:文件列表通过FTP检索,每个文件名都交给一个Goroutine。go-routine获取文件(也通过FTP),解析它并触发SQL插入。在应用程序开始时准备一个简单的

google-app-engine - Gorilla session 从 session golang 中提取结构值

我在我的gorillasession中创建了一个用户条目session.Values["ub"]=ub然而,当我提取时,提取的接口(interface)正在获取值,但是当我将数据类型断言到我的用户结构时,它显示为空。我不明白这背后的原因,因为当我用其他结构运行相同的代码时,它工作正常。可能是什么原因以及如何解决这个问题。val:=session.Values["ub"]varub=&UserBasic{}varokboolifval!=""{//typeassertion//varuserBasic=&auth.UserBasic{}ub,ok=val.(*UserBasic)if!o

google-app-engine - AppEngine "appengine"包始终失败,出现 "syscall"或 "unsafe"导入失败

使用AppEngine1.9.40SDK,我什至无法导入“appengine”包。应用程序.yaml:application:testappversion:1runtime:goapi_version:go1handlers:-url:/.*script:_go_app去代码:packagemainimport("google.golang.org/appengine")funcinit(){appengine.IsDevAppServer()}funcmain(){//Thisisonlyherebecausego-getneedsonit.}命令行:$GOPATH=$(pwd)go

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

google-app-engine - 通过将 key 存储到 session golang 中来更快地加载页面

我正在尝试更快地加载动态页面。我正在将Twitter克隆作为一项学习任务。我正在遵循以下方法当有人发推文时,将推文存储在数据存储中,并在内存缓存中对其进行保护{key.string(),json.Marshal(tweet)}我在用户主页时间线中推送推文。主页时间线是一个[]*datastore.Key,它存储在用户session中(先复制到内存缓存中,然后再复制到数据库中)。当用户打开她的主页时,主页会尝试从session中获取key,如果找不到则进行数据存储查询。一旦我获得key,我就从内存缓存中获取推文(如果不是,则从数据库中获取)我卡在了第3步。在第一种情况下,我得到了正确的信