What are the differences from running PHP-FPM over an Unix Socket vs a TCP/IP Socket?

十年热恋 提交于 2019-12-21 03:25:44

问题


There are these two ways of running PHP-FPM. I know that nothing is bullet-proof in tech, but what are the pros and cons from both methods?


回答1:


The difference is mainly the added overhead of using the full network stack to "pack" and "unpack" every piece of data. Mind you that the overhead is negligible for most deployments

  • Using a socket (e.g. listen = '/tmp/php-fpm.sock') makes sense when both the front-end (e.g. Nginx) and php-fpm are in the same box and

    1. You have the option to scale horizontally both the front and back-end together (say you are building a container with both and you can create more containers, each with a working pair) or
    2. Your only option is to scale vertically the one "box" you are using (say, you add more CPU, RAM, etc)
  • Using a TCP connection (e.g. listen = 127.0.0.1:9000) makes sense if you want to de-couple the front and the back-end, for example, if you decide to scale up your environment by having a single Nginx receiving connections and passing the work via the network to a cluster of php-fpm boxes

Every environment is different, so as always, the only true option is to start with the one setup that seems right, load-test, and keep measuring the performance so you can try different options as your load requirements evolve (normally, you go with the one that is cheaper to implement or easier to maintain, since both are solid, battle-tested approaches)



来源:https://stackoverflow.com/questions/42704763/what-are-the-differences-from-running-php-fpm-over-an-unix-socket-vs-a-tcp-ip-so

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!