- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在增强 ROS(机器人操作系统)堆栈 sql_database能够处理 postgresqls LISTEN 和 NOTIFY 命令。如前所述,我在 C++ 程序中的 Ubuntu12.04 上使用 libpq 版本 9.1.10-0。但由于某些原因,我无法检索通知。
我知道,有一个示例(示例 28-2.libpq 示例程序 2)并且运行良好。我已经玩了很长时间,还尝试尽可能准确地将它复制到我的代码中,并以某种方式更改示例代码,使其更类似于我遇到问题的代码。但这对我的问题没有帮助。
我可以在示例程序和手动登录数据库时收到通知,但在我想使用的代码中却收不到。
我还尝试了什么:
COMMIT;
在我执行了 LISTEN <channel>;
之后命令。但这导致了预期的警告,因为我没有未结交易。PQconsumeInput(connection_);
- 它纯粹是活的NOTIFY 始终由 NOTIFY <channel>;
手动触发
代码也可以在这里看到on github (在不稳定的分支上):
类 PostgresqlDatabase(在 github 上的 sql_interface->database_interface->src 中)
这个类持有连接 PGconn 并提供类似的任务
bool listenToChannel(std::string channel);
该类的主要目的是抽象 sql 查询,这样 ROS 程序员就不必再关心它们了。
类数据库绑定(bind)
它是 ROS 和数据库功能之间的粘合剂。它包含一个 PostgresqlDatabase 对象以获取数据库连接和调用任务。
主要功能
做以下事情
PostgresqlDatabase::listenToChannel(std::string channel)
-功能PostgresqlDatabase::checkNotify(notification &no)
定期检查 NOTIFY -功能checkNotify函数,每秒触发5次左右:
/*! Checks for a received NOTIFY and returns it. */
bool PostgresqlDatabase::checkNotify(notification &no)
{
PGnotify *notify;
PQconsumeInput(connection_);
if ((notify = PQnotifies(connection_)) != NULL)
{
no.channel = notify->relname;
no.sending_pid = notify->be_pid;
no.payload = notify->extra;
PQfreemem(notify);
return true;
} else
{
no.channel = "";
no.sending_pid = 0;
no.payload = "";
PQfreemem(notify);
return false;
}
}
/*! Listens to a specified channel using the Postgresql LISTEN-function.*/
bool PostgresqlDatabase::listenToChannel(std::string channel) {
//look, if we're already listening to the channel in our list
if (std::find(channels_.begin(),channels_.end(),channel) == channels_.end() )
{
std::string query = "LISTEN " + channel;
PGresultAutoPtr result = PQexec(connection_,query.c_str());
if (PQresultStatus(*result) != PGRES_COMMAND_OK)
{
ROS_WARN("LISTEN command failed: %s", PQerrorMessage(connection_));
return false;
}
ROS_INFO("Now listening to channel \"%s\"",channel.c_str());
channels_.push_back(channel);
return true;
}
ROS_INFO("We are already listening to channel \"%s\" - nothing to be done",channel.c_str());
return true;
}
最佳答案
事实证明,连接有问题。它是用该代码创建的:
void PostgresqlDatabase::pgMDBconstruct(std::string host, std::string port,
std::string user, std::string password, std::string dbname )
{
std::string conn_info = "host=" + host + " port=" + port +
" user=" + user + " password=" + password + " dbname=" + dbname;
connection_= PQconnectdb(conn_info.c_str());
if (PQstatus(connection_)!=CONNECTION_OK)
{
ROS_ERROR("Database connection failed with error message: %s", PQerrorMessage(connection_));
}
}
使用 host=192.168.10.100, port=5432, user=turtlebot, password= , dbname=rosdb.
但是一个空的用户名不满足 PQconnectdb 的使用,由于某些解析原因,它导致它登录到数据库“turtlebot”。不幸的是,该数据库存在于我的服务器上。而且它 - 当然 - 没有在“rosdb”数据库中收到任何通知并且连接良好。
对我来说,这是多么尴尬和不幸的行为。
关于c++ - 不在 C++ 程序中使用 libpq 检索 NOTIFY,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20495210/
我正在尝试在 Ubuntu 13.10 环境中安装 pgpool-II。我正在关注 this完成它的教程。 我遇到以下错误。 configure: error: libpq is not instal
我正在使用 C++ 和 libpq(libpqxx 非常不稳定)开发高负载服务器应用程序。我在线程中使用异步查询来提高性能。但是我发现,例如,PQsendQuery("SELECT 1;SELECT
我有一个 libpq 程序,它会定期将数字插入数据库。我预计这些数字会变得相当大,它们存储在 uint64_t 类型中。我想将整数作为二进制发送到 libpq,但 Postgres 无法告诉它它是无符
这是一个愚蠢的问题。 libpq 的 PQerrorMessage 函数返回一个 char const* char const* msg = PQerrorMessage(conn); 既然它是 co
我正在为 libpq 编写一个 C++ 包装器。但是我不知道应该如何编写单元测试。我最初的 react 是将 libpq 接口(interface)包装成可模拟的东西,但这有点违背了目的。有没有人这样
我有这样的程序,可以从“C”运行。如果它们不存在,则创建一个表。 PGresult *result; conn = PG_connect(); if (conn) { if (!PG_begi
我正在编写一个用 C 封装 libpq 的库。当我执行类似 DROP SCHEMA IF EXISTS bob 的查询时,bob 不存在,libpq 输出 "NOTICE: schema "bob"
为什么下面的代码要用1.2GB的内存来执行?无论传递给 generate_series 的数量如何,我都希望内存使用量相对平稳,但它却在稳步增加。请 - 告诉我我做错了什么! if (!PQsendQ
我想知道我是否可以使用 libpq 直接从 C/C++ 进行参数化查询而不是使用字符串,如果这样做,这段代码应该是什么样子? string tblins = ""; tblins = "INSERT
所以我的 psql 表中有这个名为 rooms 的结构: Table "public.rooms"
我正在尝试将多行传递到测试表,但我无法理解它在 libpq 中究竟是如何完成的。 我找到了我认为需要的用于复制数据的命令,但没有关于如何使用它们的任何示例。 https://www.postgresq
我正在尝试安装 libpq-dev,因为 postgres 需要它,但我只收到一个错误。 pip install libpq-dev==9.4.3 Could not find a version t
我可以通过字符串操作来更新表中的记录,这有一些弱点。 所以,现在我尝试使用参数进行更新,但这并不像我想的那样。 sprintf(sql, "%s%s%s%s%s%d%s", "UPDATE "
我在使用 libpq 插入一些数据时遇到了一些困难。我有两种自定义数据类型: create type size as (width real, height real); create type ro
给定以下 libpq代码: PGconn * internalConnection = PQconnectdb("my connection string"); if (PQstatus(intern
我正在阅读 libpq 引用资料。它同时具有同步和异步方法。但是我发现了一些奇怪的事情。 当我看到PQsendQuery 函数时,它似乎发送一个查询并立即返回。我希望回调函数得到通知,但没有这样的事情
我想编写使用 Postgresql 作为 DBMS 的应用程序。要编写客户端应用程序,我需要 libpq 库和头文件吗?如果是,我将从哪里获得 libpq 库和头文件。 最佳答案 Libpq 包含在完
我想编写使用 Postgresql 作为 DBMS 的应用程序。要编写客户端应用程序,我需要 libpq 库和头文件吗?如果是,我将从哪里获得 libpq 库和头文件。 最佳答案 Libpq 包含在完
我想以非阻塞方式使用 libpq 执行 SQL 查询。因此,我希望在查询执行完毕时收到通知。 据我所知,如果我使用异步 api,libpq 会支持这一点。 使用 PQsendQuery 函数,我可以将
我遇到了 libpq 的 PQexec 功能间歇性挂起的问题连接。环顾邮件列表后,解决方案是使用异步函数 PQsendQuery/PQgetResult 并实现您自己的超时。 现在我面临的问题是 PQ
我是一名优秀的程序员,十分优秀!