Nginx Reverse Proxy Conflict with Cells on Port 443

Hello everyone,

I am using cells installed with systemctl on a debian server.
I also have nginx, also installed with systemctl, for reverse proxying.

I’m sorry to post this here, as it might not be due to cells, but I’m really stuck.

I am encountering an issue. I have several reverse proxies configured, and usually, it works well because I add a different port. But this time, for an application I need to configure, I am forced to use port 443, just like cells.
However, I am indeed on a different subdomain from cells.

Like cells is : cloud.ndd.fr
And my app is : app.ndd.fr

Here is an Nginx config file:

server {
    listen 80;
    listen 443 ssl;
    server_name app.ndd.fr;
    ssl_certificate /etc/letsencrypt/live/app.ndd.fr/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/app.ndd.fr/privkey.pem;
    location / {
        proxy_pass http://localhost:1234;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
}

It is functional, I can access this server, but the problem is that I have to stop cells:

sudo systemctl stop cells

If I do not stop cells, then my Nginx will not start: bind() to 0.0.0.0:443 failed (98: Address already in use)

Because cells is already listening on port 443.

Is there a way to access my two different subdomains without having to specify a port?
I can’t find a solution.

Thank you!

Yes, you can only bind one app to a given port.

In such case, I usually also use the nginx as the reverse proxy for cells.

You could then use cells configure sites to define another unused port and add a stanza in nginx to forward the traffic to the correct port depending on the subdomain.

Would this work for you ?

1 Like

Ah ok, I understand better. Actually, I can only bind one port either to nginx or to the integrated server of cells.
But if I route everything through nginx, then it’s no longer a problem and I can associate the same port multiple times but with different subdomain names, right?
If the result is that:
cloud.ndd.fr and app.ndd.fr point transparently without adding a port in the URL, then yes, that works for me.

So I need to disable the integrated reverse proxy in cells and use nginx for cells?

Thanks a lot!

Hello,

I do not understand what is wrong with my cells configure sites.

This is what I have:

The following sites are currently defined:
±–±-------------------------±-------±---------------------+
| # | BIND(S) | TLS | EXTERNAL URL |
±–±-------------------------±-------±---------------------+
| 0 | http://cloud.ndd.fr:8080 | No Tls | https://cloud.ndd.fr |
±–±-------------------------±-------±---------------------+

"sites": [
  {
    "Binds": [
      "cloud.ndd.fr:8080"
    ],
    "ReverseProxyURL": "https://cloud.ndd.fr",
    "TLSConfig": null
  }
],

But cells is still occupying port 443, and I cannot start Nginx. :frowning:
However I can access cells like before!

Here is what I see in my admin interface; it looks like cells is not taking the config file into account?

Hmm sorry for the late reply.

Maybe dumb question, but are you sure you restarted the server after doing the change via cells configure site ???

Otherwise there must be another issue somewhere: the 2 values (in the web and in the console) should be the same…

No problem for the time :slight_smile:

I’m restarting cells with : sudo systemctl restart cells
I guess its restarting the cells server as well ?