- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在我的 C++ 应用程序中,我将::bind() 用于 UDP 套接字,但在极少数情况下,由于连接丢失而重新连接后,即使重试多次,我也会收到错误号 EADDRINUSE。将接收数据的 UDP 连接的另一端重新连接正常,正在等待 select() 指示有内容要读取。
我认为这意味着本地端口正在使用中。如果为真,我怎么会泄露本地端口,以便另一端连接到它?这里真正的问题是另一端连接正常并且正在等待,但这一端卡在 EADDRINUSE 上。
--编辑--
这是一个代码片段,显示我已经在我的 TCP 套接字上执行 SO_REUSEADDR,而不是在我遇到问题的这个 UDP 套接字上:
// According to "Linux Socket Programming by Example" p. 319, we must call
// setsockopt w/ SO_REUSEADDR option BEFORE calling bind.
// Make the address is reuseable so we don't get the nasty message.
int so_reuseaddr = 1; // Enabled.
int reuseAddrResult
= ::setsockopt(getTCPSocket(), SOL_SOCKET, SO_REUSEADDR, &so_reuseaddr,
sizeof(so_reuseaddr));
这是我完成后关闭 UDP 套接字的代码:
void
disconnectUDP()
{
if (::shutdown(getUDPSocket(), 2) < 0) {
clog << "Warning: error during shutdown of data socket("
<< getUDPSocket() << "): " << strerror(errno) << '\n';
}
if (::close(getUDPSocket()) < 0 && !seenWarn) {
clog << "Warning: error while closing data socket("
<< getUDPSocket() << "): " << strerror(errno) << '\n';
}
}
最佳答案
是的,这很正常。您需要在绑定(bind)之前设置套接字 SO_REUSEADDR
,例如在 *nix 上:
int sock = socket(...);
int yes = 1;
setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, &yes, sizeof(yes));
如果您有通过创建新套接字重新连接的单独代码,也将其设置在那个套接字上。这只是与操作系统的默认行为有关——损坏的套接字上的端口会保持失效一段时间。
[编辑] 这不应适用于 UDP 连接。也许您应该发布用于设置套接字的代码。
关于c++ - 为什么 bind() 有时会在另一端连接时给出 EADDRINUSE?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10384575/
我试图挽救在bind语句中两次尝试使用相同地址时ruby引发的异常。 documentation不是很有帮助。 这就是我想要的: require 'socket' s = UDPSocket.new(
假设您有 2 个 ASP.NET 核心项目;一个 API 和一个网站。我想使用以下 url 在本地(同时,因为该网站使用 api)处理这些问题:devapi.website.com 和 dev.web
我在 Android 上遇到 TCP 服务器问题。服务器必须管理多个传入连接,目前来自同一用户。我收到以下错误: 02-06 17:37:44.800: W/System.err(9859): jav
我已经在Ubuntu 10.04上配置并安装了ouchdb 1.6.1。在配置和安装时说成功完成了。但是,当我启动沙发床时,它给了我错误。 首次启动时。 Apache CouchDB 1.6.1 (L
IOLib 允许创建一个被动套接字来监听客户端的连接,在调用 listen 之前,我们需要调用 (bind-address) 将套接字绑定(bind)到指定的地址/端口。 嗯,问题是我第一次把sock
我正在做套接字编程。我引用了以下链接: http://examples.javacodegeeks.com/android/core/socket-core/android-socket-exampl
我开始使用 [cloud9][1] 并尝试托管我的 nodejs 应用程序。当我尝试运行我的应用程序时,它抛出以下错误: 重要:使用 process.env.PORT 作为端口,使用 process.
尝试构建实验性 CRUD 应用程序,但连接到数据库时出现问题。 使用 mLab 免费数据库。无论指定哪个端口,错误都是 EADDRINUSE::: 如何关闭可能使用这些端口的所有 Node 实例? 最
我有一个简单的 gulpfile.js: var gulp = require('gulp'); var sass = require('gulp-sass'); var connect
我有来自 CSgo roullete 的脚本。当我尝试运行它时显示此错误 errno: 'ECONNREFUSED', syscall: 'connect', address: '
这是我的 Gruntfile: module.exports = function(grunt) { grunt.initConfig({ pkg: grunt.file.readJSON
在我的 C++ 应用程序中,我将::bind() 用于 UDP 套接字,但在极少数情况下,由于连接丢失而重新连接后,即使重试多次,我也会收到错误号 EADDRINUSE。将接收数据的 UDP 连接的另
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicates: Releasing bound ports on process exit difference betw
下面是我的test fixture的精华—— SetUp() { g_listen_sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
我使用 Ubuntu 20.04、Nodemon 2.0.4、Node 14.9.0 和 Express 4.17.1。每次保存我的代码时,我都会收到此错误: events.js:291
我正在开发一个 google glass/android 应用程序。它是一个视频流应用程序,具有服务器/客户端设置,其中电话/眼镜是服务器,并将 pc 与播放视频的 session 描述 Hook 。
我有一个系统,其中在后台运行的服务器进程由控制程序控制。 控制程序是一个简单的脚本,它执行一个命令然后退出。对于 Run 命令,它会创建一个新的服务器进程;对于其他(包括关机),它通过保留的控制端口将
好吧,这真的很奇怪,我在实现一个简单的服务器时得到了 EADDRINUSE, 我已经更改了端口 寻找已经运行的node js进程 尝试使用 killall -9 node 和 root 通过sudo
我有一个使用express的测试应用程序,它在server.listen(80)上崩溃:错误:监听EADDRINUSE。我尝试使用 killall -9 node 终止所有 Node 进程,但没有进程
如果我使用端口 80 运行服务器,并且我尝试使用 XMLHttpRequest我收到此错误:错误:监听 EADDRINUSE 如果我想在端口 80 上运行服务器时发出请求,为什么 NodeJS 会出现
我是一名优秀的程序员,十分优秀!