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

WordPress Yerel Sunucudan Canlı Siteye Nasıl Taşınır (2 Yöntem)

Birçok WordPress kullanıcısı, bilgisayarlarında yerel bir sunucu kullanarak web siteleri üzerinde çalışmayı tercih eder. Bu, değişiklikleri çevrimiçi olarak kullanıma sunmadan önce web siteniz üzerinde özel olarak çalışmanıza olanak tanır.

Sonunda, çevrimiçi ziyaretçilerin erişimine açmak için web sitenizi canlı bir sunucuya taşımanız gerekecektir. Bu geçiş, web sitenizin canlı sitede düzgün çalışmasını sağlamak için çok önemlidir.

Birçok yerel web sitesi üzerinde çalıştık, bu nedenle içeriği canlı web sitelerine aktarmanın en kolay yolunu öğrenmemiz gerekiyordu.

Bu makalede, WordPress’in yerel bir sunucudan canlı bir siteye nasıl taşınacağına ilişkin adım adım talimatlar vereceğiz.

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

WordPress’i Neden Yerel Sunucudan Canlı Siteye Taşımalısınız?

WordPress blogunuzu yerel bir sunucuda oluşturmak, web sitenizdeki değişiklikleri ziyaretçileri etkilemeden test etmenin güvenli bir yoludur.

Web sitenizi mükemmelleştirmeyi tamamladığınızda, bir sonraki adım yerel sunucunuzdan canlı bir siteye geçmektir.

Sitenizi yerel bir sunucudan canlı bir siteye taşımanın iki yolunu gösterelim.

İlk yöntem bir WordPress geçiş eklentisi kullanır ve yeni başlayanlar için önerilir.

İkinci yöntemde, WordPress’i yerel bir sunucudan canlı bir siteye manuel olarak nasıl taşıyacağınızı göstereceğiz.

Sizin için en uygun olan yöntemi seçebilirsiniz:

WordPress Sitenizi Taşımadan Önce

WordPress’i yerel bir sunucudan canlı bir sunucuya taşımak için birkaç şeye sahip olmanız gerekir.

İlk olarak, bilgisayarınızdaki yerel bir sunucuda (localhost olarak da adlandırılır) çalışan bir WordPress siteniz olduğunu ve buna tam erişiminiz olduğunu varsayıyoruz.

Ardından, bir alan adına ve web barındırma hizmetine sahip olmanız gerekir.

Kötü veya ücretsiz web barındırma sağlayıcılarıyla başlayıp pişman olan yeni başlayanlardan sayısız hikaye duyduk. Deneyimlerimize göre, doğru barındırma sağlayıcısını seçmek herhangi bir web sitesinin başarısı için kritik öneme sahiptir.

Kararınızı kolaylaştırmak için Bluehost kullanmanızı öneririz. Resmi olarak önerilen bir WordPress barındırma şirketidir ve WPBeginner kullanıcılarına özel bir indirim + ücretsiz alan adı ve SSL veriyorlar.

Temel olarak, ayda 1,99 $ gibi düşük bir ücretle başlayabilirsiniz.

Harika bir Bluehost alternatifi istiyorsanız, Hostinger‘a bakabilirsiniz. Ayrıca WPBeginner kullanıcılarına ücretsiz bir alan adı ile özel bir indirim sunuyorlar.

Biraz daha fazla ödemeyi göze alabiliyorsanız, SiteGround‘a göz atın. Ayrıca WPBeginner okuyucuları için özel bir fırsatları var.

Web sitenizi kurmak için yardıma ihtiyacınız varsa, bir web sitesinin nasıl yapılacağına ilişkin adım adım kılavuzumuzu izleyin.

Son olarak, bir FTP programına ihtiyacınız olacak ve yerel sunucu sitenizi canlı siteye yüklemek için FTP’yi nasıl kullanacağınızı bileceksiniz.

Hazır mısınız? WordPress sitenizi taşımaya başlayalım.

Video Eğitimi

Subscribe to WPBeginner

Yazılı talimatları tercih ediyorsanız, okumaya devam edin.

Yöntem 1: Bir Geçiş Eklentisi Kullanarak WordPress’i Yerel Sunucudan Canlı Siteye Aktarın (Önerilen)

Bu yöntem daha kolaydır ve yeni başlayanlar için önerilir. WordPress’i localhost’tan canlı bir siteye taşımak için bir WordPress migration eklentisi kullanacağız.

Adım 1: Duplicator Eklentisini Kurun ve Ayarlayın

Öncelikle, yerel sitenize Duplicator eklentisini yüklemeniz ve etkinleştirmeniz gerekir. Daha fazla ayrıntı için, bir WordPress eklentisinin nasıl kurulacağına ilişkin adım adım kılavuzumuza bakın.

Profesyonelİpucu: Duplicator ‘ın güvenli yedeklemeler, bulut depolama, kolay site geri yükleme ve daha fazlasını sunan profesyonel bir sürümü de vardır.

Etkinleştirmenin ardından, Duplicator ” Yedeklemeler sayfasına gitmeniz ve ‘Yeni Oluştur’ düğmesine tıklamanız gerekir.

Create new backup for migration

Bu sizi yedeklemenize bir ad verebileceğiniz bir ekrana getirir.

Ardından, ‘İleri’ düğmesine tıklayın.

Name backup package

Duplicator şimdi her şeyin yolunda olup olmadığını görmek için bazı testler yapacaktır.

Tüm öğeler ‘İyi’ olarak işaretlenmişse, ‘Oluştur’ düğmesine tıklayın.

Build package

Bu işlem, web sitenizin boyutuna bağlı olarak birkaç dakika sürebilir. İşlem tamamlanana kadar bu sekmeyi açık bırakmalısınız.

Tamamlandığında, ‘Yükleyici’ ve ‘Arşiv’ paketleri için indirme seçenekleri göreceksiniz. Her iki dosyayı da bilgisayarınıza indirmek için ‘Her İki Dosyayı da İndir’ düğmesine tıklamanız gerekir.

Download both backup files

‘Arşiv’ dosyası WordPress sitenizin eksiksiz bir kopyasıdır. Tüm WordPress çekirdek dosyalarının yanı sıra resimlerinizi, yüklemelerinizi, temalarınızı, eklentilerinizi ve WordPress veritabanınızın bir yedeğini içerir.

‘Yükleyici’ dosyası, web sitenizi içeren arşiv dosyasını açarak tüm geçiş sürecini otomatikleştirecek bir komut dosyasıdır.

Adım 2: Canlı WordPress Web Siteniz İçin Bir Veritabanı Oluşturun

Yükleyiciyi çalıştırmadan veya WordPress web sitesini localhost’tan hosting sunucunuza yüklemeden önce, yeni canlı web siteniz için bir MySQL veritabanı oluşturmanız gerekir.

Zaten bir MySQL veritabanı oluşturduysanız, bu adımı atlayabilirsiniz.

Bir veritabanı oluşturmak için hosting hesabınızın cPanel kontrol panelini ziyaret etmeniz gerekir. Ardından, ‘Veritabanları’ bölümünü bulun ve ‘MySQL Veritabanı Sihirbazı’ simgesine tıklayın.

MySQL Database Wizard

Bir sonraki ekranda, yeni bir veritabanı oluşturmak için bir alan vardır.

Veritabanınız için bir ad girin ve ‘Veritabanı Oluştur’ düğmesine tıklayın.

Name new database

cPanel şimdi sizin için yeni bir veritabanı oluşturacaktır.

Bundan sonra, yeni kullanıcınız için bir kullanıcı adı ve şifre girmeniz ve ardından ‘Kullanıcı Oluştur’ düğmesine tıklamanız gerekir.

Create new database user

Ardından, yeni oluşturduğunuz kullanıcıyı veritabanına eklemeniz gerekir.

İlk olarak, ‘Tüm Ayrıcalıklar’ onay kutusunu tıklayın.

Check all privileges

Ardından, aşağı kaydırın ve değişikliklerinizi kaydetmek için ‘Değişiklik Yap’ düğmesine tıklayın.

Veritabanınız artık WordPress sitenizle birlikte kullanılmaya hazırdır. Veritabanı adını, kullanıcı adını ve parolayı not ettiğinizden emin olun. Bu bilgilere bir sonraki adımda ihtiyacınız olacak.

Adım 3: Dosyaları Yerel Sunucudan Canlı WordPress Web Sitesine Yükleyin

Şimdi, arşiv ve yükleyici dosyalarını yerel sitenizden barındırma hesabınıza yüklemeniz gerekir.

İlk olarak, bir FTP istemcisi kullanarak canlı sitenize bağlanın. Bağlandıktan sonra, web sitenizin kök dizininin tamamen boş olduğundan emin olun.

Normalde kök dizin /home/public_html/ klasörüdür.

Bazı WordPress barındırma şirketleri, kaydolduğunuzda WordPress’i otomatik olarak yükler. Eğer orada WordPress dosyalarınız varsa, onları silmeniz gerekir.

Bundan sonra, archive.zip ve installer.php dosyalarını Duplicator’dan boş kök dizininize yükleyebilirsiniz.

Upload archive and installer files

Adım 4: Geçiş Komut Dosyasını Çalıştırma

Geçiş dosyalarını yükledikten sonra, tarayıcınızda aşağıdaki URL’yi ziyaret etmeniz gerekir:

http://example.com/installer.php

‘example.com’ yerine kendi alan adınızı yazmayı unutmayın.

Bu, Duplicator geçiş sihirbazını başlatacaktır.

Yükleyici birkaç test çalıştıracak ve komut dosyasını başlatacaktır.

Duplicator migration wizard step 1

Kurulum bölümü altında, MySQL ana bilgisayarınızı, veritabanı adınızı, kullanıcı adınızı ve şifrenizi girmeniz istenecektir.

Ana bilgisayarınız muhtemelen yerel bir ana bilgisayar olacaktır. Bundan sonra, bir önceki adımda oluşturduğunuz veritabanının ayrıntılarını gireceksiniz.

Ardından, girdiğiniz bilgilerin doğru olduğundan emin olmak için ‘Doğrula’ düğmesine tıklayın.

Validate settings

Bundan sonra, devam etmek için ‘İleri’ düğmesine tıklayın.

Duplicator şimdi WordPress veritabanı yedeğinizi arşivden yeni veritabanınıza aktaracaktır.

Ayrıca yerel siteye ve yeni canlı sitenize işaret eden URL’leri de güncelleyecektir.

Artık canlı sitenizin WordPress yönetici alanına girmek için ‘Yönetici Girişi’ düğmesine tıklayabilirsiniz.

Admin login

Canlı sitenizde oturum açtığınızda, Duplicator kurulum dosyalarını otomatik olarak temizleyecektir.

Hepsi bu kadar. WordPress’i yerel sunucudan canlı sitenize başarıyla taşıdınız.

Yöntem 2: WordPress’i Yerel Sunucudan Canlı Siteye Manuel Olarak Aktarın

Bu yöntemde, WordPress’i yerel sunucudan canlı sitenize manuel olarak nasıl taşıyacağınızı göstereceğiz. İlk yöntem işe yaramazsa veya manuel olarak yapmayı tercih ederseniz faydalı olacaktır.

Adım 1: Yerel WordPress Veritabanını Dışa Aktarın

Yapmanız gereken ilk şey yerel WordPress veritabanınızı dışa aktarmaktır. Bunu yapmak için phpMyAdmin kullanacağız.

Eğer bu konuda bilginiz yoksa, phpMyAdmin kullanarak WordPress veritabanı yönetimi rehberimize göz atmak isteyebilirsiniz.

Basitçe http://localhost/phpmyadmin/ adresine gidin ve WordPress veritabanınıza tıklayın. Ardından, üst menü çubuğundan ‘Dışa Aktar’ düğmesine tıklayın.

Export from localhost

‘Dışa aktarma yöntemi:’ seçeneğinde, ‘Hızlı’ veya ‘Özel’i seçebilirsiniz. Özel, veritabanınızı dışa aktarmak için size daha fazla seçenek sağlayacaktır.

Ancak veritabanınızı indirmek için ‘Hızlı’yı seçmenizi ve ardından ‘Git’ düğmesine tıklamanızı öneririz.

Export WordPress database using phpMyAdmin

Adım 2: WordPress Dosyalarını Canlı Siteye Yükleyin

Şimdi, tüm web sitesi dosyalarınızı canlı siteye taşımamız gerekecek.

Başlamak için FTP istemcinizi açın ve web barındırma hesabınıza bağlanın.

Canlı sitenize bağlandıktan sonra, dosyaları doğru dizine yüklediğinizden emin olun. Örneğin, sitenin ‘yoursite.com’ adresinde barındırılmasını istiyorsanız, tüm dosyaları public_html dizininize yüklemek isteyeceksiniz.

Şimdi yerel WordPress dosyalarınızı seçin ve canlı sunucunuza yükleyin.

Upload WordPress files FTP

Adım 3: Canlı Sitenizde MySQL Veritabanı Oluşturun

FTP istemciniz WordPress dosyalarınızı yüklerken, veritabanınızı canlı sunucuya aktarmaya başlayabilirsiniz.

Çoğu WordPress barındırma sağlayıcısı, barındırma hesabınızı yönetmek için cPanel sunar, bu nedenle size cPanel kullanarak nasıl veritabanı oluşturacağınızı göstereceğiz.

Öncelikle, cPanel panonuza giriş yapmanız ve ‘Veritabanları’ bölümünde bulunan ‘MySQL Veritabanı Sihirbazı’ simgesine tıklamanız gerekir.

Select MySQL database wizard

Bir sonraki ekranda yeni bir veritabanı oluşturabilirsiniz.

Veritabanınız için bir ad girmeniz ve ardından ‘Veritabanı Oluştur’a tıklamanız gerekir.

Name and create new database

cPanel şimdi sizin için otomatik olarak yeni bir veritabanı oluşturacaktır.

Ardından, yeni kullanıcınız için bir kullanıcı adı ve şifre girmeniz ve ardından ‘Kullanıcı Oluştur’a tıklamanız gerekir.

Create new database user

Bundan sonra, yeni oluşturduğunuz kullanıcıyı veritabanına eklemeniz gerekir.

İlk olarak, ‘Tüm Ayrıcalıklar’ onay kutusunu işaretleyin.

Check all privileges checkbox

Ardından, aşağı kaydırın ve değişikliklerinizi kaydetmek için ‘Değişiklik Yap’a tıklayın.

Canlı WordPress siteniz için başarıyla yeni bir veritabanı oluşturdunuz.

Adım 4: WordPress Veritabanını Canlı Siteye Aktarın

Süreçteki bir sonraki adım WordPress veritabanınızı içe aktarmaktır.

cPanel panonuza gidin, ‘Veritabanları’ bölümüne ilerleyin ve ‘phpMyAdmin’e tıklayın.

Click on phpMyAdmin

Bu sizi phpMyAdmin’e götürecektir, burada yukarıda oluşturduğunuz veritabanına tıklamak isteyeceksiniz. phpMyAdmin yeni veritabanınızı tablolar olmadan gösterecektir.

Ardından, üst menüdeki ‘İçe Aktar’ sekmesine tıklayın. İçe aktarma sayfasında, ‘Dosya Seç’ düğmesine tıklayın ve ardından ilk adımda kaydettiğiniz yerel sitedeki veritabanı dosyasını seçin.

Import database via phpMyAdmin

Bundan sonra, sayfanın altındaki ‘Git’ düğmesine tıklayın. Veritabanınız otomatik olarak phpMyadmin’e aktarılacaktır.

Adım 5: Site URL’sini Değiştirin

Şimdi, canlı WordPress sitenize bağlanması için veritabanınızdaki site URL’sini değiştirmeniz gerekir.

phpMyAdmin’de, yukarıda içe aktardığınız veritabanınızdaki wp_options tablosunu arayın.

Veritabanı önekinizi değiştirdiyseniz, wp_options yerine {new_prefix}_options olabilir.

Ardından, wp_options öğesinin yanındaki ‘Gözat’ düğmesine tıklayın. Ya da wp_options tablosundaki alanların bir listesini içeren sayfayı açmak için kenar çubuğundaki bağlantıya tıklayın.

Browse the wp options table

Ardından, options_name sütununda siteurl seçeneğini aramanız gerekir.

Ardından, ‘Düzenle’ simgesine tıklayın.

Edit siteurl in phpMyAdmin

Bu, alanı düzenleyebileceğiniz bir pencere açar.

option_value giriş kutusunda, yerel yüklemenizin URL’sini göreceksiniz; bu URL http://localhost/test gibi bir şey olacaktır.

Bu alana yeni sitenizin URL’sini girmeniz gerekir, örneğin: https://www.wpbeginner.com.

Ardından, ‘Git’ düğmesine tıklayarak alanı kaydedebilirsiniz.

edit the siteurl field

Ardından, ana sayfa seçeneği adı için yukarıdaki adımların aynısını izlemeniz gerekir. wp_options menüsü birkaç sayfa uzunluğunda olabilir. Genellikle, ana sayfa seçeneği ikinci sayfada olacaktır.

Ardından, ana sayfa URL’sini güncelleyin, böylece canlı site URL’nizle aynı olur.

Adım 6: Canlı Sitenizi Kurun

Veritabanını içe aktardığınıza ve içeriğinizi yüklediğinize göre sıra WordPress’i yapılandırmaya geldi.

Şu anda sitenizde‘Veritabanı bağlantısı kurulurken hata oluştu’ hatası görünüyor olmalıdır.

Bunu düzeltmek için, bir FTP istemcisi kullanarak web sitenize bağlanın ve wp-config.php dosyasını açın.

Aşağıdaki kod satırlarını arıyor olacaksınız:

// ** 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' );

Daha önce oluşturduğunuz veritabanı adını, kullanıcı adını ve parolayı sağlamanız gerekecektir.

Ardından, wp-config.php dosyasını kaydedin ve WordPress barındırma sunucunuza geri yükleyin.

Şimdi, web sitenizi ziyaret ettiğinizde canlı olması gerekir.

Bundan sonra, WordPress yönetici panelinize giriş yapmanız ve Ayarlar ” Genel bölümüne gitmeniz gerekir. Ardından, hiçbir şeyi değiştirmeden en alta kaydırın ve ‘Değişiklikleri Kaydet’ düğmesine tıklayın.

Save general settings

Bu, sitenizin URL’sinin olması gereken başka bir yerde düzeltilmesini sağlayacaktır.

Bunu yaptıktan sonra, Ayarlar ” Kalıcı Bağlantılar’a gidin, ardından aşağı kaydırın ve tüm gönderi bağlantılarının düzgün çalıştığından emin olmak için ‘Değişiklikleri Kaydet’e tıklayın.

Save permalinks settings

Bir WordPress sitesini bir etki alanından diğerine veya yerel bir sunucudan canlı bir siteye taşıdığınızda, kırık bağlantılar ve eksik görüntülerle karşılaşırsınız.

URL’leri güncellemek için size iki yol göstereceğiz. Sizin için en uygun olanı seçebilirsiniz.

1. Search & Replace Everything Eklentisini Kullanarak URL’leri Güncelleyin (Önerilen)

Bunu düzeltmenin en güvenli yolu Search & Replace Everything kullanmaktır. Karmaşık veritabanı sorguları yazmadan web sitenizde toplu güncelleme görevlerini kolayca gerçekleştirmenizi sağlayan güçlü bir WordPress eklentisidir.

İlk olarak, Search & Replace Everything eklentisini yüklemeniz ve etkinleştirmeniz gerekir.

Etkinleştirmeden sonra Araçlar ” WP Search & Replace sayfasına gidin.

Search and replace URLs from local to live site migration

Buradan, yerel site URL’nizi ‘Ara’ alanına ve canlı site URL’nizi ‘Şununla değiştir’ alanına girmeniz gerekir.

Biraz kaydırın ve tabloların altındaki ‘Tümünü Seç’ seçeneğine tıklayın. Bu, eklentinin veritabanındaki her yerde eski URL’yi aramasını sağlar.

Select tables

Şimdi devam etmek için ‘Arama ve Değiştirmeyi Önizle’ düğmesine tıklayın.

Eklenti, veritabanınızda eski URL’nin tüm örneklerini arayacak ve ardından sonuçları önizleyecektir.

Preview changes

Her şey iyi görünüyorsa, değişiklikleri kaydetmek için ‘Tümünü Değiştir’e tıklayın.

Yaptığınız değişiklikler hakkında bir uyarı göreceksiniz. Devam etmek için ‘Evet’e tıklayın.

Eklenti şimdi veritabanını güncelleyecek ve yerel URL’leri mevcut web sitenizin URL’si ile değiştirecektir.

2. URL’leri Manuel Olarak Güncelleme (Gelişmiş)

URL’leri güncellemenin bir başka yolu da aşağıdaki SQL sorgusunu kullanmaktır:

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

Basitçe phpMyAdmin‘e gidin, veritabanınıza tıklayın ve ardından üst menüden ‘SQL’e tıklayın ve yukarıdaki sorguyu ekleyin.

Yerel siteniz ve canlı site URL’leri olarak değiştirdiğinizden emin olun ve ‘Git’ düğmesine tıklayın.

Fixing WordPress images and broken URLs after moving to live site

İşte bu kadar. Artık WordPress’i yerel sunucunuzdan canlı bir siteye başarıyla geçirdiniz.

Umarım canlı web siteniz sorunsuz bir şekilde çalışır. Herhangi bir hata fark ederseniz, sorun giderme konusunda yardım almak için yaygın WordPress hataları kılavuzumuza göz atabilirsiniz.

Umarız bu makale WordPress’i yerel bir sunucudan canlı bir siteye taşımanıza yardımcı olmuştur. Ayrıca canlı bir siteyi yerel bir sunucuya taşıma kılavuzumuzu görmek veya pratik WordPress taşıma adımları için nihai web sitesi taşıma kontrol listesine bakmak isteyebilirsiniz.

If you liked this article, then please subscribe to our YouTube Channel for WordPress video tutorials. You can also find us on Twitter and Facebook.

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 yorumLeave 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

      • Tyler

        Thanks for the fast reply!

  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.

    • Editorial Staff

      Haha the little birdie told us that you needed this article ;) Glad to be able to help.

      Admin

  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.