TCPServer त्रुटि: उपयोग में पहले से पता - बाइंड (2)


90

Jekyll कुछ हफ़्ते पहले मेरे लिए ठीक काम कर रहा था, लेकिन अब अचानक यह मुझे निम्न त्रुटि देता है:

TCPServer Error: Address already in use - bind(2)
INFO  WEBrick::HTTPServer#start: pid=7300 port=4000

 % lsof -i :4000
 <fetches nothing>

हालांकि पोर्ट पर कुछ भी नहीं चल रहा है। नीचे विवरण हैं:

 % jekyll --version
Jekyll 0.11.2
 % where jekyll
/home/bhaarat/.rvm/gems/ruby-1.9.2-p290/bin/jekyll
/usr/bin/jekyll
 % ruby --version
ruby 1.9.2p290 (2011-07-09 revision 32553) [i686-linux]
 % rvm --version
rvm 1.10.0 

यहाँ आउटपुट है

 % jekyll --server
Configuration from /home/bhaarat/blog/omnipresent.github.com/_config.yml
Auto-regenerating enabled: /home/bhaarat/blog/omnipresent.github.com -> /home/bhaarat/blog/omnipresent.github.com/_site
[2012-04-21 13:46:40] regeneration: 38 files changed
[2012-04-21 13:46:40] INFO  WEBrick 1.3.1
[2012-04-21 13:46:40] INFO  ruby 1.9.2 (2011-07-09) [i686-linux]
[2012-04-21 13:46:40] WARN  TCPServer Error: Address already in use - bind(2)
[2012-04-21 13:46:40] INFO  WEBrick::HTTPServer#start: pid=7382 port=4000

मुझे पता है कि पता उपयोग में नहीं है और जेकेल शायद किसी और कारण से टूट रहा है लेकिन उस त्रुटि को फेंक रहा है। मेरे विकल्प क्या हैं? मैंने पुनः स्थापित करने की कोशिश की है।


आपको वास्तव में यह कैसे पता चलेगा कि पता उपयोग में नहीं है?
सर्जियो तुलेंत्सेव

मैं lsof -i :<port number>एक ही कोशिश कर रहा हूँ एक ही बात एक अलग बॉक्स पर हो रही है
सर्वव्यापी

यदि आप एक वैकल्पिक पोर्ट निर्दिष्ट करते हैं तो क्या होता है?
मार्क थॉमस

दुर्भाग्य से, वही बात। पूरी तरह से jekyll को हटाने और इसे पुनर्स्थापित करने का सबसे अच्छा तरीका है।
सर्वव्यापी

यदि आपने स्थापित करने के लिए रूबी रत्न का उपयोग किया है, तो आपको इसके साथ स्थापना रद्द करने में सक्षम होना चाहिए gem uninstall jekyll। यदि आप मौजूदा संस्करण को अधिलेखित करने के लिए मणि के साथ स्थापित नहीं करते हैं। क्या आपने यह देखने के लिए अपने ब्राउज़र या टेलनेट के साथ पोर्ट को हिट करने की कोशिश की कि क्या कोई सहायता प्रदान करता है?
एलन डब्ल्यू। स्मिथ

जवाबों:


224

3000 पोर्ट का उपयोग करने वाली प्रक्रिया की पीआईडी ​​का पता लगाने के लिए इसे अपने टर्मिनल में टाइप करें:

$ lsof -wni tcp:3000

फिर, प्रक्रिया को मारने के लिए PID कॉलम में संख्या का उपयोग करें:

$ kill -9 PID

19
इसे पढ़ने वाले किसी व्यक्ति के लिए, यह सुनिश्चित करें कि अंतिम आदेश में, आप PIDउस वास्तविक संख्या के साथ स्थानापन्न करें जिसे आप पीआईडी ​​के तहत देखते हैं। उदाहरण के लिए, मैं चलाkill -9 11734
JGallardo

ध्यान दें कि समस्या IPv6 कॉन्फ़िगरेशन समस्या से आ रही एक हानिरहित चेतावनी भी हो सकती है: सर्वर पहले एक दोहरे-स्टैक IPv4 + IPv6 पते से जुड़ता है, फिर यह IPv6- केवल पते पर बाइंड करने का भी प्रयास करता है; और बाद वाला काम नहीं करता है क्योंकि IPv6 पता पहले से ही पिछले दोहरे स्टैक सॉकेट द्वारा लिया गया है।
jpetazzo

17

मैं टिप्पणी पोस्ट करने के लिए योग्य नहीं था। इसलिए मैंने एक नया उत्तर जोड़ा।

मुझे मैक ओएस एक्स 10.10.3 पर इस समस्या का सामना करना पड़ा। और मैंने पहले कभी भी Jekyll को स्थापित / उपयोग नहीं किया था। मैं अपने डिफ़ॉल्ट पोर्ट नंबर 4000 के साथ जेकिल सर्वर शुरू करने में सक्षम नहीं था। इसका कारण यह था कि पोर्ट वैसा ही था जैसा NoMachine उपयोग करता था। साथ में

$ sudo lsof -wni tcp:4000

नोट: इस कमांड को बिना चलाए sudo कोई आउटपुट नहीं होगा।

मैंने यह आउटपुट देखा:

COMMAND PID USER   FD   TYPE             DEVICE SIZE/OFF NODE NAME
nxd     449   nx    3u  IPv4 0x8d22************      0t0  TCP *:terabase (LISTEN)
nxd     449   nx    4u  IPv6 0x8d22************      0t0  TCP *:terabase (LISTEN)

पोर्ट 4000 पर कब्जा कर लिया गया था nxd, जो कि NoMachine द्वारा शुरू की गई प्रक्रिया थी। तथा

$ sudo kill -9 449

काम नहीं करेगा, क्योंकि NoMachine की nxd प्रक्रिया एक नए PID के साथ पुनः आरंभ होती रहेगी।

इसलिए, मुझे या तो करना पड़ा:

  • साइट में मेरे jekyll सर्वर पोर्ट _config.ymlको दूसरे स्थान पर बदल दिया । मैंने नीचे की पंक्ति को जोड़ दिया _config.ymlऔर यह काम कर गया।

    port: 3000 # change server port to 3000

या

  • परिवर्तित NoMachine का डिफ़ॉल्ट nxd पोर्ट, या NoMachine की स्थापना रद्द करें

धन्यवाद, मैं यह पता नहीं लगा सका कि जब तक मैं इस जवाब पर नहीं अड़ा था, तब तक टेराबेस क्या था।
हाईवे ऑफ लाइफ

10

Ctrl-Zएक कार्यक्रम को समाप्त नहीं करता है, बल्कि इसे निलंबित करता है और इसे पृष्ठभूमि पर भेजता है। आप प्रोग्राम को "एफजी" कमांड के साथ फिर से शुरू कर सकते हैं। वास्तव में इसे समाप्त करने के लिए, उपयोग करेंCtrl-C

वास्तविक त्रुटि संदेश फर्जी लगता है और इसे नजरअंदाज किया जा सकता है। मुझे एक ही त्रुटि संदेश "उपयोग में पता" मिल रहा है, लेकिन अपेक्षित पोर्ट पर जेकेल ठीक काम करता है।


मुझे भी त्रुटि संदेश मिल रहा है लेकिन मैं अपनी साइट को चला सकता हूं: 4000
joshuahornby10

3

मैं हाल ही में इस समस्या से मिला हूं।

मैंने ऊपर बताई गई सभी विधि को आजमाया, और यहां तक ​​कि अपने कंप्यूटर को पुनः आरंभ किया, लेकिन फिर भी इसे हल नहीं किया जा सका !!! फिर मैंने जेकिल को हटा दिया और एक नया संस्करण स्थापित किया, यह बस काम कर गया।

gem uninstall jekyll & gem install jekyll (शायद आपको सुपर उपयोगकर्ता निजीकरण की आवश्यकता हो)।

यदि आप वास्तव में इसी तरह के कीड़े से परेशान हैं, तो यह एसबी विधि एक कोशिश के लायक है ...



0

जांचें कि आपके पास एक और टर्मिनल खुला नहीं है जहां आप पहले से ही सर्वर चला रहे हैं। यदि ऐसा है, तो सर्वर को बंद करने के लिए एक CTRL-C करें और वह पोर्ट / एड्रेस को फ्री कर देगा।


0

पहले आपको उस प्रक्रिया की PID ढूंढनी होगी जो 3000 पोर्ट का उपयोग कर रही है:

 $ps -ef

आउटपुट इस तरह:

1003      4953  2614  0 08:51 pts/0    00:00:00 -bash
1003      5634     1  0 08:56 pts/0    00:00:00 spring server | moviestore | started 2 hours ago                                           
1003      5637  5634  0 08:56 ?        00:00:01 spring app    | moviestore | started 2 hours ago | development mode                                                              
1003      6078  4953  0 09:03 pts/0    00:00:03 puma 3.6.0 (tcp://localhost:3000) [moviestore]              
1003      6117  2614  0 09:03 pts/1    00:00:00 -bash
root      6520     2  0 09:57 ?        00:00:00 [kworker/u8:2]
root      6936  1225  0 11:09 ?        00:00:00 [lightdm] <defunct>
1003      7084     1  0 11:09 ?        00:00:00 /usr/bin/python /usr/share/apport/apport-gtk
1003      7475     1  0 11:10 ?        00:00:00 /usr/bin/python /usr/share/apport/apport-gtk
root      8739  1225  1 11:29 tty8     00:00:11 /usr/bin/X :1 -auth /var/run/lightdm/root/:1 -nolisten tcp vt8 -novtswitch
root      8853  1225  0 11:29 ?        00:00:00 lightdm --session-child 13 22
1002      8943     1  0 11:30 ?        00:00:00 /usr/bin/gnome-keyring-daemon --daemonize --login
1002      8954  8853  0 11:30 ?        00:00:00 gnome-session --session=ubuntu
1002      8992  8954  0 11:30 ?        00:00:00 /usr/bin/ssh-agent /usr/bin/dbus-launch --exit-with-session gnome-session --session=ubuntu
1002      8995     1  0 11:30 ?        00:00:00 /usr/bin/dbus-launch --exit-with-session gnome-session --session=ubuntu
1002      8996     1  0 11:30 ?        00:00:00 //bin/dbus-daemon --fork --print-pid 5 --print-address 7 --session
1002      9007  8954  0 11:30 ?        00:00:00 /usr/lib/gnome-settings-daemon/gnome-settings-daemon
1002      9015     1  0 11:30 ?        00:00:00 /usr/lib/gvfs/gvfsd
1002      9018  8954  1 11:30 ?        00:00:07 compiz
1002      9021     1  0 11:30 ?        00:00:00 /usr/lib/x86_64-linux-gnu/gconf/gconfd-2
1002      9028  8954  0 11:30 ?        00:00:00 /usr/lib/policykit-1-gnome/polkit-gnome-authentication-agent-1
1002      9029  8954  0 11:30 ?        00:00:01 nautilus -n
1002      9030  8954  0 11:30 ?        00:00:00 /usr/lib/gnome-settings-daemon/gnome-fallback-mount-helper
1002      9031  8954  0 11:30 ?        00:00:00 nm-applet
1002      9032  8954  0 11:30 ?        00:00:02 /opt/mTrac/mTrac
1002      9033  8954  0 11:30 ?        00:00:00 bluetooth-applet
1002      9045  9032  0 11:30 ?        00:00:00 /opt/mTrac/mTrac --type=zygote --no-sandbox
1002      9050     1  0 11:30 ?        00:00:00 /usr/lib/gvfs/gvfs-gdu-volume-monitor
1002      9054     1  0 11:30 ?        00:00:00 /usr/bin/pulseaudio --start --log-target=syslog
1002      9057     1  0 11:30 ?        00:00:00 /usr/lib/gvfs/gvfs-gphoto2-volume-monitor
1002      9062     1  0 11:30 ?        00:00:00 /usr/lib/gvfs/gvfs-afc-volume-monitor

यहाँ आप देख सकते हैं:

1003      6078  4953  0 09:03 pts/0    00:00:03 puma 3.6.0 (tcp://localhost:3000) [moviestore]   

लोकलहोस्ट: 3000 है pid: 6078

उस प्रक्रिया को मार डालो

$sudo kill 6078  

फिर भागो

$rails s

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.