Skip to content

Instantly share code, notes, and snippets.

@mshoaibdev
Forked from lewislarsen/reverb-instructions.md
Created June 30, 2024 10:34
Show Gist options
  • Save mshoaibdev/c7e424abd1957ed10c79e446b8fdf041 to your computer and use it in GitHub Desktop.
Save mshoaibdev/c7e424abd1957ed10c79e446b8fdf041 to your computer and use it in GitHub Desktop.
Instructions for how to setup Laravel Reverb in Production.

Reverb Walkthrough

This is a walkthrough of how to configure Laravel Reverb for production using services like Laravel Forge or Ploi. The first step is nginx configuration changes, then .env changes and finally spinning up your Reverb server.

1. Configuring Nginx

Ensure your nginx site configuration has the following inside the server block:

    location /app {
    proxy_http_version 1.1;
    proxy_set_header Host $http_host;
    proxy_set_header Scheme $scheme;
    proxy_set_header SERVER_PORT $server_port;
    proxy_set_header REMOTE_ADDR $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "Upgrade";

    proxy_pass http://0.0.0.0:8080;
}

The /app is the path for Reverb and is not your application path, do not change it. Pasting this block of code inside your nginx site configuration file should be good enough.

Note: The port '8080' here is the port that Reverb listens on, it is 8080 by default and should be okay unless you have multiple Laravel apps on the same server using Reverb. Adjust if necessary.

2. Updating your .env

Your .env file is pretty important and should contain the following configuration options at minimum in order to configure Reverb.

REVERB_APP_ID=your-app-id
REVERB_APP_KEY=set-a-key-here
REVERB_APP_SECRET=set-a-secret
REVERB_HOST=site.com
REVERB_PORT=443
REVERB_SCHEME=https
REVERB_SERVER_HOST=127.0.0.1
REVERB_SERVER_PORT=8080
BROADCAST_CONNECTION=reverb

### DO NOT REMOVE ###
VITE_REVERB_APP_KEY="${REVERB_APP_KEY}"
VITE_REVERB_HOST="${REVERB_HOST}"
VITE_REVERB_PORT="${REVERB_PORT}"
VITE_REVERB_SCHEME="${REVERB_SCHEME}"
# If you remove this, Reverb will break.

The notes below contain more information so please read them.

Note: The REVERB_HOST variable should match your site url, so laravel.com etc. No HTTP/HTTPS needed. Ensure you set your app id, key and secret.

Note 2: Please ensure the port number matches the one specified in your nginx site configuration file.

Note 3: Please ensure your broadcasting connection is set to Reverb, this escaped me for an hour!

Note 4: I have included the VITE variables here for completeness sake. Your app may not use VITE but if it does, make sure you've got these variables included otherwise it will complain about a pusher key.

3. Spawning Reverb's Server

I use Ploi which has a one-click button, however as long as you're able to create a daemon on your server that's all you need. My Reverb server command looks like:

php /home/ploi/site.com/artisan reverb:start --host=127.0.0.1 --port=8080 --no-interaction

Adjust the file path to your site but keep the --host and port parameters consistent. You may use the --debug option as well should you wish.

This should be everything needed to get Laravel Reverb working in production, this was made from the installation of my app with working Reverb.

Please ensure your port number is consistent throughout otherwise there will be issues.

@jadonbrownza
Copy link

Thorough guide, and helpful. Thank you.

@wdarins
Copy link

wdarins commented Oct 21, 2024

Thank you, this helped me a lot. I've found another article on medium.com which seems to work but it leads to the following error:
Pusher error: Authentication signature invalid.
Following this article instructions helped me to fix the issue. Thanks again!

@sinnbeck
Copy link

sinnbeck commented Dec 23, 2024

I followed this guide to the letter, but I keep getting Pusher error: Authentication signature invalid.

Edit: Seems the problem was the change suggested above. Removing it fixed the problem :)

@ridwanpr
Copy link

ridwanpr commented Jan 9, 2025

Thanks man, you're a life saver.

@erenergul
Copy link

If you put
REVERB_HOST=site.com

so it only works on your server. If people wants to connect from outside like flutter app. You should set 0.0.0.0 so enable for other ip adresses.

@CharlesLightjarvis
Copy link

OMG!!! Thank you so much... spend 3 days to find the solution Jesus.... Thank you thank you it works for me

@aymanalhattami
Copy link

Big thanks!

@LeRoyJulian
Copy link

An additional note should be added: the server does not create any "channel" until a client has connected to it. I waited for hours to see my event appear in the CLI, but nothing happened until I connected a client first. Then it worked.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment