TCP/IP 错误
检测到特定于 TCP/IP 的通信错误时,该软件返回 SQL30081N 消息 (-30081)。 通信子系统遇到的 TCP/IP 错误通过用于SQL30081N 消息的一组错误标记返回。
TCP/IP
下表列出了 Linux®, UNIX 和 Windows 操作系统上常见的 TCP/IP 错误符号 (errnos)。 可以在 /usr/include/sys/errno.h 文件中找到 UNIX 操作系统中 TCP/IP 错误的完整列表。 在 Linux 操作系统上,可在 /usr/include/asm/errno.h 文件中找到 TCP/IP 错误的完整列表。 对于 Windows 操作系统,请参阅 Windows 套接字错误代码。
| 错误代码 | AIX® 错误号 | HP-UX 错误号 | Solaris 错误号 | Linux 错误号 | Windows 错误号 | 描述 |
|---|---|---|---|---|---|---|
| EINTR | 4 | 4 | 4 | 4 | 指定的函数被信号中断。 | |
| EBADF | 9 | 9 | 9 | 9 | 套接字错误。 套接字可能已损坏。 | |
| EAGAIN | 11 | 11 | 11 | 11 | 资源暂时不可用。 | |
| EFAULT | 14 | 14 | 14 | 14 | 地址错误。 在连接时,使用了错误地址。 在接收时,数据被定向到不存在的或受保护的进程地址空间部分。 缓冲区无效。 |
|
| EBUSY | 16 | 16 | 16 | 16 | 资源正忙。 | |
| EINVAL | 22 | 22 | 22 | 22 | 传递至指定函数或套接字的无效自变量已关闭。 如果存在内存覆盖或缓存溢出问题,那么可能返回 EINVAL 错误。 | |
| ENFILE | 23 | 23 | 23 | 23 | 系统中打开的文件太多。 | |
| EMFILE | 24 | 24 | 24 | 24 | 每进程文件描述符表已满。 已超出进程的文件描述符/套接字数。 | |
| ENOSPC | 28 | 28 | 28 | 28 | 设备或系统表上未余下任何空间。 | |
| EPIPE | 32 | 32 | 32 | 32 | 管道中断。 | |
| EWOULDBLOCK | 54 | 246 | 11 | 11 | 在连接函数上,分配给 TCP/UDP 临时端口的范围已用完。 (某些操作系统将同一错误返回为 EAGAIN。) | |
| ENOTSOCK | 57 | 216 | 95 | 88 | 对非套接字执行了套接字操作。 | |
| ENOPROTOOPT | 61 | 220 | 99 | 92 | 选项未知。 | |
| EADDRINUSE | 67 | 226 | 125 | 98 | 10048 | 已经在使用指定的地址。 建立该连接的先前进程可能异常终止或未正确清除。 |
| EADDRNOTAVAIL | 68 | 227 | 126 | 99 | 不能从本地系统获取指定的主机名或 IP 地址。 | |
| ENETDOWN | 69 | 228 | 127 | 100 | 网络已停止。 | |
| ENETUNREACH | 70 | 229 | 128 | 101 | 没有任何至网络或主机的路由可用。 | |
| ENETRESET | 71 | 230 | 129 | 102 | 网络在重置时删除了该连接。 | |
| ECONNRESET | 73 | 232 | 131 | 104 | 10054 | 合作伙伴已重置连接。 |
| ENOBUFS | 74 | 233 | 132 | 105 | 10055 | 系统中没有足够的内存或资源可用来完成调用。 |
| EISCONN | 75 | 234 | 133 | 106 | 已连接该套接字。 | |
| ENOTCONN | 76 | 235 | 134 | 107 | 未连接套接字。 | |
| ETIMEDOUT | 78 | 238 | 145 | 110 | 10060 | 连接已超时。 |
| ECONNREFUSED | 79 | 239 | 146 | 111 | 10061 | 连接被拒绝。 如果您尝试连接至数据库,请检查服务器上的数据库管理器和 TCP/IP 协议支持是否已成功启动。 如果指定了 SOCKS 协议支持,那么还必须确保 SOCKS 服务器上的 TCP/IP 协议支持已成功启动。 |
| EHOSTDOWN | 80 | 241 | 147 | 112 | 主机已当机。 | |
| EHOSTUNREACH | 81 | 242 | 148 | 113 | 没有任何至主机的可用路由。 | |
| SOCECONNABORTED | 72 | 10053 | 软件已关闭连接 如果客户机应用程序上报告了错误,而该客户机应用程序使用 ODBC/CLI 连接到 DB2 UDB 服务器,那么禁用 Db2 CLI 超时:
|
|||
| WSAEINTR | 10004 | 连接已被客户机关闭。 对于 Db2 z 系统,请参阅技术说明 SQL30081n | ||||
| WSAEHOSTUNREACH | 81 | 113 | 10065 | 没有指向主机的路由 对于尝试连接到 Linux 服务器的 Windows 客户机,请取消设置 Linux 服务器上的防火墙以允许从客户机通过连接。 |
注: 可在 winsock2.h 文件中找到 Windows 操作系统中 TCP/IP 错误的完整列表。 如果未安装开发环境,那么 winsock2.h 文件未安装在您的操作系统上。