数週間前、ジキルは私のためにうまく機能していましたが、突然次のエラーが発生しました:
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
アドレスは使用されておらず、おそらく他の何らかの理由でjekyllが壊れているが、そのエラーをスローしていることを知っています。私のオプションは何ですか?私も再インストールしてみました。
端末にこれを入力して、3000ポートを使用しているプロセスのPIDを見つけます。
$ lsof -wni tcp:3000
次に、PID列の番号を使用してプロセスを強制終了します。
$ kill -9 PID
コメントを投稿する資格がありませんでした。そこで、新しい答えを追加しました。
Mac OS X 10.10.3でこの問題が発生しました。そして、私は以前にJekyllをインストール/使用したことがありませんでした。 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で再起動を続けるため、動作しません。
したがって、次のいずれかを行う必要がありました。
サイト_config.yml
のjekyllサーバーポートを別のスペアポートに変更しました。下の行を_config.yml
に追加し、機能しました。
port: 3000 # change server port to 3000
または
Ctrl-Z
はプログラムを終了するのではなく、プログラムを中断してバックグラウンドに送信します。 「fg」コマンドでプログラムを再開できます。実際に終了するには、Ctrl-C
を使用します。
実際のエラーメッセージは誤っているようで、無視してかまいません。 「使用中のアドレス」という同じエラーメッセージが表示されますが、とにかく予期されたポートでjekyllが正常に動作します。
最近、この問題に出会いました。
上記のすべての方法を試し、コンピューターを再起動しましたが、それでも解決できませんでした!!!それから私はjekyllを削除し、新しいバージョンをインストールしました。
gem uninstall jekyll & gem install jekyll
(スーパーユーザー権限が必要な場合があります)。
あなたが本当に同様のバグに悩まされるなら、このsbメソッドは試してみる価値があります...
回避策
/_site
実行:python -m SimpleHTTPServer 8080
すでにサーバーを実行している場所で別の端末を開いていないことを確認してください。その場合は、CTRL-Cを実行してサーバーをシャットダウンすると、ポート/アドレスが解放されます。
最初に、3000ポートを使用しているプロセスのPIDを見つける必要があります。
$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]
localhost:3000はpid: 6078
そのプロセスを殺す
$Sudo kill 6078
その後、実行します
$Rails s