首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用mysql本机正确安装Vibe-d服务器

如何使用mysql本机正确安装Vibe-d服务器
EN

Stack Overflow用户
提问于 2022-09-27 09:00:23
回答 1查看 63关注 0票数 0

我有vibe-d程序,被用作链接的代理。我使用mysql-本机连接到SQL。这是可行的,但服务在20-2分钟后在更高的流量下死亡。除了: core.exception.AssertError之外,我没有看到任何具体的错误。这让我想,如果一切都安排妥当的话。我没有找到任何关于如何设置这样一个项目的例子。

这是我的应用程序的一个非常简化的版本。这是连接到Vibe项目中的MySQL的正确方式吗?我在Proxyd类中创建一个mysql池,然后在lockConnection的每个操作中打开新的连接。

代码语言:javascript
复制
void main()
{
  Proxyd proxy = new Proxyd(dbConfig);
  auto settings = new HTTPServerSettings;
  HTTPListener http_listener = listenHTTP(settings, proxy.getRouter());
  runApplication();
}

class Proxyd
{
  URLRouter router;
  MySQLPool db_pool;

public:
  this(Node dbConfig)
  {
    router = new URLRouter;
    router.get("/link", &link);
    db_pool = new MySQLPool(host,username,password,database,port);
  }

private:
  void link(HTTPServerRequest request, HTTPServerResponse response)
  {
    db = db_pool.lockConnection();
    ResultRange rows = db.query("..")
  }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-09-27 09:41:12

我不太确定,但这可能是因为vibe.core.connectionpool不能在工作线程之间共享。https://github.com/vibe-d/vibe-core/blob/f19401bfbe3d689b8ff7d50a9aafdf9f52887083/source/vibe/core/connectionpool.d#L74

这将是工作。

代码语言:javascript
复制
MySQLPool pool;  // per threads, on TLS.

static this() {
    pool = new MySQLPool(...);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73864909

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档