Let’s migrate a Phpmysql site from Godaddy to Azure App Service and Mysql
Go to Marketplace; let’s create a resource group
data:image/s3,"s3://crabby-images/674fe/674fe7c406d8696adf2983c11f12d9e1b2766f57" alt=""
data:image/s3,"s3://crabby-images/c57db/c57db211db63bc05286f9b10a641d48aba9a4884" alt=""
Web App + Database
data:image/s3,"s3://crabby-images/c7003/c7003b30a11cce7b117779c8b6515f5dedd1d3f2" alt=""
Lets use PHP run time stack
data:image/s3,"s3://crabby-images/452b1/452b1a1ccab041674fcd225eb61400f4642ef075" alt=""
It auto-creates MySQL with the wizard with proper private DNS zone
data:image/s3,"s3://crabby-images/d1551/d155132b5ee46f37faa5672b1af6f837cfdbb9fe" alt=""
Generated resources after creation
data:image/s3,"s3://crabby-images/5e03b/5e03b3012ff89cbd912ca5144e125128032d38e6" alt=""
App service is online now
data:image/s3,"s3://crabby-images/8e5b0/8e5b06638dce0ad85b93d04c887cc0f42ce7c44f" alt=""
Created Windows 10 VM and Installed SQL Workbench in the same vNet to connect to MySQL and App service FTP easily
data:image/s3,"s3://crabby-images/5d104/5d1041bc1ccb81f2916ec47ac22fbb4bd466b1be" alt=""
You can download SSL and connection information from here.
data:image/s3,"s3://crabby-images/a4aba/a4aba88c3f6008d2d8e5b62ed348dca6924db55e" alt=""
Connect using MySQL Workbench
data:image/s3,"s3://crabby-images/4cfc8/4cfc828bc88203d1fa8ccd5c65078a81d22f9207" alt=""
Enter the obtained password
data:image/s3,"s3://crabby-images/f951b/f951b7b493191c42517f2206ab6a58e9d6ce069e" alt=""
Import your old database using .SQL export and import
Choose Target schema
data:image/s3,"s3://crabby-images/e2f9e/e2f9e950d1056bbdf296a7ea5af62f88d05f7d17" alt=""
Now DB is imported.
data:image/s3,"s3://crabby-images/76c30/76c30a68583d3bbea9de7bc7c9f3d4f2492ef06e" alt=""
Now you can see Tables have been created.
You can see appropriate tables populated
data:image/s3,"s3://crabby-images/8b873/8b8734b4c21c4eb19574935cc6527dcba6e341f4" alt=""
Let’s load a test PHP file to test DB connectivity , You can see the FTP Credentials
data:image/s3,"s3://crabby-images/8437f/8437f0b86e0976e50d8cf2a6546694d78c3f1070" alt=""
Connect to App Service using FTP
data:image/s3,"s3://crabby-images/06696/066961e20a6ff9b62723f010754f689ebd26d018" alt=""
if you are using WinSCP
data:image/s3,"s3://crabby-images/e4b51/e4b5153c2870c1bf2d78daedef4290858cc421b6" alt=""
Placed this file to test mySQL connectivity.
data:image/s3,"s3://crabby-images/1c2c1/1c2c1a17433d03a0084b1f47a29f937f4ae316b5" alt=""
<?php $servername = "azure365pro-com-server.mysql.database.azure.com"; $username = "izmayfiuav"; $password = "8EHW56653KRSH5MZ$"; $database_name = "azure365pro-com-database"; // Create connection $conn = new mysqli($servername, $username, $password, $database_name); // Check connection if ($conn->connect_error) { die("Connection failed: " . $conn->connect_error); } echo "Connected successfully"; ?>
Connection failed: Connections using insecure transport are prohibited while –require_secure_transport=ON.
data:image/s3,"s3://crabby-images/ddc19/ddc196a8f6c5cd5e66c57685c03f3ddd0a48d2ba" alt=""
if you turn off secure transport
data:image/s3,"s3://crabby-images/08df4/08df4e17872cf714f7c2503639e5a2bf4a3772fa" alt=""
if you turn off secure transport
data:image/s3,"s3://crabby-images/8a678/8a678a73b4b35f9e692cf0304d0c2972654ed046" alt=""
or use SSL from the PHP side (Recommended)
data:image/s3,"s3://crabby-images/eac5c/eac5c86ce775a611c91e8d40fe8fff2317145c58" alt=""
&lt;?php $servername = "azure365pro-com-server.mysql.database.azure.com"; $username = "izmayfiuav"; $password = "8EHW56653KRSH5MZ$"; $database_name = "azure365pro-com-database"; $options = array( PDO::MYSQL_ATTR_SSL_CA =&gt; '/DigiCertGlobalRootCA.crt.pem' ); // Create connection $conn = new mysqli($servername, $username, $password, $database_name, $options); // Check connection if ($conn-&gt;connect_error) { die("Connection failed: " . $conn-&gt;connect_error); } echo "Connected successfully"; ?&gt;
data:image/s3,"s3://crabby-images/6385b/6385be608c63af138c55a1eab9cc9ca9422935cf" alt=""