I suggest two solutions. Personally, I prefer the Logical Clone method because it can be done with less downtime, and database replication is a versatile capability to acquire for other reasons. However, the Exact Clone method, which is similar to what you proposed, is a generic brute-force approach to migrating any server.
Exact Clone
- Reduce the TTL of your DNS entries to make your life easier.
- rsync source to target. You don't even have to shut down services on the source; any inconsistencies will get fixed in steps (4) and (7).
- Optionally, you can run some tests the new server. Figure out what configuration changes you need to make on the target server to make things work. You might even want to reboot the target machine to make sure everything comes up cleanly.
- rsync source to target again, to undo whatever "damage" to the new server you introduced in (3), to pick up some more differences, and to get a feel for how much time it takes to run an incremental rsync (which is an indicator for how much downtime to expect).
- Shut down all services on both machines. Make sure services on the source machine stay off; you don't want a "split brain" with diverging data on the old and new machines.
- Make changes to your DNS entries. You can use a normal TTL for the new entries, assuming you don't plan to roll back.
- rsync source to target again.
- Apply any configuration changes you need on the target machine, as discovered in step (3).
- Start services on the target machine.
Logical Clone
Look into setting up MySQL replication. If you don't already have binary logging enabled on your MySQL server, you'll have to briefly bounce your database to enable it. In any case, I highly recommend enabling binary logging anyway because it is handy for doing future operations like upgrading MySQL with nearly zero downtime.
If you set up circular replication, you might even be able to run both the old and new webservers simultaneously, if MySQL is your application's only data store.