Toon posts:

[WP-CLI] Optie search-replace is niet altijd volledig

Pagina: 1
Acties:

Vraag


  • technorabilia
  • Registratie: November 2006
  • Laatst online: 19-05 17:04
Mijn vraag
Bij het overzetten van een productie Wordpress omgeving naar een testomgeving op mijn lokale server wil ik zowel de site url https://www.xxxxxx.com wijzigen in https://test.localhost en de www directory /home/xxxxxx/domains/xxxxxx.com/public_html omzetten naar /var/www/html.

Het omzetten doe ik met de WP-CLI en wel wp search-replace. Het vervangen van de site url gaat goed alleen het vervangen van de www directory laat steken vallen. In dit geval worden bij het uitvoeren van een wp search-replace <old> <new> niet alle voorkomens van <old> vervangen door <new>. Ook door gebruik te maken van de opties --all-tables en --precise.

Vraag 1:
Hoe kan ik ervoor zorgen dat wp search-replace zijn werk volledig doet?

Vraag 2:
Je ziet vaak dat alleen de site url wordt vervangen. Is het niet nodig om ook de www directory aan te passen. Je zou toch verwachten van wel?

Relevante software en hardware die ik gebruik
Laatste docker images mariadb, wordpress:latest en wordpress:cli.

Wat ik al gevonden of geprobeerd heb
Export de database en zoek naar de te vervangen string. Deze string wordt gevonden. Zoals verwacht.

Voer hierna de search & replace uit.

Export de database opnieuw en zoek opnieuw naar de te vervangen string. Deze string wordt gevonden terwijl je verwacht dat deze niet meer aanwezig is.

root@DS716:/volume1/docker/blog# docker-compose run --rm wordpress-cli db export blog_db.sql
Starting blog_db ... done
Starting blog_wordpress ... done
Success: Exported to 'blog_db.sql'.
root@DS716:/volume1/docker/blog# grep -q '/home/xxxxxx/domains/xxxxxx.com/public_html' html/blog_db.sql && echo GEVONDEN
GEVONDEN
root@DS716:/volume1/docker/blog# docker-compose run --rm wordpress-cli search-replace '/home/xxxxxx/domains/xxxxxx.com/public_html' '/var/www/html' --all-tables
Starting blog_db ... done
Starting blog_wordpress ... done
+-----------------------+-------------------------+--------------+------+
| Table                 | Column                  | Replacements | Type |
+-----------------------+-------------------------+--------------+------+
| wp_commentmeta        | meta_key                | 0            | SQL  |
| wp_commentmeta        | meta_value              | 0            | SQL  |
| wp_comments           | comment_author          | 0            | SQL  |

<knip - hele lijst met tabellen>

| wp_yoast_seo_links    | type                    | 0            | SQL  |
| wp_yoast_seo_links    | language                | 0            | SQL  |
| wp_yoast_seo_links    | region                  | 0            | SQL  |
+-----------------------+-------------------------+--------------+------+
Success: Made 0 replacements.
root@DS716:/volume1/docker/blog# docker-compose run --rm wordpress-cli db export blog_db.sql
Starting blog_db ... done
Starting blog_wordpress ... done
Success: Exported to 'blog_db.sql'.
root@DS716:/volume1/docker/blog# grep -q '/home/xxxxxx/domains/xxxxxx.com/public_html' html/blog_db.sql && echo GEVONDEN
GEVONDEN
root@DS716:/volume1/docker/blog#

👉🏻 Blog 👈🏻



Tweakers maakt gebruik van cookies

Tweakers plaatst functionele en analytische cookies voor het functioneren van de website en het verbeteren van de website-ervaring. Deze cookies zijn noodzakelijk. Om op Tweakers relevantere advertenties te tonen en om ingesloten content van derden te tonen (bijvoorbeeld video's), vragen we je toestemming. Via ingesloten content kunnen derde partijen diensten leveren en verbeteren, bezoekersstatistieken bijhouden, gepersonaliseerde content tonen, gerichte advertenties tonen en gebruikersprofielen opbouwen. Hiervoor worden apparaatgegevens, IP-adres, geolocatie en surfgedrag vastgelegd.

Meer informatie vind je in ons cookiebeleid.

Sluiten

Toestemming beheren

Hieronder kun je per doeleinde of partij toestemming geven of intrekken. Meer informatie vind je in ons cookiebeleid.

Functioneel en analytisch

Deze cookies zijn noodzakelijk voor het functioneren van de website en het verbeteren van de website-ervaring. Klik op het informatie-icoon voor meer informatie. Meer details

janee

    Relevantere advertenties

    Dit beperkt het aantal keer dat dezelfde advertentie getoond wordt (frequency capping) en maakt het mogelijk om binnen Tweakers contextuele advertenties te tonen op basis van pagina's die je hebt bezocht. Meer details

    Tweakers genereert een willekeurige unieke code als identifier. Deze data wordt niet gedeeld met adverteerders of andere derde partijen en je kunt niet buiten Tweakers gevolgd worden. Indien je bent ingelogd, wordt deze identifier gekoppeld aan je account. Indien je niet bent ingelogd, wordt deze identifier gekoppeld aan je sessie die maximaal 4 maanden actief blijft. Je kunt deze toestemming te allen tijde intrekken.

    Ingesloten content van derden

    Deze cookies kunnen door derde partijen geplaatst worden via ingesloten content. Klik op het informatie-icoon voor meer informatie over de verwerkingsdoeleinden. Meer details

    janee