草庐IT

err_ssl_protocol_error

全部标签

去旅行练习 : Errors: using Sprintf with %f to avoid infinite recursion

我正在学习Go教程,在Errors练习中它提到在Error函数中调用Sprint(f)会导致一个问题,这是一个无限循环。此处解释了为什么会发生这种情况:Error,infiniteloop在我的第一个实现中,尽管我使用了带有%f动词的Sprintf:func(eErrNegativeSqrt)Error()string{returnfmt.Sprintf("cannotSqrtnegativenumber:%f",e)}这似乎避免了这个问题,我想知道这是否是因为%f动词需要一个float,所以它强制它将e视为一个float?这次旅行提到assignmentrequiresexplici

http - 戈朗 : strategies to prevent connection reset by peer errors

该程序同时生成许多goroutines(getStock),我相信这会导致远程服务器立即断开连接。我不是要创建DOS,但我仍然想在不出现“连接重置”错误的情况下积极获取数据。最多只能有N(例如20)个同时连接的策略是什么?golang的Http客户端有内置GET请求队列吗?我仍在学习,如果能了解是否有针对此类代码的更好设计模式,那就太好了。输出$goruns1w.gosl(size):1280body:"AAPL",17.92body:"GOOG",32.13body:"FB",42.02body:"AMZN",195.83body:"GOOG",32.13body:"AMZN",19

elasticsearch - DeleteByQuery ElasticSearch Golang 错误 elastic : Error 404 (Not Found)

我正在尝试从我的索引中删除具有特定产品ID的文档。示例代码如下:packagemainimport("encoding/json""log""time""fmt""gopkg.in/mgo.v2/bson"elastic"gopkg.in/olivere/elastic.v3")funcmain(){client,err:=elastic.NewClient(elastic.SetSniff(false),elastic.SetURL("http://localhost:9200"))iferr!=nil{log.Fatal("CannotcreateESclient:",err)}b

postgresql - go-gorm,postgres : simple inserts return error

由于最近的炒作,我正在尝试做简单的插入,试图评估Postgres的有用性。我是一个mongoDB的人。这就是我想要做的:db,e:=gorm.Open("postgres",fmt.Sprintf("host=%suser=%sdbname=%spassword=%ssslmode=disable",pgHost,pgUser,pgDatabase,pgPass))ife!=nil{log.Fatal(e.Error())}deferdb.Close()db.AutoMigrate(&model.Customer{},&model.Email{},&model.Address{},&m

go - 带有 gRPC 的 golang protocol buffers 可以在不同的 OS 平台上交叉编译和使用吗?

这个问题专门关于在不同的操作系统平台上编译和使用golangProtocolBuffer(使用gRPC),我还没有看到类似的问题。是否可以在Windows上编译一个.proto文件,然后在Linux上使用生成的文件?还是相反?我在Windows和Linux上编译了相同的.proto文件,diff显示了不同的结果。一个区别是Windows编译版本有时会在请求结构的字段中重复json,如下所示:Field1Name*type`protobuf,bytes,1,opt,name=my_name,json=myName"json:"my_name,omitempty"`而Linux版本是:Fi

go - 使用 rows.NextResultSet() 在多结果集查询中调用 rows.Err()

我正在构建一个包含多个结果集的查询,按照给定的示例here.为了方便起见,下面复制了重要的部分。我的问题是,是否应该在每个forrows.Next(){...}循环之后调用rows.Err(),而不是在最开始的时候调用一次结束如示例所示?为什么/为什么不?我的理解是rows.Err()会捕获错误,"...encounteredduringiteration",而rows.NextResultSet()将捕获,"...[errors]advancingto[thenextresultset]".似乎我想在每次迭代中捕获错误,不是吗?谢谢!rows,err:=db.Query(q,age)

ssl - 通过存储与 Wireshark 一起使用的 SSL key 在 golang 中解密 TLS

我正在尝试通过提供tls.Config来建立TLS连接包含Rand的结构应始终返回相同的字段int调用他们时Read方法,参见这里的文档:https://golang.org/pkg/crypto/tls/#Config我写了这个构建器:funcnewZeroRand()*rand.Rand{returnrand.New(rand.NewSource(0))}并进行测试以确保rand.Rand总是返回相同的int什么时候Read被多次调用,注意不同的输入参数"foo"和"bar"提供相同的输出:funcTestPredictableZeroRandGenerator(t*testing

go - panic : runtime error: slice bounds out of range when concurrently running as goroutine

我将一个函数作为goroutine调用,并使用WaitGroup来防止在它们全部完成之前关闭共享扫描仪。myfunc()函数迭代一个文件。我想内存映射这个文件并在所有goroutine之间共享它,而不是每次都从磁盘读取I/O瓶颈。有人告诉我这种方法可行inananswertoanotherquestion.然而,虽然这个函数独立运行良好,但它不能同时运行。我收到错误:panic:runtimeerror:sliceboundsoutofrange但错误是当我调用Scan()方法时(不在slice上),这令人困惑。这是一个MWE://...packagedeclaration;impor

客户端的 ssl 版本和密码套件

我正在开发一个soap服务器,它将为一些带有遗留soap协议(protocol)的旧嵌入式计算机提供服务。我用go编写它,到目前为止只使用普通的http,但在生产中它必须使用ssl加密。所以我刚刚创建了一个key和一个证书(来自thissite)并使用了http.ListenAndServeTLS函数。但是现在计算机无法连接,服务器只是打印握手错误:server.go:2848:http:来自[::1]:38790的TLS握手错误:tls:客户端和服务器均不支持密码套件在文档中,对于计算机来说,不支持ssl版本或密码。所以我想知道,如何找出客户端的ssl版本,以及客户端支持的可用密码套

rest - 去 SSL 监听器

我正在用Go构建一个休息API。我有一个SSL域和一个专用服务器。域指向我的专用域并且工作正常(https://www.myweb.com)。错误是当我向我的API的某些端点发出请求时,我从未从服务器获得响应。funcmain(){router:=NewRouter()handler:=cors.New(cors.Options{AllowedMethods:[]string{"GET","POST","PUT","DELETE","PATCH"},AllowCredentials:true,AllowedOrigins:[]string{"*"},AllowedHeaders:[]s