草庐IT

配置MySQL

全部标签

go - 如何为 golang tcp 服务器配置 GKE 负载均衡器?

部署golang服务器容器和gke负载均衡器后,我可以成功连接到负载均衡器的外部ip,但没有数据到达服务器容器。当我在本地运行服务器容器并将客户端指向本地主机时,它按预期工作。我将其更改为服务于http请求,并且它在相同的kuberneteslist上运行良好。但是,如果我尝试同时提供tcp和http(在不同的端口上),那么在gke上都不起作用,但在本地又可以正常工作。所以我怀疑这可能与我配置负载均衡器的方式或我在服务器中监听tcp连接的方式有关,这在gke上而非本地运行时会中断某些事情。K8s服务listapiVersion:v1kind:Servicemetadata:name:s

mysql - 使用错误的排序规则连接到 mysql 服务器?

我有一个Golang程序,它可以连接到具有不同字符集或排序规则的数据库。例如,在编写GolangMYSQL驱动程序时默认为utf8mb4_general_cihttps://github.com/go-sql-driver/mysql#collation但是,如果我连接到这样配置的数据库:CREATEDATABASEexamplecharactersetutf8mb4collateutf8mb4_unicode_ci;我可以预料“坏事会发生”吗?索引不起作用? 最佳答案 在大多数情况下,没有问题。例如,当使用WHEREcolumn=

mysql - 避免循环 - 递归 m2m 关系自引用

这不是关于golang或mysql的问题,它更像是一个一般性问题。希望我仍然在正确的地方,有人可以帮助我解决这个问题。我有一个结构Role,它可以有多个子角色。typeRolestruct{NamestringChildren[]Role}假设角色A有一个子角色B,角色B有一个子角色C。在我的前端,m2m关系显示为多选HTML字段。为避免无限循环(A-B-C-A...),我希望用户无法输入相关角色之一。例如,角色C不应显示角色A和B,因为如果用户选择它们,则会发生无限循环。后台的数据库是这样的:角色表(主表)身份证,姓名,...role_roles(联结表)role_id,child_

go - 如何从 Go 中的文件中读取配置键/值对?

我在Node.js中有一个低延迟的应用程序,我正在用Go编写一个新的基线。节点中的应用程序使用配置和一些键/值对。在config/index.js中varconfig={};config.app={port:9000};config.log={level:"error"}module.exports=config;另一个文件config/key_values.js包含键/值对,每隔几分钟刷新一次。module.exports.key_values={"key1":"value1","key2":"value2",}为了阅读这篇文章,我只使用了下面的代码。letconfig=requir

go - 如何配置 krakend.json 转发参数化 url?

基本上我只是想转发这个请求:http://somehost:4321/api/v1/{uid}/profile进入这个:http://123.45.67.89:4321/api/{uid}/profile我在krakend.json中完成了这个:{"version":2,"timeout":"3000ms","cache_ttl":"300s","name":"myapi","output_encoding":"json","port":4321,"endpoints":[{"endpoint":"/api/v1/{uid}/profile","method":"GET","heade

MYSQL并发选择和更新

我无法理解如何使用多个goroutine选择然后更新表。在db和stmt的文档中它说:“多个goroutines并发使用是安全的。”我也使用交易但没有成功。我想启动7个goroutines并获取每一行。数据+--------+-----------+---------------------+|idTest|someValue|date|+--------+-----------+---------------------+|1|1|2019-06-1111:29:42||2|2|2019-06-1111:29:42||3|3|NULL||4|4|NULL||5|5|NULL||6|6

go - 寻找一种在golang mysql中查看内插查询的方法

所以,我有一个相当复杂的查询,我正在尝试调试它,但举一个简单的例子,假设我有这样的事情:q:="SELECTidFROMusersWHEREtimestamp>?ANDtimestamp我将按照通常的方式对此执行Query(),例如db.Query(q,1546300800,1561127488)我想记录/println/任何(用于调试)内插查询,以结束SELECTidFROMusersWHEREtimestamp>1546300800ANDtimestamp想知道这里是否有人对我有窍门。 最佳答案 根据@mkopriva的评论,N

mysql - 启用远程 MySQL 连接 : ERROR 1045 (28000): Access denied for user

运行在WindowsXP上的MySQL5.1.31。从本地MySQL服务器(192.168.233.142)我可以以root身份连接,如下所示:>mysql--host=192.168.233.142--user=root--password=redacted从远程机器(192.168.233.163),我可以看到mysql端口是打开的:#telnet192.168.233.1423306Trying192.168.233.142...Connectedto192.168.233.142(192.168.233.142).但是当尝试从远程机器连接到mysql时,我收到:#mysql--

mysql - 如何处理 sql.ErrTxDone

例如,我正在尝试在我的mysql数据库中创建一条新记录。在sql.ErrTxDone的情况下,它的实际含义是什么,如果事务已提交,我应该怎么做? 最佳答案 如果交易处于无法再使用的状态,您会收到此错误。sql.Tx:AfteracalltoCommitorRollback,alloperationsonthetransactionfailwithErrTxDone.还有sql.ErrTxDone:ErrTxDoneisreturnedbyanyoperationthatisperformedonatransactionthathas

mysql - 如何在我的 Go 程序中运行测试之前获取数据库模式

我必须为数据库交互运行Go测试。数据库模式位于.sql文件中。我有一个包含main包的文件夹A,我在A中有3个文件夹B、C和D,它们分别包含包B、C和D。B、C、D中有测试文件,但A没有任何测试。我想要一种方法,这样我就可以做一个gotest./...从A开始,我的所有测试都在将架构采购到mysql之后运行。我尝试在A中创建一个main_test.go文件并在其中放置一个TestMain函数。但它不起作用。 最佳答案 你可以在main_test.go上使用init函数packagemainfuncinit(){//loadandex