WP Discourse führt zahlreiche Anfragen an site.json durch

Ich arbeite an einer Integration für einen Kunden und hatte einen Tail auf den Discourse-Logs, während ich an seinem WordPress-Forum gearbeitet habe.

Und das ist, was ich gesehen habe (Entschuldigung für das seltsame Log-Format). Die IP-Adresse ist die IP-Adresse des WordPress-Servers. Er verwendet WP Discourse 2.5.5.

Ich habe den Code durchgesehen und kann nicht herausfinden, warum das passiert.

2024-10-23T06:39:30+00:00|67.225.163.100|5857|0.023|200|GET /site.json HTTP/1.1
2024-10-23T06:39:30+00:00|67.225.163.100|5857|0.022|200|GET /site.json HTTP/1.1
2024-10-23T06:39:30+00:00|67.225.163.100|5857|0.020|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.023|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.024|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.020|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.019|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.022|200|GET /site.json HTTP/1.1
2024-10-23T06:39:31+00:00|67.225.163.100|5857|0.021|200|GET /site.json HTTP/1.1
2024-10-23T06:39:32+00:00|67.225.163.100|5857|0.018|200|GET /site.json HTTP/1.1
2024-10-23T06:39:32+00:00|67.225.163.100|5857|0.018|200|GET /site.json HTTP/1.1
2024-10-23T06:39:32+00:00|67.225.163.100|5857|0.021|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.021|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.024|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.020|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.024|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.021|200|GET /site.json HTTP/1.1
2024-10-23T06:39:33+00:00|67.225.163.100|5857|0.022|200|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|5857|0.022|200|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|5857|0.023|200|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|5857|0.021|200|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|662|0.012|429|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|662|0.014|429|GET /site.json HTTP/1.1
2024-10-23T06:39:34+00:00|67.225.163.100|662|0.011|429|GET /site.json HTTP/1.1
2 „Gefällt mir“

Ich stelle mir vor, dass es von diesem Aufruf kommt: wp-discourse/lib/plugin-utilities.php at main · discourse/wp-discourse · GitHub

Welcher anscheinend in 3 Fällen verwendet wird:

  • Füllen des Kategorie-Selectors in einem Formular
  • Meta-Box
  • discourse-sidebar

Ja.
Das Seltsame ist, dass es zwischengespeichert werden soll und ich keinen Grund zu der Annahme habe, dass dies nicht der Fall ist.

$categories = get_transient( 'wpdc_discourse_categories' );
if ( ! empty( $options['publish-category-update'] ) || ! $categories ) {
  $body = $this->discourse_request( '/site.json' );
  if ( is_wp_error( $body ) ) {
    return $body;
  }

  if ( $body->categories ) {

    // removed for brevity

    // Note that setting the cache to 0 will disable transient expiration.
    $category_cache_period = apply_filters( 'wpdc_category_cache_minutes', 10 );
    set_transient( 'wpdc_discourse_categories', $discourse_categories, intval( $category_cache_period ) * MINUTE_IN_SECONDS );

    return $discourse_categories;
  } else {
    return new \WP_Error( 'key_not_found', 'The categories key was not found in the response from Discourse.' );
  }
}

EDIT Wenn ich die Transienten aufliste, habe ich einen Schlüssel timeout_wpdc_discourse_categories mit einem Zeitstempel in 5 Minuten, aber ich habe keinen wpdc_discourse_categories :thinking:

EDIT 2 set_transient( 'wpdc_discourse_categories', $discourse_categories, intval( $category_cache_period ) * MINUTE_IN_SECONDS ); gibt false zurück. $discourse_categories ist korrekt gefüllt. Andere Transienten funktionieren.

Update: Das Transiente wird einfach nicht gespeichert. Es wird gespeichert, wenn ich es mit json_encode() kodiert habe.

Außerdem kann ich dies auf einer anderen WordPress-Instanz nicht reproduzieren, daher verschiebe ich dies in den Support, da ich glaube, dass es sich um ein WordPress-Problem handelt. Ich vermute, dass ein Sicherheitspaket stört.

1 „Gefällt mir“