How to 'clear' the port when restarting django runserver
DjangoDjango Problem Overview
Often, when restarting Django runserver, if I use the same port number, I get a 'port is already in use' message. Subsequently, I need to increment the port number each time to avoid this.
It's not the case on all servers, however, so I'm wondering how I might achieve this on the current system that I'm working on?
BTW, the platform is Ubuntu 8.10
Django Solutions
Solution 1 - Django
I found this information (originally from Kristinn Örn Sigurðsson) to solve my problem:
To kill it with -9 you will have to list all running manage.py processes, for instance:
ps aux | grep -i manage
You'll get an output similar to this if you've started on many ports:
14770 8264 0.0 1.9 546948 40904 ? S Sep19 0:00 /usr/local/bin/python manage.py runserver 0.0.0.0:8006
14770 15215 0.0 2.7 536708 56420 ? S Sep13 0:00 /usr/local/bin/python manage.py runserver 0.0.0.0:8001
14770 30144 0.0 2.1 612488 44912 ? S Sep18 0:00 /usr/local/bin/python manage.py runserver 0.0.0.0:8000
14770 30282 0.0 1.9 678024 40104 ? S Sep18 0:00 /usr/local/bin/python manage.py runserver 0.0.0.0:8002
14770 30592 0.0 2.1 678024 45008 ? S Sep18 0:00 /usr/local/bin/python manage.py runserver 0.0.0.0:8003
14770 30743 0.0 2.1 678024 45044 ? S Sep18 0:00 /usr/local/bin/python manage.py runserver 0.0.0.0:8004
Then you'll have to select the pid (which is the second number on the left) for the right manage.py process (python manage.py runserver... etc) and do:
kill -9 pid
For the above example, if you wanted to free up port 8000, you'd do:
kill -9 30144
Solution 2 - Django
You're getting that message because the server is already running (possibly in the background). Make sure to kill the process (bring it to the foreground and press ctrl-c) to stop the process.
Solution 3 - Django
If the ps aux
command (as per Meilo's answer) doesn't list the process that you wanted to kill but shows the port active in netstat -np | grep 8004
network activity, try this command (worked on Ubuntu).
sudo fuser -k 8004/tcp
where as, 8004 is the port number that you want to close. This should kill all the processes associated with port 8004.
Solution 4 - Django
No, he's not an idiot guys. Same thing happens to me. Apparently it's a bug with the python UUID process with continues running long after the django server is shutdown which ties the port up.
Solution 5 - Django
fuser -k 8000/tcp
Run in terminal it works in ubutu. 8000
is the port.
Solution 6 - Django
This error is due to the server already running.
Background
I am answering on a more general level not specific to Django like the original question asks. So that those that land here from Google can easily fix the problem.
Solution
When you need to clear a port, all you need to do is these two steps
- In the terminal run
fg
- Press Control-C (if on a mac)
Explanation
fg brings the process to the foreground. Then Control-C stops the server.
Example
I was actually having this issue with my port 8000 when running an angular app. I was getting an error when I ran npm start
So I ran fg
, then I stopped the server with Control-C
Then I was able to successfully run the server
Solution 7 - Django
Type fg
in the terminal to bring up the background task to the foreground.
Press Ctrl+C to close/stop the running server.
Solution 8 - Django
I use pkill -If 'manage.py'
(-I
means interactive, -f
matches more than just the process name). See https://stackoverflow.com/questions/8987037/how-to-kill-all-processes-with-a-given-partial-name for more info on pkill.
Solution 9 - Django
sudo lsof -t -i tcp:8000 | xargs kill -9
If you want to free 8000 port than just copy command and paste in your cmd it will ask for sudo password. And then you are good to go.
Solution 10 - Django
If the port number that you are trying is 8001, then use this command
sudo fuser -k 8001/tcp
Solution 11 - Django
You do not want to simply increment the port number when restarting a Django server. This will result in having multiple instances of the Django server running simultaneously. A better solution is to kill the current instance and start a new instance.
To do this, you have multiple options. The easiest is
Python2: $ killall -9 python
Python3: $ killall -9 python3
If for some reason, this doesn't work, you can do
$ kill <pid>
where <pid>
is the process id found from a simple $ ps aux | grep python
command.
Solution 12 - Django
netstat -tulpn |grep 8000|awk '{print $7}'|cut -d/ -f 1|xargs kill
Solution 13 - Django
Repost from https://stackoverflow.com/a/27138521/1467342:
You can use this script in place of ./manage.py runserver
. I put it in scripts/runserver.sh
.
#!/bin/bash
pid=$(ps aux | grep "./manage.py runserver" | grep -v grep | head -1 | xargs | cut -f2 -d" ")
if [[ -n "$pid" ]]; then
kill $pid
fi
fuser -k 8000/tcp
./manage.py runserver
Solution 14 - Django
Like mipadi said, you should be terminating the server (ctrl+c) and returning to the command prompt before calling manage.py runserver
again.
The only thing that could be disrupting this would be if you've somehow managed to make runserver act as a daemon. If this is the case, I'm guessing you're using the Django test server as the actual web server, which you should NOT do. The Django test server is single threaded, slow and fragile, suitable only for local development.
Solution 15 - Django
In Leopard, I bring on the Activity Monitor and kill python. Solved.
Solution 16 - Django
Happened so often that I wrote an alias to kill the process with python
in the name (careful if you have other such processes). Now I just run (no Ubuntu)
kill $(ps | grep "python" | awk "{print $1}")
You can even add python manage.py runserver ...
to the same alias so you can restart with two keystrokes.
Solution 17 - Django
You must have been doing control + z .. Instead do control + c that will kill the server session... Cheers!!!
Solution 18 - Django
Add the following library in manage.py
> import os
> import subprocess
> import re
Now add the following python code after if name == "main":
ports = ['8000']
popen = subprocess.Popen(['netstat', '-lpn'],
shell=False,
stdout=subprocess.PIPE)
(data, err) = popen.communicate()
pattern = "^tcp.*((?:{0})).* (?P<pid>[0-9]*)/.*$"
pattern = pattern.format(')|(?:'.join(ports))
prog = re.compile(pattern)
for line in data.split('\n'):
match = re.match(prog, line)
if match:
pid = match.group('pid')
subprocess.Popen(['kill', '-9', pid])
This will first find the process id of port 8000 , will kill it and then restart your project. Now each time you don't need to kill the pid manually.
Solution 19 - Django
netstat -ntlp
See my complete answer here. https://stackoverflow.com/a/34824239/5215825