python这种语言可能最让人诟病的就是它的语言执行效率比较低(当然,相对于ruby,python还算良心),多线程残废难以利用多核cpu,最开始写java多线程写的爽了,会非常不适应在python,没办法只有多进程的方法来搞了。

在web服务器方面,python现在比较常用的方式有两种:

(1)开多个进程,大家监听不同的端口,然后前面挂一个反向代理
(2)首先启动父进程,监听端口,然后启动多个子进程,这样子进程就默认拥有了父进程的监听端口,虽然可能会存在惊群的可能性,不过其实也无所谓啦(这种方式其实还有另外一个让人蛋疼的东西,停止系统后,监听的端口可能要等一段时间才能使用)。

对于上述第一种,比较麻烦,还需要用nginx之类的搭建一个反向代理,对于第二种方式,其实有一个比较麻烦的事情,就类似于node.js的cluster一样,会发现其实大多数的请求都被某一个进程拿到了,比较蛋疼。

其实,在linux下还有另外一种方式,毕竟有sendmsg,那么思路如下:

(1)需要启动一个进程来建立监听,例如它来监听80端口,将其称之为监听进程
(2)别的进程与刚刚的监听进程建立unixdomain socket连接
(3)当监听进程accept到客户端连接之后,将文件描述符通过sendmsg方式发送给别的进程,这里就可以适当的加上一些负载均衡的手段

这样子就不再需要监听多个端口,然后挂反向代理了,而且负载均衡方面也可以得到照顾。