草庐IT

ftp-telnet-mysql-ssh-http

全部标签

api - 如何从 HTTP 处理程序中的 URL 获取参数

我正在开发一个endpoint/crypto/rates接受两个货币“符号”作为输入的网络服务应用程序。web服务应该在数据库中搜索这些字符之间的货币兑换数据,如果数据库中没有值,或者时间戳值与当前值相差超过1分钟,则向服务API发出请求:https://min-api.cryptocompare.com/documentation所以,我创建了结构和go-chi路由器。但我不知道如何构建一个工作处理程序来从URL获取参数,例如:https://min-api.cryptocompare.com/data/price?fsym=BTC&tsyms=USDpackagemainimpor

go - http put 服务器处理大文件

请考虑这个codepostedhere,它处理httpPUT请求。它工作正常,有小文件:$curl-vhttp://192.168.1.10:9193/-Tred.tx*Trying192.168.1.10...*Connectedto192.168.1.10(192.168.1.10)port9193(#0)>PUT/red.txHTTP/1.1>Host:192.168.1.10:9193>User-Agent:curl/7.47.0>Accept:*/*>Content-Length:19697247>Expect:100-continue>但是-向它发送一个大于1G大小的大文件

mysql - golang 代码中 mysql 查询的自动递增不起作用

我正在开发一个使用以太坊区block链的项目,我想用block数据填充数据库,但是对于block_id自动增量不起作用。下面的代码是创建查询stmt,err:=db.Prepare("CREATETABLEIFNOTEXISTSblock(block_idbigintNOTNULLAUTO_INCREMENT,block_numvarchar(200),block_hashvarchar(200),tx_countint,PRIMARYKEY(block_id));")下面的代码用于插入数据funcInsertBlock(db*sql.DB,block_numstring,block_

go - 在反向代理中多次重复 http.Request

我正在实现http.RoundTripper在Go中,作为httputil.ReverseProxy的一部分实现。我需要缓冲传入的请求,并根据从后端获得的响应重复多次。为此,我使用request.Write和http.ReadRequest.(我其实不确定这是否是个好主意,如果有更好的方法,我很感兴趣。)使用http.ReadRequest反序列化来自[]byte的请求后并使用http.DefaultTransport的往返程序重复它,我在我的stderr中打印了这个:2019/08/0114:35:51http:proxyerror:unsupportedprotocolscheme

go - 是什么让 http.server 使用 HTTP/2?

我制作了两个Go程序,每个程序都尝试通过TLS向对方发送请求。换句话说,两个程序既充当客户端又充当服务器。但是,第一个客户端主机尝试使用HTTP/1.1连接到服务器主机,而服务器主机使用HTTP/2进行监听,这会导致错误。程序Aclient:=&http.Client{Transport:&http.Transport{TLSClientConfig:tlsConfig,},}mux:=httprouter.New()mux.GET("/test",test)serverTLS:=&http.Server{Addr:"127.0.0.1:8081",Handler:mux,TLSCon

mysql - 无法连接到 DB : database is closed

我有以下项目结构:-main.go-db--dbinit.go在dbinit.go中,我有以下代码:packagedbimport("database/sql"_"github.com/go-sql-driver/mysql")varDb*sql.DBvarerrerrorfuncinit(){Db,err=sql.Open("mysql","myDBCreds")deferDb.Close()}在main.go中我有:packagemainimport(db"./db")funcmain(){deferdb.Db.Close()sqlStatement:=`INSERTINTOtab

performance - Go - 在用于负载测试的高性能 http 客户端中,如何阻止/忽略所有 cookie?

我正在为我的公司创建工具来对我们的系统进行负载测试。我目前有用Python编写的工具,但我正在探索使用Go的选项,希望提高效率和性能,因为我们需要同时生成数百万用户(每个盒子有数千个,有很多盒子)并且每一点都很重要。我的用户主要对我们的系统进行http调用,我需要一个非常轻量级和高效的http客户端。对于我们的Python工具,以前的员工有一些功能手动处理和重用套接字并完全忽略cookie。虽然我是Go的新手,但到目前为止我已经比较了多个Go网络实现,我对CPU和网络使用情况很满意,所以我认为我还不需要手动管理套接字,但是RAM使用率比我们的Python解决方案高出数倍。我怀疑这是由于

go - 无法在 http 请求中设置 POST 正文

这不是设置POST请求正文的正确方法吗?data:=url.Values{}data.Set("url","https://www.google.com/")client:=http.Client{}r,err:=http.NewRequest(http.MethodPost,apiURL,strings.NewReader(data.Encode()))下面的代码在执行时表明POST请求中没有发送urlparam。packagemainimport("fmt""io/ioutil""net/http""net/url""strings")funcdoAPICall(){//curl-

mysql - 如何使用csv.Writer输出MySQL数据

我正在尝试通过Go将MySQL查询的结果导出到.csv文件。在我当前的代码中,我能够在命令窗口中打印出我的查询结果,但我想通过.csv文件导出这些结果。我当前的代码如下所示:results,err:=db.Query("SELECTid,testId,testtwoId,testthreeId,testfourIdFROMTestTableLIMIT100")iferr!=nil{panic(err.Error())}forresults.Next(){varestTableTestTableerr=results.Scan(&orderEvent.id,&orderEvent.tes

http - 自定义 Go 的 http 库中的现有处理程序

根据http库中的说明定义以下内容:funcHandle(patternstring,handlerHandler)typeHandlerinterface{ServeHTTP(*Conn,*Request)}我如何通过给它一个额外的参数(并告诉它如何处理参数)来改进现有的处理程序(例如,websocket.Draft75Handler)?我正在尝试创建一个处理程序,其中包含channel的一端。它将使用该channel与程序的其他部分对话。我怎样才能让该channel进入处理函数?如果这是一个愚蠢的问题,我们深表歉意。我是新手,决定通过阅读教程来学习,然后直接跳到代码中。感谢您的帮助