Socket Error #11002错误有大神遇到过吗?怎么解决

win7电脑安装的客户端,点击测试连接时,客户端显示连接失败,在对应文件的执行日志中发现上传数据
时提示Socket Error #11002错误

3个回答

Socket error 11002 - Non-authoritative host not found
非认证主机未找到 有可能是网络问题 例如延时过大 你把连接超时的时间设置成默认 或者 一个比较长的时间试试

没有找到相应的主机,链接主机的IP有问题吧,你ping一下看看呢

可能网络延迟,用户换台电脑就正常了

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Socket Error #10053错误有大神遇到过吗?怎么解决
win7电脑安装的客户端,点击测试连接时提示连接失败,在执行日志中看到Socket Error #10053错误,代码没问题
用socket写蓝牙通信的时候遇到accept不阻塞的情况
## socket中accept不阻塞的问题,网上的方法不起作用 最近比赛需要,要用到蓝牙通信。我打算用套接字实现,但是在写套接字的程序的时候,accept总是不阻塞,检查发现错误码10014,但是长度也没问题,实在不知道怎么回事了。时间比较急,那位大神懂行的还请帮忙指点一下,感激不尽! ``` #include <iostream> #include <cstring> #include <winsock2.h> #pragma comment(lib,"Ws2_32.lib") #include <ws2bth.h> #include <bthsdpdef.h> #include <bluetoothapis.h> #pragma comment(lib, "bthprops.lib") int main() { WSADATA wsaData; int err = WSAStartup(MAKEWORD(2, 2), &wsaData) ; std::cout <<"startup return: " << err << std::endl; SOCKET sock = socket(AF_BTH, SOCK_STREAM, BTHPROTO_RFCOMM); if (sock == SOCKET_ERROR) { std::cout << "sock define error !" << std::endl; } SOCKADDR_BTH bt_addr; bt_addr.addressFamily = AF_BTH; bt_addr.port = BT_PORT_ANY; bt_addr.btAddr = 0; bt_addr.serviceClassId = GUID_NULL; std::cout << WSAGetLastError() << std::endl; err = ::bind(sock, (sockaddr*)&bt_addr, sizeof(bt_addr)); std::cout << WSAGetLastError() << std::endl; std::cout << "bind return :" <<err<< std::endl; int l = sizeof(bt_addr); std::cout <<"get sockname return: "<< getsockname(sock, (sockaddr*)&bt_addr, &l) << std::endl; err = listen(sock, 1); std::cout << "lis_return: " << err << std::endl; SOCKADDR clntAddr; int l1 = sizeof(SOCKADDR);; std::cout << l1 << std::endl; SOCKET clntSock = accept(sock, (SOCKADDR*)&clntAddr, &l1); if (err = WSAGetLastError()) { std::cout << "阻塞出错。" << std::endl; std::cout << "错误码:" << err << std::endl; } closesocket(clntSock); closesocket(sock); WSACleanup(); return 0; } ```
关于socket编程问题求大神解决
我写了一个简单的socket程序手机那边发个数据PC这边接收。写在DEV里时可以正常的接收到数据可是写在vs2010的一个按钮里就接收不到数据了,怎么回事啊,急求啊 SOCKET socket1; WSADATA wsaData; if (WSAStartup(MAKEWORD(2,1),&wsaData)) //调用Windows Sockets DLL { AfxMessageBox(_T("Winsock无法初始化!")); WSACleanup(); return; } struct sockaddr_in local; struct sockaddr_in from; int fromlen =sizeof(from); local.sin_family=AF_INET; local.sin_port=htons(27012); ///监听端口 local.sin_addr.s_addr=INADDR_ANY; ///本机 socket1=socket(AF_INET,SOCK_DGRAM,0); bind(socket1,(struct sockaddr*)&local,sizeof(local)); char buffer[1024]="\0"; if (recvfrom(socket1,buffer,sizeof(buffer),0,(struct sockaddr*)&from,&fromlen)!=SOCKET_ERROR) { AfxMessageBox(_T("接收到来自远程客户端额数据!")); } closesocket(socket1);
项目中使用FTP的方式过慢,还经常出现421错误跟Software caused connection abort: socket write error错误,有些时候上传就特别的慢,有些时候就是飞速了
![图片说明](https://img-ask.csdn.net/upload/201911/30/1575082120_116111.jpg) 就像这图片中描述的一样,一直在等待状态,等路径返回的时候,通过访问图片就显示图片损坏,这问题困扰我太久了,有大神支招吗?从百度找的我都试过了,一直找不到合适的解决方案 ![图片说明](https://img-ask.csdn.net/upload/201912/04/1575428188_620666.jpg) 这是FTP代码,或者我想知道除了FTP,OSS之外还有什么方式可以上传文件至服务器?
[新手]socket 10060 各位大神帮帮我我这个小菜鸟(刚玩CSDN)
自己电脑可以,换了同学电脑就10060 /*服务端*/ #include <stdio.h> #include <WinSock2.h> #include <windows.h> #include <process.h> #pragma comment (lib,"Ws2_32.lib") void main() { //初始化socket WSADATA wsaData; WSAStartup(MAKEWORD(2,2),&wsaData); //创建socket SOCKET listenSocket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); if (listenSocket == SOCKET_ERROR){ printf("Error->socket(s)\n"); exit(0); } printf("OK->socket(s)\n");; //设置服务器协议,IP地址,端口 SOCKADDR_IN ServAddr; ServAddr.sin_family = AF_INET; ServAddr.sin_addr.s_addr = inet_addr("172.30.84.37"); ServAddr.sin_port = htons(9999); //绑定(SOCKADDR_IN->SOCKET) if (bind(listenSocket, (SOCKADDR*)&ServAddr, sizeof(ServAddr)) == SOCKET_ERROR) { printf("Error->bind(s)\n"); exit(0); } printf("OK->bind(s)\n"); //监听端口 if (listen(listenSocket, 10) == SOCKET_ERROR) { printf("Error->listen(s)\n"); exit(0); } printf("OK->listen(s)\n"); //确认接收请求,知道成功 SOCKET acceptSocket; while (true) { if ((acceptSocket=accept(listenSocket, (SOCKADDR*)NULL, NULL))== SOCKET_ERROR) { printf("Error->accept(s)\n"); continue; } break; } printf("OK->accept(s)\n"); //发送命令 char sendbuf[100]; while (scanf("%s", sendbuf)) { if (strcmp(sendbuf, "Bye") == 0) break; send(acceptSocket, sendbuf, strlen(sendbuf) + 1, 0); } closesocket(acceptSocket); WSACleanup(); closesocket(listenSocket); } /*客户端*/ #include <stdio.h> #include <WinSock2.h> #include <cstring> #include <windows.h> #include <process.h> #pragma comment (lib,"Ws2_32.lib") void main() { //初始化 WSADATA wsaData; WSAStartup(MAKEWORD(2, 2), &wsaData); //创建socket SOCKET connectSocket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); if (connectSocket==SOCKET_ERROR) { printf("Error->socket(c)\n"); exit(0); } printf("OK->socket(c)\n"); //设置服务器协议,IP地址,端口 SOCKADDR_IN ServAddr; ServAddr.sin_family = AF_INET; ServAddr.sin_addr.s_addr = inet_addr("172.30.84.37"); ServAddr.sin_port = htons(9999); //连接服务器 if (connect(connectSocket, (SOCKADDR*)&ServAddr, sizeof(ServAddr)) == SOCKET_ERROR) { printf("Error->connect(c)\n"); exit(0); } printf("OK->connect(c)\n"); //接收命令 while (true) { char recvbuf[100]; int n = recv(connectSocket, recvbuf, 100, 0); if (n <= 0) break; printf("%d\n", n); recvbuf[n] = 0; printf("%s\n", recvbuf); } ::Sleep(10 * 1000); WSACleanup(); closesocket(connectSocket); }
c++,socket编程实现简易聊天系统,客户端一直连不上服务端,connect返回错误10014
客户端 ``` //建立线程 DWORD WINAPI ConnectThreadFunc(LPVOID pParam) { //初始化 WSAData wsData; if (!AfxSocketInit(&wsData)) { AfxMessageBox(_T("Socket 库初始化出错!")); return false; } CMFCApplication1View *pChatClient = (CMFCApplication1View*)pParam; ASSERT(pChatClient != NULL); //新建一个socket pChatClient->ConnectSock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); if (INVALID_SOCKET==pChatClient->ConnectSock ) { AfxMessageBox(_T("创建socket失败!")); return FALSE; } AfxMessageBox(_T("成功创建socket")); //获取端口 CString ServeIp; pChatClient->GetDlgItemText(IDC_SERVEID_INPUT, ServeIp); //取服务端的IP地址 int SPort = pChatClient->GetDlgItemInt(IDC_SERVEPORT_INPUT); //获取端口 if (SPort <= 0 || SPort > 65535) { AfxMessageBox(_T("请输入合法的端口:1-65535")); goto _End; } AfxMessageBox(_T("端口合法")); //将IP转换 char AddrIp[16] = { 0 }; //窄字节 USES_CONVERSION; strcpy_s(AddrIp, 16, T2A(ServeIp)); // T2A:宏,进行字符串的转换 //将服务器的信息放入通用套接字中 sockaddr_in server; server.sin_family = AF_INET; server.sin_port = htons(SPort); server.sin_addr.s_addr = inet_addr("192.168.73.1"); //客户端连接服务端 //将server传给connect if ( SOCKET_ERROR == connect(pChatClient->ConnectSock, (struct sockaddr*)&server, sizeof(struct sockaddrr*)) ) { /* char ErrorInfo[256] = { 0 }; //创建数组存储错误信息 sprintf_s(ErrorInfo, "Creat Faile : %d", GetLastError()); //把错误信息写入数组 AfxMessageBox((CString)ErrorInfo); */ AfxMessageBox(_T("连接失败!")); goto _End; } pChatClient->MsgShow(_T("服务器连接成功!")); while (TRUE) { if (SOCKERT_Select(pChatClient->ConnectSock,100,TRUE)) { char szBuf[MAX_BUF_SIZE] = { '0' }; //缓冲区 int iRet = recv(pChatClient->ConnectSock, szBuf, MAX_BUF_SIZE, 0); //recv()用来接收远程主机通过套接字sockfd发送来的数据, //并把这些数据保存到数组buf中 if (iRet > 0) { pChatClient->MsgShow((CString)szBuf); } else { pChatClient->MsgShow(_T("连接异常,请重新连接!")); break; } } Sleep(100); } _End: closesocket(pChatClient->ConnectSock); return TRUE; } ``` 服务端 ``` SOCKET ComSock; //用于发送消息 //查看客户端是否发来消息,并快速返回 BOOL SOCKERT_Select(SOCKET Socket, int TimeOut, BOOL bRead) { fd_set fdset; //通知执行了select()的进程哪一socket或文件发生了可读或可写事件 //long类型的数组,每一个数组元素都能与一打开的文件句柄建立联系 timeval tv; //判断是否超时,用于select()函数 FD_ZERO(&fdset); //清空集合中所有的元素 FD_SET(Socket, &fdset); //设置hSocket,使集合包含hSocket,即建立联系 TimeOut = TimeOut > 1000 ? 1000 : TimeOut; tv.tv_sec = 0; //秒数 tv.tv_usec = TimeOut; //微秒数 int iRet = 0; if (bRead) { //select()测试指定的fd可读?可写?有异常条件待处理? //即对socket操作 iRet = select(0, &fdset, NULL, NULL, &tv); } //读 else { iRet = select(0, NULL, &fdset, NULL, &tv); } //写 if (iRet <= 0) { //返回错误时 return FALSE; } else if (FD_ISSET(Socket, &fdset)) {//返回处于就绪状态并且已经包含在fd_set结构中的描述字总数 return TRUE; } return FALSE; //返回零时(超时返回零) } //通过线程来开启服务器,因为accept是阻塞的 //线程函数 DWORD WINAPI LisenThreadFunc(LPVOID pParam) { //LPVOID :32位的无类型的指针,在使用的时候再强制转换成需要的类型 CMFCApplication1View *pChatClient = (CMFCApplication1View*)pParam; //强制转换 ASSERT(pChatClient != NULL); //保证指针不为空 //断言函数,表达式为假则退出程序,为真继续执行 //用socket函数创建一个socket,用于监听 //成功则返回一个socket pChatClient->ListenSock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); if (pChatClient->ListenSock == INVALID_SOCKET) { AfxMessageBox(_T("创建socket失败!")); return 0; } //绑定,将 ListenSock 绑定在本地的一个ip和端口上 //1、动态获取用户输入的端口 int Port = pChatClient->GetDlgItemInt(IDC_LISTENPORT_INPUT); if (Port <= 0 || Port > 65535) { AfxMessageBox(_T("请输入合适的端口:1-65535")); goto _End; } //2、建立通用套接字 sockaddr_in service; //一种通用的套接字地址。用来建立所需信息,最后使用类型转换 //一般用于bind、connect、recvfrom、sendto等函数的参数 service.sin_family = AF_INET; //协议族 service.sin_addr.s_addr = inet_addr("127.0.0.1"); //获取本机所有可能得到的ip地址 service.sin_port = htons(Port); //传递端口 //htons:将主机字节顺序转换为网络字节顺序 //3、利用bind进行绑定 if (bind(pChatClient->ListenSock, (sockaddr*)&service, sizeof(sockaddr_in)) == SOCKET_ERROR) { AfxMessageBox(_T("绑定失败!")); goto _End; } AfxMessageBox(_T("绑定成功!")); //监听 if (listen(pChatClient->ListenSock, 4) == SOCKET_ERROR) { AfxMessageBox(_T("监听失败!")); goto _End; } //服务器已搭建完毕,开始进行消息监测 while (TRUE) { if (SOCKERT_Select(pChatClient->ListenSock, 1000, TRUE)) {//若有消息 sockaddr_in ClientSocket; int len = sizeof(sockaddr_in); //返回客户端(即对方)的IP地址和端口 SOCKET ComSock = accept(pChatClient->ListenSock, (struct sockaddr*)&ClientSocket, &len); if (ComSock == INVALID_SOCKET) { //若没有收到信息 continue; } //当要进行信息交互时,再建一个新线程来进行信息交互 // CMFCApplication1View *ClientCopy; HANDLE iTtem; iTtem = CreateThread(NULL, 0, ClientThreadProc, pChatClient, CREATE_SUSPENDED, NULL); pChatClient->comThread = iTtem; ResumeThread(iTtem); //恢复线程的执行 } Sleep(100); } _End: closesocket(pChatClient->ListenSock); //强制关闭socket return TRUE; } ``` 由于最近刚学socket,实在不知道怎么改了,请各位大神帮我康康,谢谢大家!(呜呜呜我是新手么的c币)
java下载zip文件socket write error
今天用java下载zip文件的时候老是出现如下错误,从网上找了错误原因,感觉答案解决不了我的问题: ClientAbortException: java.net.SocketException: Connection reset by peer: socket write error at org.apache.catalina.connector.OutputBuffer.realWriteBytes(OutputBuffer.java:413) at org.apache.tomcat.util.buf.ByteChunk.append(ByteChunk.java:342) at org.apache.catalina.connector.OutputBuffer.writeBytes(OutputBuffer.java:438) at org.apache.catalina.connector.OutputBuffer.write(OutputBuffer.java:426) at org.apache.catalina.connector.CoyoteOutputStream.write(CoyoteOutputStream.java:91) at java.io.BufferedOutputStream.flushBuffer(BufferedOutputStream.java:82) at java.io.BufferedOutputStream.write(BufferedOutputStream.java:126) 代码如下: File file = new File("d:/zhangrm/aa/test.zip"); response.reset(); response.setHeader("Content-Disposition", "attachment;filename=" .concat(String.valueOf(URLEncoder.encode(file.getName(), "UTF-8")))); response.setContentType("application/x-msdownload"); response.setContentLength((int) file.length()); try { InputStream inputStream = new FileInputStream(file); BufferedInputStream buffInput = new BufferedInputStream(inputStream); //写文件 byte[] b = new byte[1024]; long k = 0; OutputStream outputStream = response.getOutputStream(); BufferedOutputStream buffOutput=new BufferedOutputStream(outputStream); while (k < file.length()) { int j = buffInput.read(b, 0, 1024); k += j; buffOutput.write(b, 0, j); } buffOutput.flush(); inputStream.close(); buffInput.close(); outputStream.close(); buffOutput.close(); // deleteFile(pathTo); //deleteFile(Const.ZIPFILENAME); } catch (IOException e) { log.error("数据下载失败!"); e.printStackTrace(); } 望大神帮忙解决下!!!小妹不胜感激!
Android中连接蓝牙打印机没有UUID,能配对,但是socket不能连接 怎么办啊 各位大神!
### 1、Android中连接蓝牙打印机没有UUID,能配对,但是socket不能连接 ## - ### 2、网上找了很多都是说用这个UUID : ` SPP_UUID = "00001101-0000-1000-8000-00805F9B34FB"` ,可是还是不行。 ## - ### 3、蓝牙打印机型号是 Zebra ZD420 ## - ### 4、通过配对的设备信息 BluetoothDevice ` device.getUuids() ` 获取的UUID为空 ## - ### 5、连接方法 ``` java public void connect(final String mac, final Handler handler) { new Thread(new Runnable() { @Override public void run() { try { socket = device.createRfcommSocketToServiceRecord(UUID.fromString(BLEConfig.SPP_UUID)); if (socket != null) { System.out.println("socket不为空:开始连接..."); handler.sendEmptyMessage(CONN_START); socket.connect(); out = new PrintStream(socket.getOutputStream()); in = new BufferedReader(new InputStreamReader(socket.getInputStream())); if (socket.isConnected()) { System.out.println("连接成功..."); handler.sendEmptyMessage(CONN_SUCCESS); ReceiveInfoThread.start(); } else { System.out.println("连接失败..."); handler.sendEmptyMessage(CONN_ERROR); } } } catch (IOException e) { e.printStackTrace(); System.out.println("打印机连接异常:"+e.getMessage()); try { socket.close(); } catch (IOException e1) { e1.printStackTrace(); } handler.sendEmptyMessage(CONN_ERROR); } } }).start(); } ```
Nginx An error occurred 问题如何解决
首先我的项目是CentOS7+Nginx+uWSGI+Flask部署 在运行python3 hello.py 测试的时候出现Nginx An error occurred ![图片说明](https://img-ask.csdn.net/upload/201908/09/1565352601_348182.jpg) 我的uwsgi.ini文件内容是 ``` [uwsgi] socket = 127.0.0.1:9000 #监听socket端口,uwsgi启动使用的地址和端口 master = true module = run #python调用的模块 chdir = /www wsgi-file = /www/hello.py #python启动程序文件 callable = app #程序中启动的app变量名 processes = 4 #uwsgi进程数 threads = 2 #uwsgi线程数 pythonpath = /www #项目目录 stats = %(chdir)/uwsgi/uwsgi.status pidfile= %(chdir)/uwsgi/uwsgi.pid daemonize = /var/log/uwsgi.log #日志路径 ``` 我的nginx的配置文件内容是 ``` server { listen 80; server_name 139.105.102.000; #公网ip,站点url index index.php index.html index.htm;#设置站点默认文档 #charset koi8-r; #access_log logs/host.access.log main; location / { include uwsgi_params; # 导入uwsgi配置 uwsgi_pass 127.0.0.1:9000;# 转发端口,需要和uwsgi配置当中的监听端口一致 uwsgi_param UWSGI_CHDIR /www; # 项目根目录 #uwsgi_param UWSGI_SCRIPT www.wsgi; #入口文件,即wsgi.py相对于项目根目录的位置,“.”相当于一层目录 } ``` 我的项目放在www文件夹 uwsgi.ini,测试文件py也都放在www文件夹 由于自己是小白,摸索了好几天,希望大神看一下
tomact debug报错,哪位大神有碰到过这种问题
FATAL ERROR in native method: JDWP No transports initialized, jvmtiError=AGENT_ERROR_TRANSPORT_INIT(197) ERROR: transport error 202: gethostbyname: unknown host ERROR: JDWP Transport dt_socket failed to initialize, TRANSPORT_INIT(510) JDWP exit error AGENT_ERROR_TRANSPORT_INIT(197): No transports initialized [../../../src/share/back/debugInit.c:690] 这个问题搞得我没睡好觉,什么都没问题第二天启动debug就报这个错,启动是没问题,但debug就会报错。hosts文件也没动过,从官网考了一段代码进去还是这样,有哪位大神碰到解决过这种问题。求助!!!
PLC TCP通信报错10061
电脑通过网口连接三菱PLC,可以ping的通,但用以下代码就一直报10061的错误: ``` int main() { // initialize winsock WORD wVer = MAKEWORD(1, 1); // version NO:1.1, #include <WINSOCK.H> WSADATA wData; int err = WSAStartup(wVer, &wData); if (err) { printf("cannot initialize WinSock\n"); return 1; } // 建立SOCKET通信 SOCKET s = 0; s = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP); struct sockaddr_in server; server.sin_family = AF_INET; server.sin_port = htons(1); // ASA standard port server.sin_addr.s_addr = inet_addr("192.168.3.250"); // 建立CONNECT连接 int i = connect(s, (sockaddr *)&server, sizeof(sockaddr_in)); if (i < 0) // #define SOCKET_ERROR (-1) { printf("connect - error %d\n", WSAGetLastError()); closesocket(s); WSACleanup(); return 1; } return 0; } ``` 运行到connect指令就会返回10061的错误码,在cmd里ping 192.168.3.250是没问题的,但是htons( )里的端口号我不能确定,也不知道三菱PLC有没有默认的端口号,试了很多,除了给0会报10049的错误外,其它都是报10061。 麻烦那位大神帮忙看一下,头大,试了一天了
wolfssl 移植到liteos下执行到wolfSSL_connect时报错:wolfSSL error occurred, error = 111 line:11221 file:src/ssl.c
wolfssl-4.2.0-stable 移植到liteos后,使用https,执行到wolfSSL_connect出错,追踪底层代码,发现在执行SendClientKeyExchange函数时发生错误, log打印: ``` into wolfSSL_connect.... wolfSSL error occurred, error = 111 line:11221 file:src/ssl.c error = -111, mp_read error state sslConnect failed! ``` wolfssl源码: ``` case FIRST_REPLY_FIRST : #ifdef WOLFSSL_TLS13 printf("into WOLFSSL_TLS13 ..\n"); if (ssl->options.tls1_3) return wolfSSL_connect_TLSv13(ssl); #endif if (!ssl->options.resuming) { if ( (ssl->error = SendClientKeyExchange(ssl)) != 0) { WOLFSSL_ERROR(ssl->error); //Error occurred !! return WOLFSSL_FATAL_ERROR; } WOLFSSL_MSG("sent: client key exchange"); } ssl->options.connectState = FIRST_REPLY_SECOND; WOLFSSL_MSG("connect state: FIRST_REPLY_SECOND"); FALL_THROUGH; ``` 我的例程函数源码: ``` connection *sslConnect (void) { connection *c; c = malloc (sizeof (connection)); c->sslHandle = NULL; c->sslContext = NULL; c->socket = tcpConnect (); if (c->socket) { // Register the error strings for libcrypto & libssl #if USE_OLD_OPENSSL_API //旧版本使用 wolfSSL_load_error_strings (); #else OPENSSL_init_ssl(OPENSSL_INIT_LOAD_SSL_STRINGS | OPENSSL_INIT_LOAD_CRYPTO_STRINGS, NULL); #endif // Register the available ciphers and digests #if USE_OLD_OPENSSL_API //旧版本使用 wolfSSL_library_init (); wolfSSL_add_all_algorithms(); #else OPENSSL_init_ssl(0, NULL); OPENSSL_init_crypto(OPENSSL_INIT_ADD_ALL_CIPHERS | OPENSSL_INIT_ADD_ALL_DIGESTS, NULL); #endif // New context saying we are a client, and using SSL 2 or 3 c->sslContext = wolfSSL_CTX_new (wolfSSLv23_client_method ()); if (c->sslContext == NULL) { wolfSSL_ERR_dump_errors_fp (stderr); if(c) free(c); return NULL; } /* Load client certificates into WOLFSSL_CTX */ int ret; char buffer[128] = {0}; //设置不校验证书,Liteos上进行校验就会通不过(底层不兼容) wolfSSL_CTX_set_verify(c->sslContext,SSL_VERIFY_NONE,NULL); #if 1 ret = wolfSSL_CTX_load_verify_locations(c->sslContext, CA_CERT_FILE, NULL); if (ret != SSL_SUCCESS) { wolfSSL_ERR_dump_errors_fp (stderr); int err = wolfSSL_get_error(c->sslHandle, ret); printf("error = %d, %s\n", err, wolfSSL_ERR_error_string(err, buffer)); fprintf(stderr, "ERROR: failed to load %s, please check the file.\n",CA_CERT_FILE); return NULL; } //加载buffer使用:wolfSSL_CTX_load_verify_buffer ret = wolfSSL_CTX_use_certificate_file(c->sslContext, CLI_CERT_FILE,WOLFSSL_FILETYPE_PEM); if(ret != WOLFSSL_SUCCESS) { wolfSSL_ERR_dump_errors_fp (stderr); int err = wolfSSL_get_error(c->sslHandle, ret); printf("error = %d, %s\n", err, wolfSSL_ERR_error_string(err, buffer)); fprintf(stderr, "ERROR: failed to load %s, please check the file.\n",CLI_CERT_FILE); return NULL; } ret = wolfSSL_CTX_use_PrivateKey_file(c->sslContext, CLI_KEY_FILE,WOLFSSL_FILETYPE_PEM); if(ret != WOLFSSL_SUCCESS) { wolfSSL_ERR_dump_errors_fp (stderr); int err = wolfSSL_get_error(c->sslHandle, ret); printf("error = %d, %s\n", err, wolfSSL_ERR_error_string(err, buffer)); fprintf(stderr, "ERROR: failed to load %s, please check the file.\n",CLI_KEY_FILE); return NULL; } #endif // Create an SSL struct for the connection c->sslHandle = wolfSSL_new (c->sslContext); if (c->sslHandle == NULL) { wolfSSL_ERR_dump_errors_fp (stderr); if(c) free(c); return NULL; } /*---#新添加------------------------------------------------------------*/ /* keep handshakre resources for re-using WOLFSSL obj */ wolfSSL_KeepArrays(c->sslHandle); if(wolfSSL_KeepHandshakeResources(c->sslHandle)) { /* err_sys("SSL_KeepHandshakeResources failed"); */ if(c) free(c); return NULL; } if (wolfSSL_use_certificate_file(c->sslHandle, CLI_CERT_FILE, WOLFSSL_FILETYPE_PEM) != WOLFSSL_SUCCESS) { /*err_sys("can't load client cert file, " "Please run from wolfSSL home dir");*/ if(c) free(c); return NULL; } if (wolfSSL_use_PrivateKey_file(c->sslHandle, CLI_KEY_FILE, WOLFSSL_FILETYPE_PEM) != WOLFSSL_SUCCESS) { /*err_sys("can't load client key file, " "Please run from wolfSSL home dir");*/ if(c) free(c); return NULL; } /*---#------------------------------------------------------------*/ // Connect the SSL struct to our connection if (!wolfSSL_set_fd (c->sslHandle, c->socket)) { wolfSSL_ERR_dump_errors_fp (stderr); if(c) free(c); return NULL; } printf("into wolfSSL_connect....\n"); // Initiate SSL handshake ret = wolfSSL_connect(c->sslHandle); if (ret != SSL_SUCCESS) { ERR_print_errors_fp (stderr); int err = wolfSSL_get_error(c->sslHandle, ret); printf("error = %d, %s\n", err, wolfSSL_ERR_error_string(err, buffer)); if(c) free(c); return NULL; } printf("SSL_connect success!\n"); } else { perror ("Connect failed!\n"); if(c) free(c); return NULL; } return c; } ``` 哪位大神给点指导,谢谢
Apache 集群服务错误,大神们快来
最近几天服务总是莫名其妙的变得很慢,或者干脆连接不上服务器,查询发现如下错误: 下面两个是apache的error.log报的错误 ![图片说明](https://img-ask.csdn.net/upload/201503/02/1425287903_703280.png) ![图片说明](https://img-ask.csdn.net/upload/201503/02/1425287889_450808.png) 下面是mod_jk.log里面的错误: ``` [Sat Feb 28 09:29:52 2015][1033140:1157808] [info] jk_open_socket::jk_connect.c (627): connect to 172.16.2.5:8009 failed (errno=61) [Sat Feb 28 09:29:52 2015][1033140:1157808] [info] ajp_connect_to_endpoint::jk_ajp_common.c (995): Failed opening socket to (172.16.2.5:8009) (errno=61) [Sat Feb 28 09:29:52 2015][1033140:1157808] [error] ajp_send_request::jk_ajp_common.c (1630): (node1) connecting to backend failed. Tomcat is probably not started or is listening on the wrong port (errno=61) [Sat Feb 28 09:29:52 2015][1033140:1157808] [info] ajp_service::jk_ajp_common.c (2623): (node1) sending request to tomcat failed (recoverable), because of error during request sending (attempt=1) [Sat Feb 28 09:29:52 2015][1033140:1157808] [error] ajp_service::jk_ajp_common.c (2643): (node1) connecting to tomcat failed. [Sat Feb 28 09:29:52 2015][1033140:1157808] [info] service::jk_lb_worker.c (1478): service failed, worker node1 is in error state [Sat Feb 28 09:29:52 2015][1033140:1157808] [info] service::jk_lb_worker.c (1558): All tomcat instances are busy or in error state [Sat Feb 28 09:29:52 2015][1033140:1157808] [error] service::jk_lb_worker.c (1563): All tomcat instances failed, no more workers left [Sat Feb 28 09:29:52 2015][1033140:1157808] [info] jk_handler::mod_jk.c (2788): Service error=0 for worker=loadbalancer ``` 网上查了查,没查到报错原因的,大牛们对apache比较熟悉的帮忙解释一下原因,还有是因为Jboss导致apache挂掉还是apache挂掉导致服务崩溃的?
最多有2000个点同时与服务器互传数据。用PHPredis队列socket,请大神写个示例代码
我现在只知道:以下两部分,但是不知如何将两者结合?让redis来处理socket的2000个连接?请大神帮我结合下,写个基本的样板我参考下,谢谢啦! redis的基础代码: //连接本地的 Redis 服务 $redis = new Redis(); $redis->connect('127.0.0.1', 6379); echo "Connection to server sucessfully"; //存储数据到列表中 $redis->lpush("tutorial-list", "Redis"); $redis->lpush("tutorial-list", "Mongodb"); $redis->lpush("tutorial-list", "Mysql"); // 获取存储的数据并输出 $arList = $redis->lrange("tutorial-list", 0 ,5); echo "Stored string in redis"; print_r($arList); //连接本地的 Redis 服务 $redis = new Redis(); $redis->connect('127.0.0.1', 6379); echo "Connection to server sucessfully"; // 获取数据并输出 $arList = $redis->keys("*"); echo "Stored keys in redis:: "; print_r($arList); socket部分: set_time_limit(0); $ip = '0.0.0.0'; $port = 8081; do { if(($sock = socket_create(AF_INET,SOCK_STREAM,SOL_TCP)) < 0) { echo "socket_create() 失败的原因是:".socket_strerror($sock)."\n"; } if(($ret = socket_bind($sock,$ip,$port)) < 0) { echo "socket_bind() 失败的原因是:".socket_strerror($ret)."\n"; } if(($ret = socket_listen($sock,4)) < 0) { echo "socket_listen() 失败的原因是:".socket_strerror($ret)."\n"; } if (($msgsock = socket_accept($sock)) < 0) { echo "socket_accept() failed: reason: " . socket_strerror($msgsock) . "\n"; break; } else { $msg = "\nPHP Test Server. \n" ."用quit,shutdown,sun等命令测试.\n"; socket_write($msgsock, $msg, strlen($msg)); socket_last_error(); do{ if(false ===($buf = socket_read($msgsock,8192))){ echo "socket_read() failed: reason: " . socket_strerror($ret) . "\n"; break 2; } if (!$buf = trim($buf)) { continue; } if ($buf == 'sun') { echo'what are you doing?'; $msg = "\nPHP Test Server. \n" ."what are you doing?.\n"; socket_write($msgsock, $msg, strlen($msg)); } if ($buf == 'quit') { break; /*服务器还在监听*/ } if ($buf == 'shutdown') { socket_close($msgsock); break 2; /*服务器已经断开连接*/ } $talkback = "receive:" . $buf; socket_write($msgsock, $talkback, strlen($talkback)); echo $talkback . '<br /n>'; }while(true); } //socket_close($msgsock); } while (true); //socket_close($sock); -------------------------------------------------------------------------------------------------------------------------------------------------
多线程socket网络编程在线程中出现段错误,recv返回-1
![图片说明](https://img-ask.csdn.net/upload/201901/31/1548868389_326564.png) 如图,通过右边的变量信息可知在第一个线程中socket没错,recv成功接收到消息,但把socket传递给下一个消息循环接收处理线程却报错:在一个非套接字上尝试了一个操作。继续执行,则会出现第二张图上的错误提示![图片说明](https://img-ask.csdn.net/upload/201901/31/1548869520_577881.png) 即段错误,不知该怎么解决,望有大神能够解答下我。多谢 下面是两个线程函数代码 ``` //服务器线程函数 DWORD WINAPI ServerThread(LPVOID lpParam) { int AddrSize; char buff[1024] = {0}; //存放接受信息 TH tp; //传递的参数 struct sockaddr_in their_addr; EnterCriticalSection(&gs); AddrSize = sizeof(struct sockaddr_in); tp.hwnd = (HWND)lpParam; tp.socket = accept(sockfd ,(struct sockaddr*)&their_addr ,&AddrSize); if(tp.socket != INVALID_SOCKET) { recv(tp.socket,buff,20,0); MessageRecv(buff,tp.socket,tp.hwnd); cThread = (HANDLE)CreateThread(NULL,0,ClientThread ,&tp, 0, NULL); if (cThread == NULL) { GetLastError(); ShowError(); } } LeaveCriticalSection(&gs); } //通信线程函数 DWORD WINAPI ClientThread(LPVOID lpParam) { char buff[1024] = {0}; TH *tp = (TH *)lpParam; EnterCriticalSection(&gs); while(1) { if(recv(tp->socket,buff,1024,0) != SOCKET_ERROR) { MessageRecv(buff,tp->socket,tp->hwnd); } else { GetLastError(); ShowError(); } } LeaveCriticalSection(&gs); } ```
myeclipse中tomcat8.0启动报错,大神们知道怎么解决吗?
2016-06-26 18:55:30,718 [localhost-startStop-1] ERROR [com.alibaba.druid.pool.DruidDataSource] - init datasource error, url: jdbc:oracle:thin:@localhost:1521:orcl java.sql.SQLRecoverableException: IO 错误: Software caused connection abort: socket write error at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:428) at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:536) at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:228) at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:32) at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:521) at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:148) at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:211) at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:142) at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1377) at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1431) at com.alibaba.druid.pool.DruidDataSource.init(DruidDataSource.java:632) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:606) Caused by: java.net.SocketException: Software caused connection abort: socket write error at java.net.SocketOutputStream.socketWrite0(Native Method) at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:113) at java.net.SocketOutputStream.write(SocketOutputStream.java:159) at oracle.net.ns.Packet.send(Packet.java:386) at oracle.net.ns.ConnectPacket.send(ConnectPacket.java:182) at oracle.net.ns.NSProtocol.connect(NSProtocol.java:284) at oracle.jdbc.driver.T4CConnection.connect(T4CConnection.java:1054) at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:308) ... 87 more 2016-06-26 18:55:30,732 [localhost-startStop-1] ERROR [com.alibaba.druid.pool.DruidDataSource] - dataSource init error java.sql.SQLRecoverableException: IO 错误: Software caused connection abort: socket write error at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:428) at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:536) at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:228) at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:32) at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:521) at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:148) at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:211) at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:142) at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1377) at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1431) at com.alibaba.druid.pool.DruidDataSource.init(DruidDataSource.java:632) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:606) 今天我用tomcat启动项目时,启动过程中就报错,这种情况前几天也出现过,我把oracle数据库卸载后重新装,又重启几次电脑,第二天到公司上班又能正常启动了,现在又出现这种问题,请各位师兄帮我看下,非常感谢!
求大神们解答!!!解决了好久还是解决不了。
使用db2时报错: 2016-10-12 12:56:22,388-[SL] DEBUG localhost-startStop-1 druid.sql.Statement - {conn-10047, stmt-20046} closed 2016-10-12 12:56:22,396-[SL] ERROR localhost-startStop-1 com.alibaba.druid.pool.DruidDataSource - init datasource error, url: jdbc:db2://192.168.1.10:50000/TEST com.ibm.db2.jcc.am.ro: [jcc][t4][2030][11211][4.8.87] 在对连接的底层 socket、socket input stream 或 socket output stream 执行操作期间 发生通信错误。错误位置:Reply.fill()。消息:Connection reset。 ERRORCODE=-4499, SQLSTATE=08001 at com.ibm.db2.jcc.am.gd.a(gd.java:319) at com.ibm.db2.jcc.t4.a.a(a.java:416) at com.ibm.db2.jcc.t4.a.a(a.java:411) at com.ibm.db2.jcc.t4.cb.b(cb.java:205) at com.ibm.db2.jcc.t4.cb.c(cb.java:249) at com.ibm.db2.jcc.t4.cb.c(cb.java:360)
android socket 多线程访问服务器有的时候会返回数据有的时候返回失败
在写项目的时候遇到一个很棘手的问题,就是加载广告图片的时候,有多个连结同时访问服务器,在返回数据的时候总是只有一个广告线程能返回数据,另一个不能返回,需要让第二个广告线程sleep两秒以上才可以得到广告图片,是一个很纠结的问题,谢谢大神指点`package public class SocketToService { public static final Object SOCKETERROR = "#0x123"; public Socket socket =new Socket(); private BufferedReader reader; private InputStream socketin; private BufferedWriter writer; private static int i =0;//端口地址表示 private StringBuffer buffer;//返回报文 /** * @param dstName 服务器地址 * @param dstPort 服务器端口 * @param putXml 发送的报文 * @TODO 发送报文到服务器并接收返回报文 * @throws UnknownHostException * @author yb * @throws IOException * @Reten #0x123表示端口错误 */ static boolean flag = true; /** * @Title: todoService * @Description: 连接服务器 * @param dstName * @param dstPort * @param putXml * @return * @author yb * @return String */ public String todoService(String dstName,int[] dstPort,String putXml){ buffer=new StringBuffer(); try { //发送报文 if (flag) { System.out.println(new InetSocketAddress(dstName,dstPort[0])); socket.connect(new InetSocketAddress(dstName,dstPort[0]),3000); }else{//连接错误后调用备用端口 System.out.println(i); System.out.println(new InetSocketAddress(dstName,dstPort[i])); socket.close();//关闭无法使用的Socket socket=new Socket(); socket.connect(new InetSocketAddress(dstName,dstPort[i]),3000);//设置连接并设置超时时间 } doAction(socket, putXml);//连接成功调用访问机制 } catch (IOException e2) { flag=false; if (i<dstPort.length) {//判断dstPort是否数组越界 i++; if (i==dstPort.length) {//如果遍历完备用端口为连接返回错误信息:#0x123 return buffer.append(SOCKETERROR).toString(); } } todoService(dstName, dstPort, putXml);//执行回调方法 }finally{ try { //重置状态 flag=true; i=0; socket.close(); } catch (IOException e) { e.printStackTrace(); } } return buffer.toString(); } /** * @TODO 报文发送和接收机制 * @param socket * @param putXml */ private void doAction(Socket socket,String putXml){ String content; try { writer = new BufferedWriter(new OutputStreamWriter(socket.getOutputStream())); System.out.println("发送报文:"+putXml); writer.write(putXml.toCharArray()); writer.flush(); socket.shutdownOutput();//关闭输出流 //读取返回的报文 socketin = socket.getInputStream(); reader = new BufferedReader(new InputStreamReader(socketin)); while ((content=reader.readLine())!=null) { buffer.append(content); } } catch (IOException e) { e.printStackTrace(); }finally{ try { writer.close(); reader.close(); } catch (IOException e1) { e1.printStackTrace(); } } } public boolean isConn(){ return socket.isClosed(); } public void closeConn(){ if (socket!=null) { try { socket.close(); } catch (IOException e) { LogUtil.e("error", e.getMessage()); } } } }
ssm随机出现的一个问题 ,有没有大神遇到过?不影响功能 但看着一堆的报错不舒服
org.apache.catalina.connector.ClientAbortException: java.net.SocketException: Software caused connection abort: socket write error at org.apache.catalina.connector.OutputBuffer.doFlush(OutputBuffer.java:370) at org.apache.catalina.connector.OutputBuffer.flush(OutputBuffer.java:334) at org.apache.catalina.connector.CoyoteOutputStream.flush(CoyoteOutputStream.java:101) at org.springframework.util.StreamUtils.copy(StreamUtils.java:127) at org.springframework.web.servlet.resource.ResourceHttpRequestHandler.writeContent(ResourceHttpRequestHandler.java:256) at org.springframework.web.servlet.resource.ResourceHttpRequestHandler.handleRequest(ResourceHttpRequestHandler.java:155) at org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter.handle(HttpRequestHandlerAdapter.java:51) at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:938) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:870) at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:961) at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:852) at javax.servlet.http.HttpServlet.service(HttpServlet.java:624) at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:837) at javax.servlet.http.HttpServlet.service(HttpServlet.java:731) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.shiro.web.servlet.ProxiedFilterChain.doFilter(ProxiedFilterChain.java:61) at org.apache.shiro.web.servlet.AdviceFilter.executeChain(AdviceFilter.java:108) at org.apache.shiro.web.servlet.AdviceFilter.doFilterInternal(AdviceFilter.java:137) at org.apache.shiro.web.servlet.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:125) at org.apache.shiro.web.servlet.ProxiedFilterChain.doFilter(ProxiedFilterChain.java:66) at org.apache.shiro.web.servlet.AbstractShiroFilter.executeChain(AbstractShiroFilter.java:449) at org.apache.shiro.web.servlet.AbstractShiroFilter$1.call(AbstractShiroFilter.java:365) at org.apache.shiro.subject.support.SubjectCallable.doCall(SubjectCallable.java:90) at org.apache.shiro.subject.support.SubjectCallable.call(SubjectCallable.java:83) at org.apache.shiro.subject.support.DelegatingSubject.execute(DelegatingSubject.java:383) at org.apache.shiro.web.servlet.AbstractShiroFilter.doFilterInternal(AbstractShiroFilter.java:362) at org.apache.shiro.web.servlet.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:125) at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:344) at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:261) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at com.alibaba.druid.support.http.WebStatFilter.doFilter(WebStatFilter.java:83) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:219) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:110) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:506) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:169) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:962) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:445) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1115) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:637) at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:318) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Thread.java:745) Caused by: java.net.SocketException: Software caused connection abort: socket write error at java.net.SocketOutputStream.socketWrite0(Native Method) at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:109) at java.net.SocketOutputStream.write(SocketOutputStream.java:153) at org.apache.coyote.http11.InternalOutputBuffer.realWriteBytes(InternalOutputBuffer.java:216) at org.apache.tomcat.util.buf.ByteChunk.flushBuffer(ByteChunk.java:487) at org.apache.coyote.http11.InternalOutputBuffer.flush(InternalOutputBuffer.java:120) at org.apache.coyote.http11.AbstractHttp11Processor.action(AbstractHttp11Processor.java:828) at org.apache.coyote.Response.action(Response.java:173) at org.apache.catalina.connector.OutputBuffer.doFlush(OutputBuffer.java:366) ... 56 more 七月 14, 2018 8:11:35 下午 org.apache.catalina.core.ApplicationDispatcher invoke 严重: Servlet.service() for servlet jsp threw exception java.lang.IllegalStateException: getOutputStream() has already been called for this response at org.apache.catalina.connector.Response.getWriter(Response.java:663) at org.apache.catalina.connector.ResponseFacade.getWriter(ResponseFacade.java:213) at javax.servlet.ServletResponseWrapper.getWriter(ServletResponseWrapper.java:104) at org.apache.jasper.runtime.JspWriterImpl.initOut(JspWriterImpl.java:125) at org.apache.jasper.runtime.JspWriterImpl.flushBuffer(JspWriterImpl.java:118) at org.apache.jasper.runtime.PageContextImpl.release(PageContextImpl.java:186) at org.apache.jasper.runtime.JspFactoryImpl.internalReleasePageContext(JspFactoryImpl.java:125) at org.apache.jasper.runtime.JspFactoryImpl.releasePageContext(JspFactoryImpl.java:79) at org.apache.jsp.WEB_002dINF.jsp.error_jsp._jspService(error_jsp.java:148) at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) at javax.servlet.http.HttpServlet.service(HttpServlet.java:731) at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:439) at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:395) at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:339) at javax.servlet.http.HttpServlet.service(HttpServlet.java:731) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:743) at org.apache.catalina.core.ApplicationDispatcher.doInclude(ApplicationDispatcher.java:603) at org.apache.catalina.core.ApplicationDispatcher.include(ApplicationDispatcher.java:542) at org.springframework.web.servlet.view.InternalResourceView.renderMergedOutputModel(InternalResourceView.java:201)
相见恨晚的超实用网站
相见恨晚的超实用网站 持续更新中。。。
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
python 简易微信实现(注册登录+数据库存储+聊天+GUI+文件传输)
socket+tkinter详解+简易微信实现 历经多天的努力,查阅了许多大佬的博客后终于实现了一个简易的微信O(∩_∩)O~~ 简易数据库的实现 使用pands+CSV实现数据库框架搭建 import socket import threading from pandas import * import pymysql import csv # 创建DataFrame对象 # 存储用户数据的表(...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小型人工智障。 知识可以运用在不同地方,不一定非是天气预报。
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
JavaScript 为什么能活到现在?
作者 | 司徒正美 责编 |郭芮 出品 | CSDN(ID:CSDNnews) JavaScript能发展到现在的程度已经经历不少的坎坷,早产带来的某些缺陷是永久性的,因此浏览器才有禁用JavaScript的选项。甚至在jQuery时代有人问出这样的问题,jQuery与JavaScript哪个快?在Babel.js出来之前,发明一门全新的语言代码代替JavaScript...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Python 编程开发 实用经验和技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法和技巧,包括小数保留指定位小数、判断变量的数据类型、类方法@classmethod、制表符中文对齐、遍历字典、datetime.timedelta的使用等,会持续更新......
吐血推荐珍藏的Visual Studio Code插件
作为一名Java工程师,由于工作需要,最近一个月一直在写NodeJS,这种经历可以说是一部辛酸史了。好在有神器Visual Studio Code陪伴,让我的这段经历没有更加困难。眼看这段经历要告一段落了,今天就来给大家分享一下我常用的一些VSC的插件。 VSC的插件安装方法很简单,只需要点击左侧最下方的插件栏选项,然后就可以搜索你想要的插件了。 下面我们进入正题 Material Theme ...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
开源并不是你认为的那些事
点击上方蓝字 关注我们开源之道导读所以 ————想要理清开源是什么?先要厘清开源不是什么,名正言顺是句中国的古代成语,概念本身的理解非常之重要。大部分生物多样性的起源,...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
相关热词 c#中dns类 c#合并的excel c# implicit c#怎么保留3个小数点 c# 串口通信、 网络调试助手c# c# 泛型比较大小 c#解压分卷问题 c#启动居中 c# 逻辑或运算符
立即提问