目前,WordPress 和 Discourse 的链接工作方式是,每篇文章都会自动以隐藏状态传输到 Discourse。因此,即使是没有进行讨论的文章也会被传输。
这非常消耗资源,因为 WordPress 会创建许多“空”主题。
有人能想到一个解决方案,让只有在开始讨论的文章才从 WP 传输到 Discourse 吗?
目前,WordPress 和 Discourse 的链接工作方式是,每篇文章都会自动以隐藏状态传输到 Discourse。因此,即使是没有进行讨论的文章也会被传输。
这非常消耗资源,因为 WordPress 会创建许多“空”主题。
有人能想到一个解决方案,让只有在开始讨论的文章才从 WP 传输到 Discourse 吗?
嘿 @Petr_Mišák,
要做到这一点,您需要将 WordPress 上创建的评论导入 Discourse 作为帖子。使用 WP Discourse 插件无法实现这一点,并且在不久的将来也不太可能得到支持。有关这方面的更广泛的思考,请参阅
话虽如此,我想到了,一旦我们在 ActivityPub 插件中添加了 Discourse 分类参与者关注其他 ActivityPub 参与者的功能(我目前正在开发中),您或许可以通过某种方式配置 WordPress ActivityPub 插件来实现这一点。尽管这只是猜测。
我还想更深入地了解为什么您认为这“消耗资源”。如果您发布了大量未获得参与的文章,也许可以考虑在论坛上发布一部分更有可能获得参与的文章?反之,大量没有回复的嵌入式主题是否以某种您观察到的方式损害了您的社区?也许您可以做些什么来解决根本问题,可以说?
为了方便理解,我认为您有一个热门的 WordPress 网站,有很多帖子,并且最近创建了一个 Discourse 论坛,并将 Discourse WordPress 插件添加到了您的网站。
您的 WordPress 网站上有多少帖子?旧帖子是否经常收到评论,还是人们通常只评论新帖子?
在解决方案方面,您是否会考虑需要向 WordPress 网站添加自定义代码的解决方案,还是只对不需要任何自定义代码的方法感兴趣?
如果网站上的帖子通常在发布后只在短时间内收到评论,那么最简单的解决方案就是开始将网站上最新的帖子发布到 Discourse。
下一个最简单的做法是向您的网站添加一个插件,该插件修改 WP Discourse 的“开始讨论”链接,使其不再是指向 Discourse 主题的链接,而是触发 WP Discourse 插件将帖子发布到 Discourse 的链接。实现这一目标最棘手的部分是弄清楚如何处理第一次单击“开始讨论”链接的用户的情况——他们是否应该在主题发布后自动重定向到该主题,他们在主题发布期间会看到什么,等等。
另一种可能的解决方案不需要自定义 WordPress 插件,但需要一些可能昂贵的开发时间,那就是找人编写一个导入脚本,将您网站上现有的所有帖子、评论和用户导入到 Discourse。这将解决空主题的问题。如果采取这种方法,可以考虑使用您的 WordPress 网站作为 Discourse 网站的 DiscourseConnect 提供商。这将方便导入的用户访问 Discourse。
空主题不消耗多少资源。您说的是成千上万个吗?
这可能只是我翻译错误,但我不想在 Discourse 中发布 WordPress 评论,只想在 Discourse 中讨论 WordPress 文章的主题。
为此,我需要 WordPress 插件在每篇已发布的文章发布后,在 Discourse 中插入一个隐藏的主题。
我非常介意的是,WordPress 文章与 Discourse 中的评论之间的链接是在文章发布时创建的,而不是在有人表示有兴趣讨论该主题时创建的。
考虑到所有文章中只有 10% 有人评论,但 WordPress 插件会为每篇已发布的文章在 Discourse 中创建一个链接。因此,以这种方式创建的 90% 的链接将保持隐藏状态,并白白占用资源。
我们每天发布约 13 篇文章。所以一年有 13*365=4,745 篇文章。其中 4,270 篇将在 Discourse 系统中设置为隐藏主题,并且永远不会有评论添加。这意味着 10 年内将有 42,700 个垃圾主题。
解决方案是,隐藏主题不在文章在 WordPress 中发布时创建,而是在有人在 WordPress 文章下表示有兴趣评论时才创建该主题。
这样就不需要创建隐藏且未使用的 Discourse 线程了。
正如您所说,我们有一个访问量很大的 WordPress 网站,但我们正在将用户帐户、登录名、文章评论完全迁移到 Discourse。WordPress 将只成为一个“DiscourseConnect 客户端”。
我们每天发布大约 13 篇文章 ![]()
人们通常会评论新文章,但一篇旧文章的讨论发展起来也并不罕见。我们试图在文章发布一段时间后对其进行更新。添加到文章的新信息可以重新点燃讨论。
我们很乐意在 WordPress 中添加一段代码。
使用当前的 Discourse WordPress 插件,我们计划只将 2023 年 11 月 1 日之后发布的新文章添加到 Discourse,但这将在 Discourse 中创建数千个未使用的主题。此外,如果有人想评论 2015 年的文章,他们将无法做到,因为该主题在 Discourse 中不存在。
如果主题仅在用户点击“开始讨论”时创建,那将是最好的。
我大致设想整个过程将如何进行?我将举一个说明性但虚构的例子。
然后有人点击 WordPress 文章下方的“开始讨论”按钮
如果同一个人想在同一篇 WordPress 文章上“添加评论”(另一条评论)
使用 JavaScript 只会在有人点击“开始讨论”并想添加第一条评论时才会在 Discourse 中创建一个新主题。
我们也许可以自己完成整个解决方案,但目前 WordPress 程序员短缺。此外,如果此功能直接包含在官方 Discourse 插件中,那将是最好的。
在我们的案例中,这大约是10年内50,000个主题。
这没什么大不了的,但你可以每年清理掉一些几年前的。
清理它是有意义的,但我们会尝试更新旧文章并在发布一段时间后激活讨论。因此,删除不是我们理想的解决方案。 …
这都说得通,尤其是在处理已发布的文章时。我唯一担心的是,依赖自定义代码会增加 WordPress/Discourse 集成的复杂性。不过我认为应该没问题。请确保您的开发人员使用 WP Discourse 插件的 action 和 filter 钩子,并且不要编辑核心插件的代码。他们需要弄清楚在点击“开始讨论”链接时如何调用公共 sync_to_discourse 方法:wp-discourse/lib/sso-client/sso-client-base.php at main · discourse/wp-discourse · GitHub WordPress 文章中。
那太好了!也许可以看看这个 Discourse 站点:https://bbs.boingboing.net/c/boing/3。他们使用 WordPress 插件将类似数量的文章发布到 Discourse。在他们的案例中,他们会自动将所有新文章发布到 Discourse。他们没有将 WordPress 网站设置 Discourse 之前创建的文章发布到 Discourse。
在这个论坛上是否有任何合适的地方可以让我找到开发者来修改上面描述的 Discourse 的 WordPress 插件?
谢谢,你速度很快。我本来在分类里找,但没找到。这让我很惊讶。不过搜索帮了我。
感谢您详细的回复 Petr,但我有点困惑。
如果您不想要 WordPress 评论,并且 Discourse 中还没有相关主题,那么人们将如何表达对讨论文章的兴趣?
*编辑 啊,我看到了,您已经设计了一个用户体验。
是的,这完全可行。
现在想来,我认为这可能是该插件的一个小缺陷,我们没有更简单的方法来做到这一点。我认为添加一个实用函数以及一个连接到它的短代码和区块是有意义的。我将在当前版本之后的下一个版本中对此进行研究。
为 Discourse 的官方 WordPress 插件添加支持是个好主意。能否大致了解该插件的哪个版本以及需要多长时间才能实现此新功能?
我下周将开始着手处理这个问题,以便添加到 2.5.1(下下个版本)中。@Petr_Mišák 你将能够使用它来实现你的目标。
太好了,我很期待。我们已经在主站 https://www.svetandroida.cz/ 上部署了 Discourse。