Trusted WordPress tutorials, when you need them most.
Beginner’s Guide to WordPress
WPB Cup
25 Million+
Websites using our plugins
16+
Years of WordPress experience
3000+
WordPress tutorials
by experts

Wie man WordPress von einem lokalen Server auf eine Live-Site verschiebt (2 Methoden)

Viele Benutzer von WordPress ziehen es vor, an ihren Websites über einen lokalen Server auf ihrem Computer zu arbeiten. So können Sie privat an Ihrer Website arbeiten, bevor Sie die Änderungen online zur Verfügung stellen.

Schließlich müssen Sie sie auf einen Live-Server verschieben, um sie für Online-Besucher zugänglich zu machen. Dieser Übergang ist wichtig, um sicherzustellen, dass Ihre Website auf der Live-Site ordnungsgemäß funktioniert.

Wir haben an vielen lokalen Websites gearbeitet und mussten daher lernen, wie man Inhalte am einfachsten auf Live-Websites übertragen kann.

In diesem Artikel geben wir Ihnen eine schrittweise Anleitung, wie Sie WordPress von einem lokalen Server auf eine Website umziehen können.

How to move WordPress from local server to live site (2 methods)

Warum WordPress von einem lokalen Server auf eine Live-Site verschieben?

Die Erstellung Ihres WordPress-Blogs auf einem lokalen Server ist ein sicherer Weg, um Änderungen an Ihrer Website zu testen, ohne die Besucher zu beeinträchtigen.

Wenn Sie Ihre Website perfektioniert haben, ist der nächste Schritt der Umzug von Ihrem lokalen Server auf eine Live-Site.

Wir zeigen Ihnen zwei Möglichkeiten, wie Sie Ihre Website von einem lokalen Server auf eine Live-Site übertragen können.

Die erste Methode verwendet ein WordPress-Migrations-Plugin und ist für Anfänger zu empfehlen.

In der zweiten Methode zeigen wir Ihnen, wie Sie WordPress manuell von einem lokalen Server auf eine Live-Site verschieben können.

Sie können die Methode wählen, die für Sie am besten geeignet ist:

Bevor Sie Ihre WordPress-Website migrieren

Um WordPress von einem lokalen Server auf einen Live-Server zu migrieren, müssen Sie einige Vorkehrungen treffen.

Zunächst gehen wir davon aus, dass Sie eine WordPress Website auf einem lokalen Server (auch localhost genannt) auf Ihrem Computer laufen haben und dass Sie vollen Zugriff darauf haben.

Als Nächstes benötigen Sie einen Domänennamen und Webhosting.

Wir haben unzählige Geschichten von Anfängern gehört, die mit schlechten oder kostenlosen Hosting-Anbietern angefangen und es bereut haben. Nach unserer Erfahrung ist die Wahl des richtigen Hosting-Anbieters entscheidend für den Erfolg einer Website.

Um Ihnen die Entscheidung zu erleichtern, empfehlen wir Bluehost. Bluehost ist ein offiziell empfohlener WordPress-Hosting-Anbieter und bietet WPBeginner-Nutzern einen exklusiven Rabatt sowie eine kostenlose Domain und SSL.

Im Grunde können Sie schon für 1,99 $ pro Monat einsteigen.

Wenn Sie eine gute Bluehost-Alternative suchen, können Sie sich Hostinger ansehen. Sie bieten auch einen exklusiven Rabatt für WPBeginner-Nutzer mit einem kostenlosen Domainnamen.

Wenn Sie es sich leisten können, ein wenig mehr zu bezahlen, dann schauen Sie sich SiteGround an. Sie haben auch ein spezielles Angebot für WPBeginner-Leser.

Wenn Sie Hilfe bei der Einrichtung Ihrer Website benötigen, folgen Sie unserer Schritt-für-Schritt-Anleitung für die Erstellung einer Website.

Schließlich benötigen Sie ein FTP-Programm und müssen wissen , wie Sie FTP verwenden, um Ihre lokale Server-Site auf die Live-Site hochzuladen.

Sind Sie bereit? Beginnen wir mit der Migration Ihrer WordPress-Website.

Video-Anleitung

Subscribe to WPBeginner

Wenn Sie eine schriftliche Anleitung bevorzugen, dann lesen Sie einfach weiter.

Methode 1: Übertragen von WordPress vom lokalen Server auf die Live-Site mithilfe eines Migrations-Plugins (empfohlen)

Diese Methode ist einfacher und wird für Anfänger empfohlen. Wir werden ein WordPress-Migrations-Plugin verwenden, um WordPress vom lokalen Host auf eine Live-Site zu verschieben.

Schritt 1: Installieren und Einrichten des Duplicator-Plugins

Zunächst müssen Sie das Duplicator-Plugin auf Ihrer lokalen Website installieren und aktivieren. Weitere Einzelheiten finden Sie in unserer Schritt-für-Schritt-Anleitung für die Installation eines WordPress-Plugins.

Profi-Tipp: Es gibt auch eine Pro-Version von Duplicator, die sichere Backups, Cloud-Speicher, einfache Wiederherstellung von Websites und mehr bietet.

Nach der Aktivierung müssen Sie auf die Seite Duplicator ” Backups gehen und auf die Schaltfläche “Neu erstellen” klicken.

Create new backup for migration

Daraufhin wird ein Bildschirm angezeigt, in dem Sie der Sicherung einen Namen geben können.

Klicken Sie dann auf die Schaltfläche “Weiter”.

Name backup package

Duplicator führt nun einige Tests durch, um festzustellen, ob alles in Ordnung ist.

Wenn alle Punkte mit “Gut” markiert sind, klicken Sie auf den Button “Erstellen”.

Build package

Dieser Vorgang kann einige Minuten dauern, je nach Größe Ihrer Website. Sie müssen diesen Tab geöffnet lassen, bis er abgeschlossen ist.

Wenn Sie fertig sind, sehen Sie Download-Optionen für “Installer”- und “Archiv”-Pakete. Sie müssen auf die Schaltfläche “Beide Dateien herunterladen” klicken, um beide Dateien auf Ihren Computer herunterzuladen.

Download both backup files

Die “Archiv”-Datei ist eine vollständige Kopie Ihrer WordPress-Website. Sie enthält alle WordPress-Kerndateien sowie Ihre Bilder, Uploads, Themes, Plugins und ein Backup Ihrer WordPress-Datenbank.

Die “Installer”-Datei ist ein Skript, das den gesamten Migrationsprozess automatisiert, indem es die Archivdatei mit Ihrer Website entpackt.

Schritt 2: Erstellen Sie eine Datenbank für Ihre Live-WordPress-Website

Bevor Sie das Installationsprogramm ausführen oder die WordPress-Website von localhost auf Ihren Hosting-Server hochladen können, müssen Sie eine MySQL-Datenbank für Ihre neue Live-Website erstellen.

Wenn Sie bereits eine MySQL-Datenbank erstellt haben, können Sie diesen Schritt überspringen.

Um eine Datenbank zu erstellen, müssen Sie das cPanel-Dashboard Ihres Hosting-Accounts aufrufen. Suchen Sie dann den Abschnitt “Datenbanken” und klicken Sie auf das Symbol “MySQL-Datenbank-Assistent”.

MySQL Database Wizard

Auf dem nächsten Bildschirm gibt es ein Feld zum Erstellen einer neuen Datenbank.

Geben Sie einfach einen Namen für Ihre Datenbank ein und klicken Sie auf die Schaltfläche “Datenbank erstellen”.

Name new database

cPanel wird nun eine neue Datenbank für Sie erstellen.

Danach müssen Sie einen Benutzernamen und ein Passwort für Ihren neuen Benutzer eingeben und dann auf die Schaltfläche “Benutzer erstellen” klicken.

Create new database user

Als nächstes müssen Sie den soeben erstellten Benutzer zur Datenbank hinzufügen.

Klicken Sie zunächst auf das Kontrollkästchen “Alle Berechtigungen”.

Check all privileges

Blättern Sie dann nach unten und klicken Sie auf die Schaltfläche “Änderungen vornehmen”, um Ihre Änderungen zu speichern.

Ihre Datenbank ist nun bereit, mit Ihrer WordPress-Website verwendet zu werden. Notieren Sie sich unbedingt den Namen der Datenbank, den Benutzernamen und das Passwort. Sie werden diese Informationen im nächsten Schritt benötigen.

Schritt 3: Upload von Dateien vom lokalen Server auf die WordPress-Live-Website

Nun müssen Sie das Archiv und die Installationsdateien von Ihrer lokalen Website auf Ihr Hosting-Konto hochladen.

Stellen Sie zunächst mit einem FTP-Client eine Verbindung zu Ihrer Live-Website her. Vergewissern Sie sich nach der Verbindung, dass das Stammverzeichnis Ihrer Website völlig leer ist.

Normalerweise ist das Stammverzeichnis der Ordner /home/public_html/.

Einige WordPress-Hosting-Unternehmen installieren WordPress automatisch, wenn Sie sich anmelden. Wenn Sie dort WordPress-Dateien haben, müssen Sie diese löschen.

Danach können Sie die Dateien archive.zip und installer.php von Duplicator in Ihr leeres Stammverzeichnis hochladen.

Upload archive and installer files

Schritt 4: Ausführen des Migrationsskripts

Nachdem Sie die Migrationsdateien hochgeladen haben, müssen Sie die folgende URL in Ihrem Browser aufrufen:

http://example.com/installer.php

Vergessen Sie nicht, “example.com” durch Ihren eigenen Domänennamen zu ersetzen.

Dadurch wird der Duplicator-Migrationsassistent gestartet.

Das Installationsprogramm führt ein paar Tests durch und initialisiert das Skript.

Duplicator migration wizard step 1

Im Abschnitt Setup werden Sie aufgefordert, den MySQL-Host, den Datenbanknamen, den Benutzernamen und das Passwort einzugeben.

Ihr Host wird wahrscheinlich ein lokaler Host sein. Danach geben Sie die Details der Datenbank ein, die Sie im vorherigen Schritt erstellt haben.

Klicken Sie dann auf die Schaltfläche “Validieren”, um sicherzustellen, dass die eingegebenen Daten korrekt sind.

Validate settings

Klicken Sie anschließend auf die Schaltfläche “Weiter”, um fortzufahren.

Duplicator importiert nun die Sicherung Ihrer WordPress-Datenbank aus dem Archiv in Ihre neue Datenbank.

Außerdem werden die URLs aktualisiert, die auf die lokale Website und Ihre neue Website verweisen.

Sie können nun auf die Schaltfläche “Admin Login” klicken, um in den WordPress-Administrationsbereich Ihrer Live-Site zu gelangen.

Admin login

Sobald Sie sich bei Ihrer Live-Site anmelden, bereinigt Duplicator automatisch die Installationsdateien.

Das war’s schon. Sie haben WordPress erfolgreich vom lokalen Server auf Ihre Live-Site verschoben.

Methode 2: Manuelle Übertragung von WordPress vom lokalen Server auf die Live-Site

In dieser Methode zeigen wir Ihnen, wie Sie WordPress manuell vom lokalen Server auf Ihre Live-Site verschieben können. Sie ist nützlich, wenn die erste Methode nicht funktioniert oder wenn Sie es lieber manuell machen möchten.

Schritt 1: Lokale WordPress-Datenbank exportieren

Als Erstes müssen Sie Ihre lokale WordPress-Datenbank exportieren. Wir werden dafür phpMyAdmin verwenden.

Wenn Sie damit nicht vertraut sind, sollten Sie einen Blick auf unsere Anleitung zur WordPress-Datenbankverwaltung mit phpMyAdmin werfen.

Gehen Sie einfach auf http://localhost/phpmyadmin/ und klicken Sie auf Ihre WordPress-Datenbank. Klicken Sie dann auf die Schaltfläche “Exportieren” in der oberen Menüleiste.

Export from localhost

In der Option “Exportmethode:” können Sie “Schnell” oder “Individuell” wählen. Die Option “Individuell” bietet Ihnen mehr Optionen für den Export Ihrer Datenbank.

Wir empfehlen jedoch, “Schnell” zu wählen und dann auf die Schaltfläche “Los” zu klicken, um Ihre Datenbank herunterzuladen.

Export WordPress database using phpMyAdmin

Schritt 2: WordPress-Dateien auf die Live-Site hochladen

Nun müssen wir alle Dateien Ihrer Website auf die Live-Site verschieben.

Um loszulegen, öffnen Sie Ihren FTP-Client und verbinden Sie sich mit Ihrem Webhosting-Konto.

Sobald Sie mit Ihrer Website verbunden sind, stellen Sie sicher, dass Sie die Dateien in das richtige Verzeichnis hochladen. Wenn Sie zum Beispiel möchten, dass die Website auf “yourite.com” gehostet wird, müssen Sie alle Dateien in Ihr Verzeichnis public_html hochladen.

Wählen Sie nun Ihre lokalen WordPress-Dateien aus und laden Sie sie auf Ihren Live-Server hoch.

Upload WordPress files FTP

Schritt 3: Erstellen Sie eine MySQL-Datenbank auf Ihrer Live-Site

Während Ihr FTP-Client Ihre WordPress-Dateien hochlädt, können Sie damit beginnen, Ihre Datenbank auf den Live-Server zu importieren.

Die meisten Hosting-Anbieter von WordPress bieten cPanel zur Verwaltung Ihres Kontos an. Wir zeigen Ihnen, wie Sie eine Datenbank mit cPanel erstellen.

Melden Sie sich zunächst in Ihrem cPanel-Dashboard an und klicken Sie auf das Symbol “MySQL-Datenbank-Assistent”, das Sie im Abschnitt “Datenbanken” finden.

Select MySQL database wizard

Auf dem nächsten Bildschirm können Sie eine neue Datenbank anlegen.

Geben Sie einen Namen für Ihre Datenbank ein und klicken Sie dann auf “Datenbank erstellen”.

Name and create new database

cPanel wird nun automatisch eine neue Datenbank für Sie erstellen.

Als nächstes müssen Sie einen Benutzernamen und ein Passwort für Ihren neuen Benutzer eingeben und dann auf “Benutzer erstellen” klicken.

Create new database user

Danach müssen Sie den soeben erstellten Benutzer in die Datenbank aufnehmen.

Aktivieren Sie zunächst das Kontrollkästchen “Alle Berechtigungen”.

Check all privileges checkbox

Blättern Sie dann nach unten und klicken Sie auf “Änderungen vornehmen”, um Ihre Änderungen zu speichern.

Sie haben erfolgreich eine neue Datenbank für Ihre Live-WordPress-Site erstellt.

Schritt 4: WordPress-Datenbank in die Live-Site importieren

Der nächste Schritt ist der Import Ihrer WordPress-Datenbank.

Gehen Sie zu Ihrem cPanel Dashboard, scrollen Sie nach unten zum Abschnitt ‘Datenbanken’ und klicken Sie auf ‘phpMyAdmin’.

Click on phpMyAdmin

Dies führt Sie zu phpMyAdmin, wo Sie auf die Datenbank klicken, die Sie gerade erstellt haben. phpMyAdmin zeigt Ihre neue Datenbank ohne Tabellen an.

Klicken Sie dann im oberen Menü auf die Registerkarte “Importieren”. Klicken Sie auf der Importseite auf die Schaltfläche “Datei auswählen” und wählen Sie dann die Datenbankdatei von der lokalen Website, die Sie im ersten Schritt gespeichert haben.

Import database via phpMyAdmin

Klicken Sie anschließend auf die Schaltfläche “Go” unten auf der Seite. Ihre Datenbank wird automatisch in phpMyadmin importiert.

Schritt 5: Ändern Sie die URL der Website

Nun müssen Sie die Website-URL in Ihrer Datenbank ändern, damit sie sich mit Ihrer Live-WordPress-Site verbindet.

Suchen Sie in phpMyAdmin nach der Tabelle wp_options in Ihrer Datenbank, die Sie oben importiert haben.

Wenn Sie Ihr Datenbankpräfix geändert haben, könnte es statt wp_options {new_prefix}_options heißen.

Klicken Sie dann auf die Schaltfläche “Durchsuchen” neben wp_options. Oder klicken Sie auf den Link in der Seitenleiste, um die Seite mit einer Liste der Felder in der Tabelle wp_options zu öffnen.

Browse the wp options table

Dann müssen Sie in der Spalte options_name nach der Option siteurl suchen.

Klicken Sie dann auf das Symbol “Bearbeiten”.

Edit siteurl in phpMyAdmin

Daraufhin öffnet sich ein Fenster, in dem Sie das Feld bearbeiten können.

Im Eingabefeld option_value sehen Sie die URL Ihrer lokalen Installation, die etwa http://localhost/test lautet.

In dieses Feld müssen Sie die URL Ihrer neuen Website eingeben, z. B. https://www.wpbeginner.com.

Anschließend können Sie das Feld speichern, indem Sie auf die Schaltfläche “Go” klicken.

edit the siteurl field

Als nächstes müssen Sie die gleichen Schritte wie oben für den Namen der Home-Option ausführen. Das Menü wp_options kann einige Seiten lang sein. Normalerweise befindet sich die Home-Option auf der zweiten Seite.

Aktualisieren Sie dann die Home-URL, damit sie mit der URL Ihrer Live-Site übereinstimmt.

Schritt 6: Einrichten Ihrer Live-Site

Nachdem Sie nun die Datenbank importiert und Ihre Inhalte hochgeladen haben, ist es an der Zeit, WordPress zu konfigurieren.

Zu diesem Zeitpunkt sollte auf Ihrer Website die Fehlermeldung“Fehler beim Herstellen einer Datenbankverbindung” angezeigt werden.

Um dies zu beheben, verbinden Sie sich mit einem FTP-Client mit Ihrer Website und öffnen Sie die Datei wp-config.php.

Sie werden nach den folgenden Codezeilen suchen:

// ** MySQL settings - You can get this info from your web host ** //
/** The name of the database for WordPress */
define( 'DB_NAME', 'database_name_here' );
/** MySQL database username */
define( 'DB_USER', 'username_here' );
/** MySQL database password */
define( 'DB_PASSWORD', 'password_here' );
/** MySQL hostname */
define( 'DB_HOST', 'localhost' );

Sie müssen den Datenbanknamen, den Benutzernamen und das Passwort angeben, die Sie zuvor erstellt haben.

Speichern Sie anschließend die Datei wp-config.php und laden Sie sie zurück auf Ihren WordPress-Hosting-Server.

Wenn Sie jetzt Ihre Website besuchen, sollte sie live sein.

Danach müssen Sie sich in Ihr WordPress-Administrationspanel einloggen und zu den Einstellungen ” Allgemein gehen. Dann, ohne etwas zu ändern, scrollen Sie zum Ende und klicken Sie auf die Schaltfläche “Änderungen speichern”.

Save general settings

Dadurch wird sichergestellt, dass die URL Ihrer Website überall dort korrigiert wird, wo sie sein muss.

Wenn Sie das getan haben, gehen Sie zu Einstellungen ” Permalinks, scrollen Sie nach unten und klicken Sie auf “Änderungen speichern”, um sicherzustellen, dass alle Beitragslinks funktionieren.

Save permalinks settings

Wenn Sie eine WordPress-Site von einer Domain auf eine andere oder von einem lokalen Server auf eine Live-Site verschieben, werden Sie mit defekten Links und fehlenden Bildern konfrontiert.

Wir zeigen Ihnen zwei Möglichkeiten zur Aktualisierung von URLs. Sie können diejenige wählen, die für Sie am besten geeignet ist.

1. URLs mit dem Plugin “Search & Replace Everything” aktualisieren (empfohlen)

Der sicherste Weg, dies zu beheben, ist die Verwendung von Search & Replace Everything. Dabei handelt es sich um ein leistungsstarkes WordPress Plugin, mit dem Sie problemlos Massenaktualisierungen auf Ihrer Website durchführen können, ohne komplexe Abfragen an die Datenbank zu stellen.

Zunächst müssen Sie das Plugin Search & Replace Everything installieren und aktivieren.

Gehen Sie nach der Aktivierung auf die Seite Werkzeuge ” WP Suchen & Ersetzen.

Search and replace URLs from local to live site migration

Hier müssen Sie die URL Ihrer lokalen Website in das Feld “Suchen nach” und die URL Ihrer Live-Website in das Feld “Ersetzen durch” eingeben.

Scrollen Sie ein wenig und klicken Sie unter den Tabellen auf “Alle auswählen”. Dadurch wird sichergestellt, dass das Plugin überall in der Datenbank nach der alten URL sucht.

Select tables

Klicken Sie nun auf den Button “Vorschau Suchen & Ersetzen”, um fortzufahren.

Das Plugin durchsucht Ihre Datenbank nach allen Instanzen der alten URL und zeigt dann eine Vorschau der Ergebnisse an.

Preview changes

Wenn alles gut aussieht, klicken Sie auf “Alles ersetzen”, um die Änderungen zu speichern.

Sie erhalten eine Warnung über die Änderungen, die Sie vornehmen. Klicken Sie auf “Ja”, um fortzufahren.

Das Plugin wird nun die Datenbank aktualisieren und die lokalen URLs durch die aktuelle URL Ihrer Website ersetzen.

2. URLs manuell aktualisieren (Erweitert)

Eine andere Möglichkeit, die URLs zu aktualisieren, ist die folgende SQL-Abfrage:

UPDATE wp_posts SET post_content = REPLACE(post_content, 'localhost/test/', 'www.yourlivesite.com/');

Gehen Sie einfach zu phpMyAdmin, klicken Sie auf Ihre Datenbank und dann im oberen Menü auf ‘SQL’ und fügen Sie die obige Abfrage hinzu.

Vergewissern Sie sich, dass Sie die URLs Ihrer lokalen Website und Ihrer Live-Website eingeben, und klicken Sie auf den Button “Go”.

Fixing WordPress images and broken URLs after moving to live site

Das war’s. Sie haben WordPress nun erfolgreich von Ihrem lokalen Server auf eine Live-Site migriert.

Hoffentlich funktioniert Ihre Live-Website jetzt reibungslos. Wenn Sie Fehler bemerken, können Sie unseren Leitfaden zu häufigen WordPress-Fehlern lesen, um Hilfe bei der Problembehandlung zu erhalten.

Wir hoffen, dass dieser Artikel Ihnen geholfen hat, WordPress von einem lokalen Server auf eine Live Website zu übertragen. Vielleicht interessiert Sie auch unser Leitfaden für den Umzug einer Live-Website auf einen lokalen Server oder die ultimative Checkliste für die Migration von Websites für praktische WordPress-Migrationsschritte.

Wenn Ihnen dieser Artikel gefallen hat, dann abonnieren Sie bitte unseren YouTube-Kanal für WordPress-Videotutorials. Sie können uns auch auf Twitter und Facebook finden.

Disclosure: Our content is reader-supported. This means if you click on some of our links, then we may earn a commission. See how WPBeginner is funded, why it matters, and how you can support us. Here's our editorial process.

Avatar

Editorial Staff at WPBeginner is a team of WordPress experts led by Syed Balkhi with over 16 years of experience in WordPress, Web Hosting, eCommerce, SEO, and Marketing. Started in 2009, WPBeginner is now the largest free WordPress resource site in the industry and is often referred to as the Wikipedia for WordPress.

The Ultimate WordPress Toolkit

Get FREE access to our toolkit - a collection of WordPress related products and resources that every professional should have!

Reader Interactions

908 KommentareLeave a Reply

  1. sam

    Isn’t it better to use a duplicator plugin instead of taking all this trouble as described in here
    or here
    I think using the duplicator is a easier. Feel free to add or correct me.

    • WPBeginner Support

      Yes, we have mentioned using Duplicator or BackupBuddy as the easier ways to do this in the article.

      Admin

  2. Louise

    Thanks so much for an excellent article – very straight forward and easy to understand.

  3. fadilah

    hi, i’m getting a problem with my permalink, my permalink is still pointed to my localhost something like fadil.dev so when i add a post/page, the permalink is pointed to my fadil.dev/?p=ID it should be pointed to fadil.com (my real domain) and not fadil.dev (my local domain) .. where i can find the configuration ? help me .. thankyou :)

      • fadilah

        my article/page works fine on the front-end, but the permalink on wp-admin when i added a new post/page appeared wrong , you can see my printscreen http://prntscr.com/2cfznc .. it should be terazam.com not terazam.dev

        • WPBeginner Support

          Seems like you didn’t change your site and home URLs either. Please follow all the steps mentioned above and your problem should get resolved.

        • fadilah

          i had changed my siteurl according to your instruction at 5th step before i asked this problem and my front-end issue was solved, thankyou :) … but it seems that when i changed the siteurl on wp_options table there was no effect with permalink on my wp-admin :(

        • fadilah

          SOLVED :)

          i found the config on Administration > Settings > General and you will find the “Site Address URL” and i changed it into the correct value. so WordPress Address and Site Address are different. i found it on wp documentation http://codex.wordpress.org/Moving_WordPress

          thankyou for your help :) have a nice day

  4. prox

    nice tutorial i was thinking to do and found your website luckily and also i would like to ask two thing

    1. what’s this footer advertisement option is it a plugin ?

    2 what’s the plugin your using for newsletter i saw when i enter to your site there’s nice pop up banner that saying do you want to lean about WordPress and then enter your email address

    please share if you don’t mind

    thank you

  5. Nathan

    Great help, thanks!

    One question, if I buy a theme, can I use it on both my local and live site even though they are different installations and thus have different WordPress id’s?

    I am building my first live site but I have set up a local to play with the designs and construct the content.

    Thanks.

    • WPBeginner Support

      Nathan, this is a theme licensing question and the themeshop you purchased it from would be better able to answer this. However, we don’t see any harm in that.

      Admin

  6. Deepo

    wonderful tutorial. complexity made simple

  7. Matt

    Hi. Firstly I’d like to thank you, this process was easy to understand and errorless on your end!

    My one hang-up was at the very end. I put in the SQL code in order to fix some linking errors, but must not have put the right local host because some small inconsistencies were not fixed. I have been using MAMP and accessing my site by going to “localhost:8888” Is this what I should put in that Step 7 code, or is there a different path?

    • WPBeginner Support

      Matt first you need to make sure that inside your wp_posts table you are using localhost:8888 inside post content. If yes, then use this in the step 7. If you are seeing all your links as localhost, then use localhost.

      Admin

  8. Dayomaks

    All instructions works fine, thanks, i am so glad, but the issue i am having now is importing my database…while trying to import my database to a live server i got these errors below:

    Error
    SQL query:


    — Database: `soundmode`

    — ——————————————————–

    — Table structure for table `xs_commentmeta`

    CREATE TABLE IF NOT EXISTS `xs_commentmeta` (

    `meta_id` BIGINT( 20 ) UNSIGNED NOT NULL AUTO_INCREMENT ,
    `comment_id` BIGINT( 20 ) UNSIGNED NOT NULL DEFAULT ‘0’,
    `meta_key` VARCHAR( 255 ) DEFAULT NULL ,
    `meta_value` LONGTEXT,
    PRIMARY KEY ( `meta_id` ) ,
    KEY `comment_id` ( `comment_id` ) ,
    KEY `meta_key` ( `meta_key` )
    ) ENGINE = INNODB DEFAULT CHARSET = utf8 AUTO_INCREMENT =1;

    MySQL said: Documentation

    #1046 – No database selected

    ANY ASSISTANCE ON THERE?

    • WPBeginner Support

      Check your database name, username, and password to make sure that you are using the correct settings to connect to your live site’s database.

      Admin

  9. Christie Bellah

    This worked great, thanks! In the past I had installed WordPress in the new hosting, dropped database tables, imported, etc. – this is so much faster and simpler.

  10. Stefano

    First of all, thanks for the tutorial – invaluable and well written.

    Unfortunately, I managed to get stuck anyway.
    I uploaded everything via filezilla and phpmyadmin, and when i try to go to my domain it doesn’t show up any error. But nothing else, either.

    Just a blank page – which is weird, because by typing /wp-admin at the end of the url i DO have access to the wordpress control panel, and every page seems to be all right.

    Sorry to bother, but I really have no clue about what’s happening..
    Thanks in advance!

    • Stefano

      Solved!
      Apparently, it had some issues with the theme loading.
      I couldn’t use the children theme i had worked on, but luckily I had changed just a couple of thing, so no big deal..

      • Stefano

        I did, and in fact the url worked (even if it showed just a blank page).
        I still have no clue about what happened, but setting up the theme again solved it.
        Lucky shot =P

  11. javed choudahry

    Hi
    Sir

    Thanku so much .This website is very good for wordpress learn and very help full .

  12. sesan

    please am having an error from step 4
    SQL query:


    — Database: `wordpress`

    CREATE DATABASE IF NOT EXISTS `wordpress` DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;

    MySQL said: Documentation
    #1044 – Access denied for user ‘Admin7393’@’%’ to database ‘wordpress’

    • WPBeginner Support

      Sesan, the export file prepared by phpmyadmin to import into your live site database, contains a line to check if a database exists if not then it tries to create it. To resolve this issue, you need to extract the zip archive you created. Inside it you will find a file with .sql extension. Open this file in a text editor like Notepad and then delete these lines

      CREATE DATABASE IF NOT EXISTS `wordpress` DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;

      Below this line you will see another line like this

      USE `wordpress`;

      Replace wordpress with the name of the database you are trying to import into.

      Save your changes and put the sql file back into a zip archive (if it is too big, other wise you can also import it as it is).

      Admin

      • sesan

        men you guys are d bomb it worked thank youuuuuuuuuuuuu!!!!!!!!!!!!!!

  13. Tyler

    Hi, thanks for the tutorial!

    I’m struggling with Step 2. Your tutorial shows several files/folders being uploaded whereas I only have wordpress.sql.gz from Step 1. I can’t seem to extract the file using any software but can open using a text editor.

    Any help would be greatly appreciated!

    • WPBeginner Support

      In the second step, you do not need to upload your phpMyAdmin export file (wordpress.sql.gz in your case). You need to upload your WordPress files which are located in htdocs or www folder of your localhost

      Admin

  14. Mario

    do I need a cpanel to do this procedure? I am using a plugin to backup and export databases already, unfortunately the host provider that the client is using does not have a cpanel.

  15. Rhomy Prama Dhieka (Web Designer)

    thanks for sharing.
    it help me alot migrating my wp website.
    would you mind if i translte this to my language, then i will put ur credit there ?
    thanks.

  16. ryan

    hi, i am using stablehost and have used them before with WP websites. I followed all your steps and I am getting a parked page from my hosting provider…

    • WPBeginner Support

      There can be several reasons for that. First make sure that you have installed WordPress in the root directory of your website. If you did then make a backup of your .htaccess file and delete the one from root directory of your website. If that doesn’t work, then find the default parked page files there might be an index.html file on your web server delete that file (Do Not delete index.php). If none of these help then contact your hosting provider.

      Admin

  17. Alex

    Thanks!

    I did a search for the ‘‹’ character in the extracted .sql file, but got an alert saying: The string ‘‹’ was not found.

    I don’t know if this matters, but I noticed that my local phpMyadmin version is 5.5.3, while my host’s phpMyadmin version is 3.5.8.2.

    Another note is that I had all my WordPress files already up on my public_html directory (which is your step 2) BEFORE exporting my local WordPress database (which is your step 1). I’m not sure if it makes a difference.

    I’ll try starting over with step 1, as you suggested, and if I get the same error then I may try the Duplicator plugin that you mentioned.

    Alex

  18. PatoPanichelli

    You really helped me. This step by step is awesome, I had no problems migrating from MAMP to a live site. Thanks

  19. Alex

    Thanks for the tutorial!

    Everything’s gone well until I get to the end of step 4. When I press the Go button at the bottom of the page, instead of having phpMyadmin import my WordPress database I get an error message that reads as follows:

    #1064 – You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘‹’ at line 1

    Can you let me know what you think may be causing this?

    Alex

    • WPBeginner Support

      Alex, it seems like the database file you are trying to import has a character ‘‹’ which is not supposed to be there. You have two options to fix that, first option is go back to your localhost/phpmyadmin and export your local database again and then try to import it again. If the same error occurs again, then extract your database gzip file using 7zip program. Open the .sql file in a text editor like notepad and look at the first line. Also take a look at our database management using phpMyAdmin guide to learn more.

      Admin

    • Anna

      Make sure you clicked on the database name on the lefthand side that you’d like to import to. Make sure that is highlighted and then try again. (phpMyAdmin version 4.0.8).

  20. qs

    I get this error when I import datebase into live site. How do i solve it?

    Error
    SQL query:

    /*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;

    /*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;

    /*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;

    /*!40101 SET NAMES utf8 */;


    — Database: `wordpress`

    CREATE DATABASE IF NOT EXISTS `wordpress` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci;

    MySQL said:

    #1044 – Access denied for user ‘bossaballsg’@’10.%’ to database ‘wordpress’

    • WPBeginner Support

      Try checking MySQL user privileges to make sure that the database user can perform these operations.

      Admin

      • Chathuranga

        Hi,

        Hope your DB name is “wordpress”

        Change the,
        – Database: `wordpress`

        CREATE DATABASE IF NOT EXISTS `wordpress` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci;

        change “wordpress” to your live DB name. It’s at your sql file.

      • qs

        I checked and all the privileges are already set to “yes”.

        is it because of the “latin1_swedish_ci” collation in my database? because the rest of the tables are all in “utf8_general_ci”

      • qs

        I checked and all the privileges are already set to “yes”.

        is it because of the “latin1_swedish_ci” collation in my database? because the rest of the tables are all in “utf8_general_ci”

  21. fab

    hi there,
    totally newbie here. hope you can help with this error message during step 4:
    Error
    SQL query:


    — Database: `information_schema`CREATE DATABASE `information_schema` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
    MySQL said:

    #1044 – Access denied for user ‘renta730’@’localhost’ to database ‘information_schema’

    When setting this user I allowed all privileges to the database previously created (named “inicial”).
    Any thoughts?

    • WPBeginner Support

      You are not supposed to install WordPress in the database information_schema. Create a new database for your WordPress site, and continue from the step 4.

      Admin

  22. neha

    Hi,Nice tute,but can u plz tell how to change database name and password etc from wordpress from live server?

    • WPBeginner Support

      To change database username and password connect to your live website using an FTP client. Find wp-config.php file and edit it. You will see your database name, database username, and host information. Change it to the database information for your live site.

      Admin

      • Kerry O'Connor

        I’ve tried every variation of my ‘host url’ in the wp.config file and uploaded it every time, no avail, still getting ‘Error Establishing db..’

        Where before it was ‘localhost’, now it should be ‘mywebsite.com’, is that right?

        thanks

        • WPBeginner Support

          For MySQL hostname, localhost works fine for most user. However, if you don’t know your database host, then you can ask your web hosting provider.

  23. Manish Patel

    Good Explanation.We can easily setup from this tutorial.Nice Post.I have helpful it.

  24. Mohammadreza

    Best ever, I really appreciate your clear explanation. you’ve got your new follower for sure :)

  25. Changdeo Mhaske

    Thank You,

    would only make sense if this is a new site. If it is an existing site, then you would have to constantly comment out the hosts file in order to access the live site.

  26. Justin Esparza

    Thank you very much for this clear concise how-to. It helped immensely. You have a new follower.

  27. Satyanarayana

    Hi Dude.
    Actually i followed the process as you explaned above is very nice and clear.
    but i was getting the error “page not found”. when i click on link in a website
    i am changing my files from main server to localserver
    Can you please help

  28. Carol

    New to WP and completely lost. But I managed my first migration thanks to this article.
    Thank you! Thank you!

  29. Steve

    As a beginner, I found this article very helpful, but couldn’t get my site up live after developing locally. Everything was fine until Step 6. I did see the Error Establishing Database Connection error, and then edited the wp-config.php file. However, my site became a blank screen at that stage and I haven’t been able to change it.

    I continued on and went to my WordPress admin panel, and checked Settings » General. They still showed the localhost web address so I changed it to my site url. This is when things turned ugly. I was automatically logged out of WordPress and can’t get back in. In fact, when I ask WordPress to email me a new password to log in, its sends a localhost URL that takes me to a sign-on page with a message that reads “Sorry, that key does not appear to be valid.” I have no idea what caused that.

    Any help would be greatly appreciated.

    • WPBeginner Support

      Open your database in phpMyAdmin as mentioned in Step 5 and make sure that in wp_options table, your site url and home url options point to your live website.

      Admin

      • Steve

        Thanks for your suggestion. I double-checked and yes I had completed that step. Both have the correct URL

        Part of my confusion is that I now have two databases for this website. I originally had one accessible through a URL that starts with the number of an IP Address/phpmyadmin. Then I have the one I created in Step 3, which I did through my hosting company’s e-panel. They have different passwords and names. But I’ve tried both combinations in the wp-config file and still get the blank screen. Which one of these databases should I be using? They seem to have identical content.

    • Patrick

      Sparky!
      Your step-by-step guide was spot on. I am a mac user, and after MAMP, I am live now. Thanks a lot. It worked perfectly for me.
      Hat docked!

  30. Vishal Kumar

    I have done migration form live site to localhost successfully. But I noticed that Comment facility is not there after this. I have also checked all the option in ‘Setting->Discussion’ page. Everything is cheked but Commenting option and Leave comment box is not visible anywhere in the localhost. Please give me any suggestion for this because I am new in wordpress I am a Zend framework developer basically.

  31. NARESH

    Instead of moving the wordpress site, I would like to fresh install wordpress using fantastico or hostgator’s quick install, so will I be able to do like this too just by exporting and importing databases and uploading the themefiles? or this is the only way we can do it?

    I don’t know why. my local machine wordpress loads very slow than one, whichever is installed on live server using fantastico or quick install.

    • WPBeginner Support

      Naresh yes you can import your posts and comments using import/export tools in WordPress, then you can upload theme and other files using FTP. There are multiple ways to do things you need to choose one that works best for you.

      Admin

  32. Siddharth Khare

    Best Explanation Ever. I was able to set up in a mere 5-10 mins

  33. Mark Jones

    Do all of these instructions remain the same if there’s already an older, existing, non-wordpress page built where you want to move your wordpress page? For instance, rebuilding an existing site as a wordpress site, then switching over.

    • Editorial Staff

      Thanks for leaving a comment Erwin. Yes, some others have recommended that tool as well in the comments.

      Admin

  34. Abrishca

    It’s easy to forget just how much work a good plugin really does for us – I personally use the Duplicator plugin to transfer new websites from my development server to the client’s domain and you can see how much time this plugin (and Backup Buddy) can save you.

  35. Praveen

    Hi,
    I am facing problem in changing the database after creating the new database.
    Is there any problem with my hosting service or anything else

  36. Iskandar Dzulkarnain

    thanks, your tutorial is solution for my problem

  37. Anna

    Are you reading my mind?! Just a little while back I sat down at the computer to figure out how to add a Facebook like button to my first website, currently in development. Whala! “How to add a Facebook like button to your posts” was that day’s article. Then I’m wondering how to begin the local to live migration today, and AGAIN, here’s this post! GET OUT OF MY HEAD! :)

    And seriously, thank you very much for the invaluable help you’ve given to a beginner like myself.

  38. riaz ali shah

    great article, the technique i often use for develop wordpress sites for clients, i use dummy text and images for local and then i move my theme only on server.

  39. John Coleman

    This was a great article. Another option to address the broken links issue is to do a find/replace on your .sql file (in a text editor) of the local URL to the production URL before you import it. This is also handy when moving a site to/from a sub-directory, or to push from staging (e.g. http://staging.domain.com) to production (e.g. http://www.domain.com).

    Thanks for putting this out there. I am sure it will help a lot of people.

  40. David

    Could have used this article 20 months ago. The trick I discovered in making the move was to open the database file in a good text editor. From there I did a search & replace maneuver to change localhost to the proper URL. It discovered numerous instances without me tracking down the tables, or worrying if my command syntax was correct.

    There’s a plugin called Broken Link Checker that’s worth running as well after the move.

    There are some web-hosting sites who’s infrastructure keeps everything in your WordPress site as localhost. No need to change anything in your local build. Just copy it over. Will definitely chose one of them next time.

  41. Mark

    2 suggestions to make it easier to move:

    1. When developing locally edit your HOSTS file (c:\Windows\System32\Drivers\etc\hosts) to point your domain name at local server. This avoids having to change the SITE URL and other links/images. Note: this will require config changes to your local web server.

    2. If you have to modify the SITE URL etc, after you have exported the local database and before import, Open the file in notepad and search for all instances of localhost/yourtestsite and replace with http://www.yourlivesite.com

    • Editorial Staff

      Mark,

      1. would only make sense if this is a new site. If it is an existing site, then you would have to constantly comment out the hosts file in order to access the live site.

      2. Yes that would make sense.

      Admin

      • Mark

        Changing the hosts file is something I do quite often and have a shortcut on my desktop giving me quick access.

  42. Gregg

    I also recommend DeskTop Server which I have been using for more then a year. Desktop Server allows you to create a local version of your site and then direct deploy it. Awesome!

  43. Sü Smith

    Great post! I typically just do find and replace on the .sql file with Notepad++ before uploading it to phpmyadmin. This is a nice alternative.

  44. Mike Ott

    Unfortunately this only works for some sites. A lot of wordpress plugins store serialised data in the database (Gravity Forms is one such plugin), and serialised data isn’t portable so doing an SQL dump and importing via PHPMyAdmin won’t work properly because of the string length differences between your local URL and live domain. You can’t even run an SQL query over serialised data.

    The best thing I’ve found to get around this problem is by using the WP Migrate DB plugin (http://wordpress.org/plugins/wp-migrate-db/). It handles the serialised data problem flawlessly every time and you won’t have to do half the other things you mentioned in this post.

    Have fun.

    • Mark

      Just had a light bulb moment! I have run into this issue before, thanks for the heads up Mike and pointer to the plugin,

    • Augustas

      For replacing paths and URLs I always use “Search and Replace” tool ( http://goo.gl/MCsKl ). It replaces serialized data, and it can be used for other CMSs as well, not only for WordPress.

  45. estudiowp

    Nice article an well explained steps!

    However, many people will find troubles in their migrations because of the serialized data.

    Some plugins and themes use serialized data, and the replaces in step 5 and step 7 won´t change all the urls and paths that need to be changeed.

    For those steps you could use these tools or plugins:

    · wp migrate db plugin: http://wordpress.org/plugins/wp-migrate-db/

    · search and replace tool: http://interconnectit.com/products/search-and-replace-for-wordpress-databases/

    I hope this comment will be useful and sorry for my english!

  46. RW

    awesome post! I could have used this with my first local > server migration!

  47. Jean

    Great article – best I’ve read on this subject.

    I moved a site a while back and the only thing I would add is that you might need to re-save the permalinks settings. I had to do this because none of my menu links worked so this was an easy fix (luckily!)

    • Mike Ott

      If anyone wants to know what that happens, it’s the .htaccess file shows a different RewriteRule between local and live.

      A quick edit to .htaccess fixes the problem or as Jean pointed out, re-saving the permalinks settings will also do the trick as it’s just fixing the RewriteRule.

Leave A Reply

Thanks for choosing to leave a comment. Please keep in mind that all comments are moderated according to our comment policy, and your email address will NOT be published. Please Do NOT use keywords in the name field. Let's have a personal and meaningful conversation.