Ich habe große Schwierigkeiten, eine Integration zwischen Ghost und Discourse einzurichten.
Discourse ist: 2.8.0.beta1, Docker auf Ubuntu – ohne Nginx.
Ich verwende Traefik auf einem eigenständigen System hinter einem einzelnen IP-Router in einem NAT-geschützten Heim-LAN. Traefik ermöglicht HTTP/HTTPS-Routing.
Traefik ist mit einer traefik_dynamic.toml konfiguriert und nicht über Docker-Labels. Es gibt kein gemeinsames Docker-Netzwerk. (Falls jemand an der Traefik-Konfiguration interessiert ist – bitte melden Sie sich – sie funktioniert als Reverse-Proxy sehr gut).
Ghost ist ebenfalls die neueste Version (4.6.4) und läuft auf einem separaten Host (beide Hosts sind Ubuntu-VMs – VERSION=“20.04.2 LTS (Focal Fossa)”, laufen auf Proxmox).
Ich habe die verschiedenen Tutorial-Seiten befolgt, die auf der Ghost-Dokumentationsseite und im Discourse-Forum verfügbar sind.
Die Firefox-Webentwickler-Tools zeigen an, dass die Seite folgenden Quellcode zurückgibt:
<div class="comment container small">
<div class="discourse-comments"></div>
<script type="text/javascript">
if (window.location.pathname.indexOf('/p/') < 0) {
DiscourseEmbed = { discourseUrl: 'https://discourse.mydomain/', discourseEmbedUrl: 'https://ghost.mydomain/testing-new-stuff/' };
(function() {
var d = document.createElement('script'); d.type = 'text/javascript'; d.async = true;
d.src = DiscourseEmbed.discourseUrl + 'javascripts/embed.js';
(document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(d);
})();
}
</script>
</div>
Es werden jedoch keine tatsächlichen Kommentare zurückgegeben. Ich kann sehen, dass mein Discourse-Host embed.js zurückgibt, aber auf der Seite kommt nichts an. (Entschuldigung, ich bin kein Webentwickler).
Es scheint also, dass das Skript durchkommt, aber nichts zurückgibt.
Es ist eine neue Discourse-Installation und befindet sich noch in der Lernphase (Bootstrap-Modus). Es gibt also kaum Themen.
Die app.yml ist unten angehängt.
Die eingebetteten Host-Einstellungen sind meiner Meinung nach korrekt, mit dem Discourse-Administratorbenutzernamen für die Themenerstellung; die Pfad-Whitelist ist derzeit “”.
Ich habe eine Kategorie namens „testing“ erstellt und diese zu „Post to category“ hinzugefügt.
Außerdem habe ich DISCOURSE_ENABLE_CORS: true zu app.yml hinzugefügt, da dies helfen könnte. Ich habe den Proxy sowie http://ghost.mydomain und http://ghost.mydomain zu den CORS-Ursprüngen hinzugefügt.
Kann mir jemand Rat geben, wie man dies debuggen kann?
app.yml:
#
templates:
- "templates/postgres.template.yml"
- "templates/redis.template.yml"
- "templates/web.template.yml"
- "templates/web.ratelimited.template.yml"
## Diese beiden Zeilen kommentieren Sie aus, wenn Sie Lets Encrypt (https) hinzufügen möchten
# - "templates/web.ssl.template.yml"
# - "templates/web.letsencrypt.ssl.template.yml"
## Welche TCP/IP-Ports sollte dieser Container exponieren?
## Wenn Sie möchten, dass Discourse einen Port mit einem anderen Webserver wie Apache oder nginx teilt,
## siehe https://meta.discourse.org/t/17247 für Details
expose:
- "8081:80" # http
# - "443:443" # https
params:
db_default_text_search_config: "pg_catalog.english"
## Setzen Sie db_shared_buffers auf maximal 25 % des Gesamtspeichers.
## wird automatisch vom Bootstrap basierend auf dem erkannten RAM gesetzt, oder Sie können es überschreiben
db_shared_buffers: "2048MB"
## Kann die Sortierleistung verbessern, erhöht aber die Speichernutzung pro Verbindung
#db_work_mem: "40MB"
## Welche Git-Revision soll dieser Container verwenden? (Standard: tests-passed)
#version: tests-passed
env:
LC_ALL: en_US.UTF-8
LANG: en_US.UTF-8
LANGUAGE: en_US.UTF-8
# DISCOURSE_DEFAULT_LOCALE: en
DISCOURSE_ENABLE_CORS: true
## Wie viele gleichzeitige Webanfragen werden unterstützt? Hängt von Speicher und CPU-Kernen ab.
## wird automatisch vom Bootstrap basierend auf den erkannten CPUs gesetzt, oder Sie können es überschreiben
UNICORN_WORKERS: 2
## TODO: Der Domainname, auf den diese Discourse-Instanz antworten soll
## Erforderlich. Discourse funktioniert nicht mit einer bloßen IP-Nummer.
DISCOURSE_HOSTNAME: mydiscoursehost.mydomain
## Kommentieren Sie dies aus, wenn Sie möchten, dass der Container mit demselben
## Hostnamen (-h-Option) wie oben angegeben gestartet wird (Standard: "$hostname-$config")
#DOCKER_USE_HOSTNAME: true
## TODO: Liste der durch Komma getrennten E-Mails, die bei der ersten Anmeldung zu Administratoren und Entwicklern werden
## Beispiel 'user1@example.com,user2@example.com'
DISCOURSE_DEVELOPER_EMAILS: 'myemailaddress@mydomain'
## TODO: Der SMTP-Mailserver, der zur Validierung neuer Konten und zum Senden von Benachrichtigungen verwendet wird
## SMTP-Adresse, Benutzername und Passwort sind erforderlich
## WARNUNG: Das Zeichen '#' im SMTP-Passwort kann Probleme verursachen!
DISCOURSE_SMTP_ADDRESS: smtp.mailgun.org
DISCOURSE_SMTP_PORT: 587
DISCOURSE_SMTP_USER_NAME: postmaster@mydomain
DISCOURSE_SMTP_PASSWORD: "mypostmasterpassword7"
#DISCOURSE_SMTP_ENABLE_START_TLS: true # (optional, Standard true)
DISCOURSE_SMTP_DOMAIN: mydomain
DISCOURSE_NOTIFICATION_EMAIL: noreply@mydomain
## Wenn Sie die Lets-Encrypt-Vorlage hinzugefügt haben, kommentieren Sie unten aus, um ein kostenloses SSL-Zertifikat zu erhalten
# LETSENCRYPT_ACCOUNT_EMAIL: notused
## Die HTTP- oder HTTPS-CDN-Adresse für diese Discourse-Instanz (konfiguriert zum Abrufen)
## siehe https://meta.discourse.org/t/14857 für Details
#DISCOURSE_CDN_URL: https://discourse-cdn.example.com
## Der MaxMind-Geolokalisierungs-IP-Schlüssel für die IP-Adresssuche
## siehe https://meta.discourse.org/t/-/137387/23 für Details
#DISCOURSE_MAXMIND_LICENSE_KEY: 1234567890123456
## Der Docker-Container ist zustandslos; alle Daten werden in /shared gespeichert
volumes:
- volume:
host: /var/discourse/shared/standalone
guest: /shared
- volume:
host: /var/discourse/shared/standalone/log/var-log
guest: /var/log
## Plugins gehen hier
## siehe https://meta.discourse.org/t/19157 für Details
hooks:
after_code:
- exec:
cd: $home/plugins
cmd:
- git clone https://github.com/discourse/docker_manager.git
## Beliebige benutzerdefinierte Befehle, die nach dem Build ausgeführt werden sollen
run:
- exec: echo "Beginning of custom commands"
## Wenn Sie die 'From'-E-Mail-Adresse für Ihre erste Registrierung festlegen möchten, kommentieren Sie dies aus und ändern Sie:
## Nach Erhalt der ersten Anmelde-E-Mail diesen Kommentar wieder entfernen. Es muss nur einmal ausgeführt werden.
#- exec: rails r "SiteSetting.notification_email='info@unconfigured.discourse.org'"
- exec: echo "End of custom commands"