विंडोज: क्लाइंटहेलो के बाद एसएसएल / टीएलएस कनेक्शन रिसेट


2

मैं वर्कस्टेशन के रूप में विंडोज सर्वर 2012 का उपयोग कर रहा हूं। समस्या यह है कि नोड द्वारा शुरू किया गया HTTPS कनेक्शन बेतरतीब ढंग से विफल रहता है। संभवतः यह सिस्टम-वाइड समस्या है और न केवल नोड प्रभावित होता है, लेकिन यह ज्यादातर नोड के साथ दिखाई देता है।

क्योंकि कोई भी HTTPS अनुरोध बेतरतीब ढंग से विफल हो सकता है, npm इंस्टॉल एक लॉटरी है और बड़े पैकेजों के लिए यह अंतहीन रिट्रीट के बाद TLSWrap.onread त्रुटि पर ECONNRESET के साथ हमेशा विफल रहेगा। एक अन्य उदाहरण गितुब से फ़ोल्डर सामग्री लाने के लिए मेरी नोड स्क्रिप्ट है, अगर लगभग हमेशा पहली फ़ाइल डाउनलोड करने की कोशिश करने में विफल रहता है, लेकिन कभी-कभी यह कुछ प्राप्त कर सकता है और फिर विफल हो सकता है।

केवल मानक Windows फ़ायरवॉल और सिस्टम सेंटर समापन बिंदु सुरक्षा (AKA Microsoft सुरक्षा अनिवार्य) उस मशीन पर स्थापित है और मैंने उन दोनों को बंद करने की कोशिश की - कोई मदद नहीं। इसके अलावा नेटवर्क कार्ड, आईपी एड्रेस, गेटवे या यहां तक ​​कि आईएसपी बदलने से भी मदद नहीं मिली। मैंने अनइंस्टॉल करने की भी कोशिश की और फिर कुछ एसएसएल-संबंधित विंडोज़ अपडेट्स को फिर से इंस्टॉल किया और इससे भी मदद नहीं मिली। हालाँकि सब कुछ एक ही स्विच से जुड़े दूसरे पीसी पर ठीक काम करता है और यहां तक ​​कि लिनक्स में इस पीसी पर भी। समय और तारीख सही है, ब्राउज़िंग (HTTP और HTTPS) कुछ पर दुर्लभ कनेक्शन रीसेट त्रुटियों को छोड़कर भी ठीक है, लेकिन सभी HTTPS- सक्षम साइट्स (उदाहरण के लिए imgur.com) नहीं।

यहां ओपनसेल से दो आउटपुट हैं, कुछ सेकंड अलग किए गए, पहले एक पास, दूसरा विफल।

openssl s_client -msg -debug -state -connect www.npmjs.com:443

पहले एक पद पर रखने के लिए बहुत बड़ा है, इसलिए यहाँ है pastebin लिंक

दूसरा:

CONNECTED(00000138)
write to 0xf4e608 [0xf87210] (307 bytes => 307 (0x133))
0000 - 16 03 01 01 2e 01 00 01-2a 03 03 4b 71 63 8e 02   ........*..Kqc..
0010 - 73 68 40 9b 77 eb 06 5f-47 58 c5 3e d5 0f 33 1d   sh@.w.._GX.>..3.
0020 - 76 73 d1 b0 0a 11 b8 84-29 32 e3 00 00 ac c0 30   vs......)2.....0
0030 - c0 2c c0 28 c0 24 c0 14-c0 0a 00 a5 00 a3 00 a1   .,.(.$..........
0040 - 00 9f 00 6b 00 6a 00 69-00 68 00 39 00 38 00 37   ...k.j.i.h.9.8.7
0050 - 00 36 00 88 00 87 00 86-00 85 c0 32 c0 2e c0 2a   .6.........2...*
0060 - c0 26 c0 0f c0 05 00 9d-00 3d 00 35 00 84 c0 2f   .&.......=.5.../
0070 - c0 2b c0 27 c0 23 c0 13-c0 09 00 a4 00 a2 00 a0   .+.'.#..........
0080 - 00 9e 00 67 00 40 00 3f-00 3e 00 33 00 32 00 31   ...g.@.?.>.3.2.1
0090 - 00 30 00 9a 00 99 00 98-00 97 00 45 00 44 00 43   .0.........E.D.C
00a0 - 00 42 c0 31 c0 2d c0 29-c0 25 c0 0e c0 04 00 9c   .B.1.-.).%......
00b0 - 00 3c 00 2f 00 96 00 41-00 07 c0 11 c0 07 c0 0c   .<./...A........
00c0 - c0 02 00 05 00 04 c0 12-c0 08 00 16 00 13 00 10   ................
00d0 - 00 0d c0 0d c0 03 00 0a-00 ff 01 00 00 55 00 0b   .............U..
00e0 - 00 04 03 00 01 02 00 0a-00 1c 00 1a 00 17 00 19   ................
00f0 - 00 1c 00 1b 00 18 00 1a-00 16 00 0e 00 0d 00 0b   ................
0100 - 00 0c 00 09 00 0a 00 23-00 00 00 0d 00 20 00 1e   .......#..... ..
0110 - 06 01 06 02 06 03 05 01-05 02 05 03 04 01 04 02   ................
0120 - 04 03 03 01 03 02 03 03-02 01 02 02 02 03 00 0f   ................
0130 - 00 01 01                                          ...
>>> TLS 1.2  [length 0005]
    16 03 01 01 2e
>>> TLS 1.2 Handshake [length 012e], ClientHello
    01 00 01 2a 03 03 4b 71 63 8e 02 73 68 40 9b 77
    eb 06 5f 47 58 c5 3e d5 0f 33 1d 76 73 d1 b0 0a
    11 b8 84 29 32 e3 00 00 ac c0 30 c0 2c c0 28 c0
    24 c0 14 c0 0a 00 a5 00 a3 00 a1 00 9f 00 6b 00
    6a 00 69 00 68 00 39 00 38 00 37 00 36 00 88 00
    87 00 86 00 85 c0 32 c0 2e c0 2a c0 26 c0 0f c0
    05 00 9d 00 3d 00 35 00 84 c0 2f c0 2b c0 27 c0
    23 c0 13 c0 09 00 a4 00 a2 00 a0 00 9e 00 67 00
    40 00 3f 00 3e 00 33 00 32 00 31 00 30 00 9a 00
    99 00 98 00 97 00 45 00 44 00 43 00 42 c0 31 c0
    2d c0 29 c0 25 c0 0e c0 04 00 9c 00 3c 00 2f 00
    96 00 41 00 07 c0 11 c0 07 c0 0c c0 02 00 05 00
    04 c0 12 c0 08 00 16 00 13 00 10 00 0d c0 0d c0
    03 00 0a 00 ff 01 00 00 55 00 0b 00 04 03 00 01
    02 00 0a 00 1c 00 1a 00 17 00 19 00 1c 00 1b 00
    18 00 1a 00 16 00 0e 00 0d 00 0b 00 0c 00 09 00
    0a 00 23 00 00 00 0d 00 20 00 1e 06 01 06 02 06
    03 05 01 05 02 05 03 04 01 04 02 04 03 03 01 03
    02 03 03 02 01 02 02 02 03 00 0f 00 01 01
read from 0xf4e608 [0xf8c770] (7 bytes => -1 (0xFFFFFFFF))
---
no peer certificate available
---
No client certificate CA names sent
---
SSL handshake has read 0 bytes and written 307 bytes
---
New, (NONE), Cipher is (NONE)
Secure Renegotiation IS NOT supported
Compression: NONE
Expansion: NONE
No ALPN negotiated
SSL-Session:
    Protocol  : TLSv1.2
    Cipher    : 0000
    Session-ID: 
    Session-ID-ctx: 
    Master-Key: 
    Key-Arg   : None
    PSK identity: None
    PSK identity hint: None
    SRP username: None
    Start Time: 1457623360
    Timeout   : 300 (sec)
    Verify return code: 0 (ok)
---
SSL_connect:before/connect initialization
SSL_connect:SSLv2/v3 write client hello A
SSL_connect:error in SSLv2/v3 read server hello A
write:errno=10054

यहाँ से प्रतिक्रिया है www.howsmyssl.com एपीआई नोड.जेएस से अनुरोध किया गया

{  
   "given_cipher_suites":[  
      "TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256",
      "TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256",
      "TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384",
      "TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384",
      "TLS_DHE_RSA_WITH_AES_128_GCM_SHA256",
      "TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256",
      "TLS_DHE_RSA_WITH_AES_128_CBC_SHA256",
      "TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384",
      "TLS_DHE_RSA_WITH_AES_256_CBC_SHA256",
      "TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384",
      "TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA",
      "TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA",
      "TLS_DH_DSS_WITH_AES_256_GCM_SHA384",
      "TLS_DHE_DSS_WITH_AES_256_GCM_SHA384",
      "TLS_DH_RSA_WITH_AES_256_GCM_SHA384",
      "TLS_DHE_RSA_WITH_AES_256_GCM_SHA384",
      "TLS_DHE_DSS_WITH_AES_256_CBC_SHA256",
      "TLS_DH_RSA_WITH_AES_256_CBC_SHA256",
      "TLS_DH_DSS_WITH_AES_256_CBC_SHA256",
      "TLS_DHE_RSA_WITH_AES_256_CBC_SHA",
      "TLS_DHE_DSS_WITH_AES_256_CBC_SHA",
      "TLS_DH_RSA_WITH_AES_256_CBC_SHA",
      "TLS_DH_DSS_WITH_AES_256_CBC_SHA",
      "TLS_ECDH_RSA_WITH_AES_256_GCM_SHA384",
      "TLS_ECDH_ECDSA_WITH_AES_256_GCM_SHA384",
      "TLS_ECDH_RSA_WITH_AES_256_CBC_SHA384",
      "TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA384",
      "TLS_ECDH_RSA_WITH_AES_256_CBC_SHA",
      "TLS_ECDH_ECDSA_WITH_AES_256_CBC_SHA",
      "TLS_RSA_WITH_AES_256_GCM_SHA384",
      "TLS_RSA_WITH_AES_256_CBC_SHA256",
      "TLS_RSA_WITH_AES_256_CBC_SHA",
      "TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256",
      "TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA",
      "TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA",
      "TLS_DH_DSS_WITH_AES_128_GCM_SHA256",
      "TLS_DHE_DSS_WITH_AES_128_GCM_SHA256",
      "TLS_DH_RSA_WITH_AES_128_GCM_SHA256",
      "TLS_DHE_DSS_WITH_AES_128_CBC_SHA256",
      "TLS_DH_RSA_WITH_AES_128_CBC_SHA256",
      "TLS_DH_DSS_WITH_AES_128_CBC_SHA256",
      "TLS_DHE_RSA_WITH_AES_128_CBC_SHA",
      "TLS_DHE_DSS_WITH_AES_128_CBC_SHA",
      "TLS_DH_RSA_WITH_AES_128_CBC_SHA",
      "TLS_DH_DSS_WITH_AES_128_CBC_SHA",
      "TLS_ECDH_RSA_WITH_AES_128_GCM_SHA256",
      "TLS_ECDH_ECDSA_WITH_AES_128_GCM_SHA256",
      "TLS_ECDH_RSA_WITH_AES_128_CBC_SHA256",
      "TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA256",
      "TLS_ECDH_RSA_WITH_AES_128_CBC_SHA",
      "TLS_ECDH_ECDSA_WITH_AES_128_CBC_SHA",
      "TLS_RSA_WITH_AES_128_GCM_SHA256",
      "TLS_RSA_WITH_AES_128_CBC_SHA256",
      "TLS_RSA_WITH_AES_128_CBC_SHA",
      "TLS_ECDHE_RSA_WITH_3DES_EDE_CBC_SHA",
      "TLS_ECDHE_ECDSA_WITH_3DES_EDE_CBC_SHA",
      "TLS_DHE_RSA_WITH_3DES_EDE_CBC_SHA",
      "TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA",
      "TLS_DH_RSA_WITH_3DES_EDE_CBC_SHA",
      "TLS_DH_DSS_WITH_3DES_EDE_CBC_SHA",
      "TLS_ECDH_RSA_WITH_3DES_EDE_CBC_SHA",
      "TLS_ECDH_ECDSA_WITH_3DES_EDE_CBC_SHA",
      "TLS_RSA_WITH_3DES_EDE_CBC_SHA",
      "TLS_EMPTY_RENEGOTIATION_INFO_SCSV"
   ],
   "ephemeral_keys_supported":true,
   "session_ticket_supported":true,
   "tls_compression_supported":false,
   "unknown_cipher_suite_supported":false,
   "beast_vuln":false,
   "able_to_detect_n_minus_one_splitting":false,
   "insecure_cipher_suites":{  

   },
   "tls_version":"TLS 1.2",
   "rating":"Probably Okay"
}

मैंने पहले से ही इस मुद्दे को हल करने के लिए अंतहीन घंटे बिताए, लेकिन कुछ भी काम नहीं आया। मैं इस पीसी पर नोड का उपयोग करने में असमर्थ हूं और आधुनिक दुनिया में यह दर्द होता है, इसलिए मैं इसे पुनः स्थापित कर रहा हूं ओएस और सभी सॉफ़्टवेयर को पुनर्स्थापित करने की आखिरी उम्मीद के रूप में।

जवाबों:


0

आप कमांड प्रॉम्प्ट में इन कमांड को चलाकर TCP / IP स्टैक को व्यवस्थापक के रूप में रीसेट कर सकते हैं:

  • स्थापना चूक के लिए WinSOCK प्रविष्टियों को रीसेट करें: netsh winsock reset catalog
  • स्थापना दोषों के लिए IPv4 TCP / IP स्टैक रीसेट करें। netsh int ipv4 reset reset.log
  • स्थापना चूक के लिए IPv6 टीसीपी / आईपी स्टैक रीसेट करें। netsh int ipv6 reset reset.log
  • Winsock कैटलॉग रीसेट करें: netsh winsock reset catalog
  • या केवल : netsh int ip reset reset.log
  • तथा netsh winsock reset catalog

उपरोक्त आदेशों में कुछ दोहराव हो सकता है, लेकिन यह सभी हैं रीसेट जो मुझे पता है कि आदेश।

यदि सब कुछ विफल रहता है, तो यह दुख नहीं होगा IPv6 को निष्क्रिय करें और भी sfc / scannow Windows घटकों को सत्यापित करने के लिए।


खैर, मुझे नहीं लगता कि यह एक नोड बग है, क्योंकि नोड का एक ही संस्करण दूसरे पीसी पर ठीक काम करता है। और मैंने सिर्फ पायथन स्क्रिप्ट के साथ परीक्षण किया और कनेक्शन रीसेट त्रुटि भी मिली। इस त्रुटि से प्रभावित वेब सर्वरों पर भी मेरा कोई नियंत्रण नहीं है (उदाहरण के लिए npmjs.com या raw.githubusercontent.com)। मुझे लगता है कि यह विंडोज अपडेट या अन्य सॉफ़्टवेयर के कारण सिस्टम-वाइड समस्या है। वैसे भी मदद के लिए धन्यवाद।
graycrow

शायद आप सही हैं। यदि यह केवल एक कंप्यूटर पर होता है, तो मैंने विंडोज के लिए जाने वाले सभी रीसेट कमांड के ऊपर सूचीबद्ध किया है। क्या अन्य कंप्यूटर भी विंडोज सर्वर 2012 पर है?
harrymc

IPv6 अक्षम है, उन कमांड्स को मैंने पहले आज़माया था और इससे मदद नहीं मिली। sfc / scannow कुछ भी संदिग्ध नहीं मिला। अन्य पीसी विंडोज सर्वर 2008 आर 2 पर है। यह थोड़ा अलग ओएस है, मुझे पता है, लेकिन यह सिर्फ यह साबित करने के लिए है कि समस्या नेटवर्क हार्डवेयर या आईएसपी के कारण नहीं है। और यह लगभग असंभव है कि नोड.जेएस और पायथन दोनों में केवल 2012 के सर्वर से संबंधित बग हैं।
graycrow

यह किसी भी अन्य विंडोज सर्वर 2012 की स्थापना में काम किया है? आपको कुछ असंगति का सामना करना पड़ सकता है। मेरे उत्तर के पिछले संस्करण की तरह, यह कीप-सजीव या निष्क्रिय सॉकेट्स के साथ हो सकता है। मुझे बाद में WS2012 में उनके मापदंडों पर एक नजर होगी, हालांकि यह सुनिश्चित नहीं है कि आप क्लाइंट को नियंत्रित कर सकते हैं। आप परीक्षण संस्करण के रूप में भी VM के अंदर WS2012 R2 की कोशिश करने पर विचार कर सकते हैं।
harrymc

इसके अलावा, कीप-सजीव और बेकार की कुर्सियां ​​इस संभावना का सुझाव देती हैं कि इन यादृच्छिक त्रुटियों का कारण एक समयबाह्य है क्योंकि दूसरा पक्ष अतिभारित है, इसलिए कनेक्शन बस बाहर निकलता है। यह देखने की कोशिश करें कि क्या समस्या अलग-अलग समय पर समान रूप से होती है जैसे कि सुबह या देर रात।
harrymc
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.