I have set up a new Ubuntu 18 Cloud Server and installed Discourse like I did it all times, the Standard under 30 Min setup. When I now want to first create a admin, I am calling the installation in my browser and getting error that server is not reachable. 2 things are different to my other servers, 1. I changed to Hetzner Cloud, 2. I can only call the installtion with the IP adress at the moment, as I want to switch another existing server to the new one.
The Hetzner Ubuntu Image is minimal I think, nothing installed. I am out of knowledge now and hope that someone could point me the right direction
thx for reply. I think I explained wrong. I tried only to access via IP, the domain name is still not pointed on the new server. The result of trying to access via IP is the error I said before.
Discourse is up and running but the server somehow diesn´t point to the docker container. I don´t have clue.
I have another stupid question, really stupid
Do I need an an apache or any other webserver installed additionally? Or does the mentioned install method supports everything needed for launching? Sorry for that dumb question
The server is complete fresh, minimal installation of ubuntu, so nothing more is installed.
I recommend opening a ticket with the provider and/or checking their settings to see if you need to do something to open up ports. Sometimes all ports are closed by default.
My provider Hetzner doesn´t offers a extern firewall for the cloud server structure. The only I can do is to check up my system configuration, ufw for example.
Nmap scan report for localhost (127.0.0.1)
Host is up (0.00013s latency).
Not shown: 131065 closed ports
PORT STATE SERVICE
22/tcp open ssh
80/tcp open http
443/tcp open https
6010/tcp open x11
68/udp open|filtered dhcpc
Nmap done: 1 IP address (1 host up) scanned in 4851.83 seconds
root@crazy-geek:~# ufw status
Status: inactive
As I said, its a standard configuration. I am sure I am missing a small thing (
One or both of those should return a bunch of html. If they don’t, go look at the log files in /var/discourse/shared/standalone/log/var-log/nginx/ and /var/discourse/shared/standalone/log/rails/production.log for clues about what could be wrong
You could try ./launcher enter app in the discourse directory and running the top command to verify that nginx, redis, postmaster and ruby are all running. curl is available to test inside the container too.
root@crazy-geek:~# cd /var/discourse
root@crazy-geek:/var/discourse# ./launcher enter app
root@crazy-geek-app:/var/www/discourse# curl http://localhost/
curl: (7) Failed to connect to localhost port 80: Connection refused
root@crazy-geek-app:/var/www/discourse# curl http://172.17.0.2/
curl: (7) Failed to connect to 172.17.0.2 port 80: Connection refused
Outside the container:
root@crazy-geek:/var/discourse# curl http://localhost/
curl: (56) Recv failure: Connection reset by peer
root@crazy-geek:/var/discourse# curl http://172.17.0.2/
curl: (7) Failed to connect to 172.17.0.2 port 80: Connection refused
Error Logs from inside the container:
Nginx (whole error.log is full of the same message):
Thanks a lot. That was a noob mistake actually. I needed to deactivate ssl templates in app.yml and rebuild new. Problem was that letsencrypt couldn´t verify the cert for the domain, as the domain is still pointed to the old server
Sorry for my mistakes and thx a lot for the provided help!
Ich habe das selbst stundenlang vergeblich versucht. Die Installationsanweisungen unter discourse/docs/INSTALL-cloud.md at main · discourse/discourse · GitHub legen nahe, dass die Einrichtung von Let’s Encrypt übersprungen wird, wenn man bei der entsprechenden Zeile einfach Enter drückt. Das funktioniert jedoch nicht. Es werden weiterhin Dinge konfiguriert, die ein SSL-Zertifikat verwenden wollen, das es unter der E-Mail-Adresse me@example.com nicht gibt.
Man muss dann in die app.yml gehen, die Zeile mit der E-Mail-Adresse für Let’s Encrypt sowie die SSL-Vorlagen auskommentieren und anschließend den Launcher neu aufbauen. Ich denke, das sollte als Fehler in discourse-setup betrachtet werden. Außerdem sollte discourse-setup von Anfang an die Möglichkeit bieten, ein eigenes SSL-Zertifikat von einer anderen Zertifizierungsstelle zu installieren, damit man nicht neu aufbauen muss.
Das ist beabsichtigt. Discourse wird standardmäßig sicher mit HTTPS installiert, ohne dass zusätzliche Konfiguration nötig ist. Dieses E-Mail-Feld dient lediglich dazu, Sie über Probleme bei der Verlängerung zu informieren.
Welchen Vorteil bietet es, ein Zertifikat von einer anderen Zertifizierungsstelle zu verwenden? EV-Zertifikate sind praktisch nicht mehr relevant, und Discourse kann sein eigenes Zertifikat automatisch verwalten.
Discourse setup ist nur für die ganz standardmäßige Installation gedacht. Wenn du in der Lage bist, ein eigenes Zertifikat zu besorgen, bist du auch dafür verantwortlich, es zu installieren. Ich stimme zu, dass es etwas verwirrend ist, dass Let’s Encrypt standardmäßig installiert wird, aber es ist sicherer und ist schon seit sehr langer Zeit so, wobei es nur sehr wenige Berichte über Probleme gab.
Dann sollte die Eingabeaufforderung im Abschnitt Let’s Encrypt nicht ‘SKIP’ anzeigen, da sie tatsächlich nicht übersprungen wird, wenn man ENTER drückt. Oder es sollte ein Hinweis gegeben werden, was zu tun ist, wenn Let’s Encrypt nicht verwendet wird.
Meiner Meinung nach sollte SKIP unterstützt werden. Wenn es übersprungen wird, sollte Discourse ohne SSL eingerichtet werden und nur auf Port 80 funktionieren, anstatt gar nicht zu funktionieren und in einem sehr mysteriösen und schwer zu debuggenden Zustand zu enden, wie die oben gezeigten Beiträge illustrieren.
Es wird tatsächlich das Angeben deiner E-Mail übersprungen. Wenn du andere Anforderungen hast, kannst du die YAML-Datei manuell bearbeiten, um sie anzupassen.