我正在尝试下载一个远程元数据文件(.torrent),使用的是只使用libtorrent-rasterbar 0.16.13的非DHT跟踪器行为。
不幸的是,我得到了很多peer_disconnected错误;从我的程序中播种并通过客户端下载,比如BT或QBittorrent工作。
我正在使用十六进制编码的散列,我不知道这是否是问题所在,因为libtorrent-rasterbar似乎同时支持Magnet中的十六进制和Base32散列。
请记住,我已经有一个跟踪器,我不想使用DHT,但磁铁只是下载远程洪流到我的本地文件系统。
这是我的AddMagnetLink代码:
RESULT SessionManager::addMagnetLink(const QString& info_hash,
const QString& torrentPath,
libtorrent::torrent_handle &thndl)
{
try
{
libtorrent::add_torrent_params tp;
boost::filesystem::path path(torrentPath.toStdWString());
std::string url;
url.append("magnet:?xt=urn:btih:");
url.append(info_hash.toStdString());
url.append("&tr=udp://tracker.publicbt.com:80");
qDebug() << "Using magnet URI: "<< url.c_str();
qDebug() << "Save path is " << tp.save_path.c_str();
tp.paused = false;
tp.auto_managed = true;
tp.save_path = path.string();
libtorrent::error_code ec;
thndl = libtorrent::add_magnet_uri(*_lt_session, url, tp,ec);
qDebug() << "add_torrent error_code = " << ec.message().c_str();
qDebug() << "Has metadata";
}
catch (std::exception& e)
{
qWarning() << "(!) Exception thrown: " << e.what();
return NKT_E_FAIL;
}
return S_OK;
}示例输出:
peer_disconnected_alert: 8061b09e2229111ed93a48080835e371c89c1111 peer (1xx.1xx.3x.x5, libtorrent 0.16.0) disconnecting: [libtorrent error] connected to ourselves
peer_disconnected_alert: 8061b09e2229111ed93a48080835e371c89c1111 peer (1xx.1xx.3x.x5, Unknown) disconnecting: [asio.misc] End of file我在我的本地局域网里,在我的机器之间尝试这个。
编辑:(添加更多数据)
令人惊讶的是,只发生在元数据传输中,,因为我已经尝试了正常的洪流文件和它的工作(种子和下载)。我启用了metadata_transfer和ut_metadata扩展;还启用了DHT、PEX、UPNP、NATPMP和本地发现。似乎在传输元数据方面存在一些问题。
提前谢谢。,
发布于 2014-03-19 16:43:18
跟踪器只会报告您的公共IP和端口。
如果您有两个客户端在同一个网络上,具有相同的外部IP,并且没有映射端口(使用UPnP或NAT),那么它们将无法通过跟踪器找到彼此。
您可以启用本地对等点发现(本地服务发现),让对等方在本地网络上宣传他们的存在,或者通过启用UPnP和NAT(假设您的路由器支持此功能),确保它们都可以通过外部IP访问。你可能会想让两者都能。
您发布的断开连接消息表明,对等方只能看到自己。
https://stackoverflow.com/questions/22471139
复制相似问题