Solved

Migrating WPMS from apache to IIS7 causes Database Error

Posted on 2012-04-05
1
368 Views
Last Modified: 2012-04-10
// Be sure to read the updates below
-------------------------------------------------------------------------------------------------------------------------------

I have a large multisite installation hosted on XAMPP on an XP 2003 server and am trying to move it to a new Windows 2008 server with IIS7.

I can successfully get fresh installs of WP up and running and can get multisite working perfectly. When I import my old WPMS MySQL database and change the DB_NAME in my wp-config.php file to have the old WPMS database instead of the new WPMS database, I'm hit with Error establishing database connection

Here are my wp-config.php settings:

// ** MySQL settings - You can get this info from your web host ** //
/** The name of the database for WordPress */
define('DB_NAME', 'migrated_db_2012');

/** MySQL database username */
define('DB_USER', 'wpms_user_2012');

/** MySQL database password */
define('DB_PASSWORD', 'wpms_password');

/** MySQL hostname */
define('DB_HOST', 'localhost');

/** Database Charset to use in creating database tables. */
define('DB_CHARSET', 'utf8');

/** The Database Collate type. Don't change this if in doubt. */
define('DB_COLLATE', '');

Open in new window

I've double checked the username & password and even changed them several times to make sure they matched up. I've tried localhost, 127.0.0.1, and the IP address of my server itself for the DB_NAME. Nothing.

-------------------------------------------------------------------------------------------------------------------------------

/* UPDATE */

I've successfully connected to the database finally!

Visiting the front page of the domain (http://domain.com) gave me the
Error establishing database connection
message, but trying to visit the dashboard/admin area (http://domain.com/wp-admin) helped me see the problem. In my many DB/user name changes, I neglected to give full permissions to wpms_user_2012 on migrated_DB_2012. D'OH!

// New Problem

I still get the database error when visiting the front page, but now when I visit /wp-admin, I see the following:

One or more database tables are unavailable. The database may need to be repaired.
When I follow the "repair" link, it walks me through the auto-repair sequence, but since this is a multisite installation, it skips over a few tables and tells me the following tables don't exist:

wp_posts
wp_comments
wp_links
wp_options
wp_postmeta
wp_terms
wp_term_taxonomy
wp_term_relationships
wp_commentmeta

Only, these tables do exist, but they exist as: wp_1_posts, wp_1_comments, etc.

What should the next steps be to get my migrated DB to work properly?

-------------------------------------------------------------------------------------------------------------------------------

/* Let me explain a bit more: */

For this installation, I started from scratch with a fresh install of WP, set it up with a network and then copied the old /blogs.dir over to the new wp-content/.

(Reasoning for fresh install: I believe my old site had been hacked and I wanted to prevent any compromised core files from being transferred over to the new server.)

Next, I imported my old database (migrated_WPMS_database) into MySQL via phpMyAdmin, gave the appropriate privileges to the wpms_user and set up wp-config.php with the proper database/user/password information.

I ran the WP repair and you can see my // Update for the results. Basically, it was telling me that the main site's tables weren't there: I've read that the "repair" feature doesn't work well with WPMS because it looks for wp_[tableNames] instead of wp_1_[tableNames]. Am I mistaken?

After this, I even went through phpMyAdmin and ran it's built in "repair", also.

I can still connect successfully to the fresh install's database (test_database) if I change wp-config.php accordingly. So, it is seeing that it is a network and it is able to connect to the database server successfully, too.

Based on the WP Repair results, it seems WP is still looking for wp_[tableNames] instead of wp_1_[tableNames], is that right? Why would it do this? There's got to be something I'm missing inside the migrated database's tables or something, because of the message I receive when trying to access wp-admin:

One or more database tables are unavailable. The database may need to be repaired.
If it helps, my OLD site was set up as WPMU back before the merge, so the OLD wp-config.php is set up slightly different, and if I use it instead of the newer 3.3 wp-config.php, my front-end becomes a blank screen w/o the database error message and I'm able to get to the wp-login screen ... but it just puts me into a redirect loop back to the login page.
0
Comment
Question by:tahlequahitguys
1 Comment
 
LVL 1

Accepted Solution

by:
tahlequahitguys earned 0 total points
Comment Utility
I worked through this problem myself with the help of a forum mod on wordpress.org. You can see the full forum post here.
0

Featured Post

Backup Your Microsoft Windows Server®

Backup all your Microsoft Windows Server – on-premises, in remote locations, in private and hybrid clouds. Your entire Windows Server will be backed up in one easy step with patented, block-level disk imaging. We achieve RTOs (recovery time objectives) as low as 15 seconds.

Join & Write a Comment

I was supporting a handful of Windows 2008 (non-R2) 2 node clusters with shared quorum disks. Some had SQL 2008 installed and some were just a vendor application that we supported. For the purposes of this article it doesn’t really matter which so w…
In order to have all security and back ups taken care of, WordPress users can sign up for services with WP Engine.
This tutorial will show how to configure a new Backup Exec 2012 server and move an existing database to that server with the use of the BEUtility. Install Backup Exec 2012 on the new server and apply all of the latest hotfixes and service packs. The…
The purpose of this video is to demonstrate how to set up the permalinks on a WordPress Website. This will be demonstrated using a Windows 8 PC. Go to your WordPress login page. This will look like the following: mywebsite.com/wp-login.php : Go t…

763 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now