Welcome to my Azure Database Migration Project! In this comprehensive endeavor, I will architect and implement a cloud-based database system on Microsoft Azure, showcasing practical skills in cloud engineering. Our journey begins with the setup of a production environment database, followed by a smooth migration to Azure SQL Database.
Additionally, I emphasize the creation of a dedicated development environment, kept separate from the production system, serving as a sandbox for testing and experimentation. This environment mirrors the production setup, allowing for controlled exploration of new concepts without impacting critical systems.
Furthermore, my project includes the automation and scheduling of backups to Azure storage, ensuring consistent protection and simplifying recovery processes. This strategic backup approach enhances data security and resilience, critical in maintaining the integrity of your database systems.
Throughout this project, I'll cover essential aspects such as virtual machine setup, SQL Server installation, database creation, migration setup, validation, disaster recovery, geo-replication, failover procedures, and Microsoft Entra Directory integration. Each section contributes to a robust and comprehensive understanding of managing databases on Azure; skills necessary for efficient cloud-based data management.
An Azure Project Diagram.pdf has also been added to this repo to help visualise the architecture of this project (Note: database names have been generalised for understanding).
In the initial phase, we create a Windows Virtual Machine (VM) to emulate the functions of a Windows server, resembling an on-premise system within a company. This VM serves as a secure repository for the company's database. Here's a quick rundown of the setup process:
- Virtual Machine Creation: Accessing the VM service in Azure; create a new Windows VM, allocating sufficient resources (CPU, RAM, Storage) with cost/use case in mind.
- Firewall Rules: Set up Windows Firewall to allow RDP traffic (port 3389) and open necessary ports for SQL Server (port 1433) - this is default.
- Remote Connection to the VM: Connect to the VM using Remote Desktop Connection and enter the VM's static IP address and login credentials - this can be done by downloading the RDP file via the connections menu when viewing the VM resource.
With the VM set up, it's time to install SQL Server. Follow these steps:
- SQL Server Installation: Download the SQL Server installation package (https://learn.microsoft.com/en-us/sql/ssms/download-sql-server-management-studio-ssms?view=sql-server-ver16), follow the installation wizard, and configure authentication with a strong password for the SA account.
- SQL Server Management Studio (SSMS): Download and install SSMS.
Utilizing the AdventureWorks database as a comprehensive sample database for our project, follow these steps:
AdventureWorks Database: Obtain the AdventureWorks backup file, save it in 'C:\Program Files\Microsoft SQL Server\MSSQL16.MSSQLSERVER\MSSQL\Backup', and restore the AdventureWorks database using SSMS.
Now, let's migrate both schema and data from our local database to Azure SQL Database.
Prepare the target for migration by setting up the Azure SQL Database:
- Creation of Azure SQL Database: Create an Azure SQL Database for migration.
- SQL Server Authentication: Configure SQL Server to use SQL login.
- Firewall Rules: Ensure the SQL Server has appropriate firewall rules.
Set up Azure Data Studio for seamless migration:
- Installation of Azure Data Studio: Azure Data Studio is already preinstalled via the installation of SSMS and can be accessed via tools within SSMS.
- Connection to On-Premise Database: Use Azure Data Studio to establish a connection to the existing on-premise database.
- Connection to Azure SQL Database: Connect to the newly created Azure SQL Database using Azure Data Studio.
- SQL: Queries can be ran within Azure Data Studio.
Migrate the schema with the SQL Server Schema Compare extension:
- Installation of SQL Server Schema Compare Extension: Install the extension within Azure Data Studio.
- Schema Comparison and Migration: Leverage the extension to compare and migrate the schema from the on-premise database to the Azure SQL Database.
Transfer data seamlessly using the Azure SQL Migration extension:
- Installation of Azure SQL Migration Extension: Install the extension within Azure Data Studio.
- Data Transfer: Utilize the extension to transfer data from the on-premise database to the Azure SQL Database.
Ensure a successful migration with a comprehensive validation process:
Comprehensive Validation: Inspect data, schema, and configurations to guarantee a successful migration and data integrity.
In this section, we'll cover the essential steps for generating a full backup of the production database, securing it locally, and establishing a robust backup strategy for a development environment.
Begin by creating a safety net for unforeseen issues by generating a full backup of the production database hosted on the Windows VM. Follow these steps:
- Generate Backup: Use SQL Server tools to create a full backup of the production database.
- Local Storage: Once the backup is complete, store the resultant backup file in a designated location on the local computer.
Securely store your database backups in Azure Blob Storage for an extra layer of protection. Here's how:
- Configure Azure Blob Storage: Start by configuring an Azure Blob Storage account.
- Upload to Blob Storage: Upload the previously created database backup file to the Blob Storage container.
Create a controlled experimentation environment, similar to a sandbox, for development purposes. Follow these steps:
- Provision New Windows VM: Provision a new Windows VM mirroring the development setup.
- Install SQL Server: Install SQL Server on the new VM to mimic the necessary database infrastructure.
- Restore Database Backup: Restore the database backup from the blob storage onto this new "sandbox" environment.
Before utilizing the SQL Server Maintenance Plan Wizard, it was necessary to create a SQL Server Credential. This step ensures secure access to the Azure Blob Storage. Execute the following SQL script:
CREATE CREDENTIAL [YourCredentialName]
WITH IDENTITY = '[Your Azure Storage Account Name]',
SECRET = 'Access Key';
Implement an automated backup strategy for your development environment using SSMS. Here's how:
- Management Task with SSMS: On your development Windows VM, use SSMS to establish a Management Task.
- Configure Backup Schedule: Configure a weekly backup schedule using the SSMS maintenance plan wizard to ensure consistent protection for your evolving work and simplify recovery for your development environment if needed. This was configured to upload to the Azure blob storage.
Disasters can occur in various forms, such as data deletion or corruption. Hence, it is crucial to ensure regular backups are saved for recovery purposes. A simulated deletion was run within the production environment.
- Table Deletion in SSMS: The Sales.SalesTerritoryHistory table was deleted directly from SSMS - to recover, we can simply use the previously saved/automated backup created.
- Data Deletion or Corruption: Luckily, the database is backed up directly to Azure blob storage. We can access this and select restore, after completing the form and selecting a point of restoration; this will restore the database to the previous version and allow us to refresh the Azure Data Studio and regain deleted or corrupted information.
SQL queries below are methods of intentional data deletion or corruption.
-- Intentional Deletion
DELETE TOP (100)
FROM Sales.SalesTerritoryHistory;
-- Data Corruption
UPDATE TOP (100) Sales.SalesTerritoryHistory
SET product_price = NULL
To enhance data protection and further prevent data loss, reduce downtime, and ensure data availability, geo-replication is used to create a replica of our production database and store it in another geographical location. This can be done pretty easily by accessing the original production database and selecting a replica from the selections provided in the Azure side menu. By simply filling out the forms and deploying, we can create the geo-replicated database which can be connected to should we need it.
In Azure, failover is crucial for maintaining uninterrupted service availability and reliability. Failover automatically redirects traffic from a primary instance to a secondary one in case of failure. Azure provides tools like Traffic Manager, Load Balancer, and Site Recovery to facilitate failover. These services ensure continuous operation by distributing traffic, detecting and rerouting around failures, and orchestrating recovery processes. Implementing failover in Azure minimizes downtime, enhances business continuity, and instills confidence in the reliability of cloud-based applications and services.
To initiate a failover, follow these steps:
- Primary and Secondary Databases: Ensure you have a primary and secondary database set up, such as the newly made/geo-replicated database from section 7.
- Access Azure Portal: Navigate to the Azure portal and access the server associated with the primary database.
- Select Failover Groups: Under the data management pane, select the failover groups option.
- Create Failover Group: Create a new failover group and proceed by selecting failover. This action will switch the roles of the primary and secondary databases.
- Test Failover: To test a successful failover, connect to the now primary server via Azure Data Studio, and validate the schema and data.
By integrating Microsoft Entra Directory (Entra ID) we can add a more advanced layer of security and authorisation to a users database access. We can define who has access via Entra ID and to what level, always opting to adhere to the 'principle of least privilege' - This ensures very few people can accidentally modify a database.
Assigning admin privileges: Simply by accessing our main server via the Azure portal we can access Microsoft Entra ID via the settings section, we can then set an admin and save. Once assigned, this user can then use the Microsoft Entra ID authentication type when connecting to the database via Azure Data Studio.
Assigning db_datareader / read-only access to a user:
-
Create a new user account by navigating to the Microsoft Entra ID service via the Azure Portal (make note of the password and user principal name (e.g.DB_Reader@yourdomain.com).
-
Using the Azure Data Studio access the database and right-click to run a the query;
CREATE USER [DB_Reader@yourdomain.com] FROM EXTERNAL PROVIDER; ALTER ROLE db_datareader ADD MEMBER [DB_Reader@yourdomain.com];
This will assign the new user with the db_datareader status.
To test this we can simply edit the connection to our database, authenticate with a 'new account' and sign in with the new user details. User will only have read-only access.
Azure offers a seamless user experience, enticing users to integrate more with its services through its intuitive interface and abundance of tools. When architecting a new cloud-based system, having a visual diagram of the architecture can be invaluable. It serves as a guide, ensuring clarity and preventing confusion amidst the build process.