3

知道下面两个命令有什么区别吗?

命令: manage.py runfcgi 方法=线程主机=127.0.0.1 端口=3033

labs@li68:/var/www/django_projects/myproject$ ps aux|grep manage.py
labs   14558  0.0  2.2  65948  8212 ?        Sl   Oct19   0:09 python /var/www/django_projects/myproject/manage.py runfcgi method=threaded host=127.0.0.1 port=3033

命令: python manage.py runfcgi host=127.0.0.1 port=7021 protocol=fcgi pidfile=/tmp/myproject.fcgi.pid

labs@li68:/var/www/django_projects/myproject$ ps aux|grep manage.py
labs   21082  0.0  2.8  15440 10472 ?        S    22:27   0:00 python manage.py runfcgi host=127.0.0.1 port=3034 protocol=fcgi pidfile=/tmp/myproject.fcgi.pid
labs   21083  0.0  2.7  15440 10084 ?        S    22:27   0:00 python manage.py runfcgi host=127.0.0.1 port=3034 protocol=fcgi pidfile=/tmp/myproject.fcgi.pid
labs   21084  0.0  2.7  15440 10084 ?        S    22:27   0:00 python manage.py runfcgi host=127.0.0.1 port=3034 protocol=fcgi pidfile=/tmp/myproject.fcgi.pid
labs   21085  0.0  2.7  15440 10084 ?        S    22:27   0:00 python manage.py runfcgi host=127.0.0.1 port=3034 protocol=fcgi pidfile=/tmp/myproject.fcgi.pid
labs   21086  0.0  2.7  15440 10084 ?        S    22:27   0:00 python manage.py runfcgi host=127.0.0.1 port=3034 protocol=fcgi pidfile=/tmp/myproject.fcgi.pid
labs   21087  0.0  2.7  15440 10084 ?        S    22:27   0:00 python manage.py runfcgi host=127.0.0.1 port=3034 protocol=fcgi pidfile=/tmp/myproject.fcgi.pid

第二个命令看起来生成了 6 个进程,每个进程都分配了内存。

  • 如果您没有很多内存,最好的选择是什么?并运行几个 django 实例?
  • 为什么第二个命令会产生 6 个进程?
  • 每种方法的优点/缺点是什么?
  • 你如何限制产生的进程数量?
4

1 回答 1

6

您看到多个进程的原因是因为默认runfcgi使用method=prefork。使用这种方法,会分叉一堆 FCGI 进程来处理请求;显然method=threaded使用了多线程 FCGI 进程。

每个都有优点和缺点。prefork 方法将使用更多内存,因为进程使用的内存比线程多。启动也需要更多时间,因为分叉比创建新线程需要更多时间。但是,通常预分叉处理比线程加载更好,因此如果您的应用程序负载较高,则预分叉的性能可能会更好(如果不是,您可能不会注意到两种方式有太大的区别)。

为什么第二个命令会产生 6 个进程?你如何限制产生的进程数量?

如果您不指定要生成的数量,Django 将在预分叉时生成默认数量的进程。maxspare您可以使用或maxchildren选项更改此设置。

于 2010-12-03T21:13:23.303 回答