Created
          November 11, 2014 17:41 
        
      - 
      
- 
        Save amichaelgrant/90d99d7d5d48bf8fd209 to your computer and use it in GitHub Desktop. 
    failed (104: Connection reset by peer) while reading response header from upstream, client:
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | failed (104: Connection reset by peer) while reading response header from upstream, client: | |
| If you are getting the above error in nginx logs running in from of upstream servers you may consider doing this as it worked for me: | |
| check the ulimit on the machines and ensure it is high enough to handle the load coming in. 'ulimit' on linux, I am told determines the maximum number of open files the kernel can handle. | |
| The way I did that? | |
| modifying limits: for open files: | |
| -------------------------------- | |
| add or change this line in /etc/systcl.conf | |
| fs.file-max = <limit-number> | |
| set soft & hard limits in this file for various users: /etc/security/limits.conf | |
| <user-name or group-name or *> soft nofile <limit-number> | |
| <user-name or group-name or *> soft nofile <limit-number> hard nofile <limit-number> | |
| Then reload the system settings withou restarting: | |
| sysctl -p | |
| nginx settings : | |
| -------------------------------- | |
| in nginx.conf add/set: | |
| worker_rlimit_nofile <limit-number> | |
| When setting up upstream servers or not, it is a good idea to keep some connections alive when running on HTTP 1.1. Consider adding this to the upstream block on : | |
| keepalive <some-number>; | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
            
If the same message appears occasionally, but not always — say, 20% of the time, which is annoying enough but not easily reproducible because it doesn't happen all the time... — then there are three further possibilities:
session.save_path = "/var/lib/php/sessions"). This can be bad permissions, bad ownership, bad user/group, or more esoteric/obscure issues like running out of inodes on that directory (or even a full disk!). This will usually not leave many core dumps around and possibly not even anything on the PHP error logs.