data:image/s3,"s3://crabby-images/05c21/05c218cc29b0d6c1b886fd1a680b67770490f5e1" alt=""
As I am rebuilding my lab from scratch, I decided to test and use SQL BAG. BAG stands for Basic Availability Groups.
I will use Windows Server 2019 and SQL Server 2017 Standard Edition.
The main difference with Always On Availability Groups is that you can only “protect” 1 database with a BAG, but on the other hand it only requires SQL Standard and not Enterprise.
For details regarding limitation, it’s here
Prerequisites
You will need :
- At least 2 domain-joined Windows Server 2019 (one for each Node) up to date
- Windows Server Enterprise or DataCenter Edition for Windows Failover Clustering Role
- SQL Server 2017 Standard Edition
- A Windows service account for SQL
- Azure Storage Account (for Cloud Witness)
Implementation
1. Install Failover Clustering Feature
data:image/s3,"s3://crabby-images/f89ad/f89ad47eefb3b92ddacc414c355e8a47610ff507" alt=""
- Within Server Manager, click on Manage > Add Roles and Features
data:image/s3,"s3://crabby-images/e7d48/e7d48536c98fb6d934697df35aee38503d9ab3c2" alt=""
- Click on Next
data:image/s3,"s3://crabby-images/0a395/0a3959f0e143b5f9c2eb88e099c20579bbb9e9e7" alt=""
- Click on Next
data:image/s3,"s3://crabby-images/11a4c/11a4ca188d84369a3c9f05f6687ab41bbb323057" alt=""
- Click on Next
data:image/s3,"s3://crabby-images/6b193/6b193c5da1e950ebf17155c0f74d08b4e7124d54" alt=""
- Click on Next
data:image/s3,"s3://crabby-images/f037a/f037a40c590745d998c4e5d060a3175b8d16585e" alt=""
- Select Failover Clustering and click on Add Features
data:image/s3,"s3://crabby-images/76e5b/76e5be58399abdda9b0fe2e2d4b5c6ca0f0ecec9" alt=""
- Click on Next
data:image/s3,"s3://crabby-images/09cbc/09cbcab0cceddea52e60dbd710d09b6b533f4ae7" alt=""
- Click on Install
data:image/s3,"s3://crabby-images/8606b/8606b99b371c1b1a809a49a9da68602f1b1266c2" alt=""
- Click on Close and restart the server if needed
Note: The above steps need to be done on all other Nodes
2. Create Cluster
data:image/s3,"s3://crabby-images/501e1/501e11576e4e9bf65c30ecca058370c16baef713" alt=""
- Within Server Manager, click on Tools > Failover Cluster Manager
data:image/s3,"s3://crabby-images/ad844/ad844b72be62aa8e579874b94ab23d0fb9ae6120" alt=""
- Click on Create Cluster
data:image/s3,"s3://crabby-images/033d8/033d8e04218e076126fb18d5e8f896b69b11b431" alt=""
- Click on Next
data:image/s3,"s3://crabby-images/20ffa/20ffa207f8276a19ef935c66a4a938d1d82b9c7d" alt=""
- Add your Nodes and click on Next
data:image/s3,"s3://crabby-images/730f5/730f55a49663e3b2eca663a53d48e760f79c8d9e" alt=""
- Provide a name for the Cluster and an IP, then click Next
data:image/s3,"s3://crabby-images/1ad34/1ad34c786d76a5c425d350004ef118f0b304a7ff" alt=""
- Verify information and click on Next
data:image/s3,"s3://crabby-images/24c91/24c9173c6e7eee3f4bc3bc1b6fbb87830e479308" alt=""
- Click on Finish
3. Configure Computer account
The SQL Cluster will need special permissions on AD, here are the steps
data:image/s3,"s3://crabby-images/2235b/2235b9ac84888cc170ebb10f2e5ae3c88458d5ef" alt=""
- On a domain controller open Active Directory Users and Computers mmc
data:image/s3,"s3://crabby-images/613f2/613f2a6ffe47a36108d8774e026dabade38b5f50" alt=""
- Click on View > Advanced Features
data:image/s3,"s3://crabby-images/365db/365db11f5ffd7270699ee54cb92804603b33e761" alt=""
- Make a right click on the OU where the SQL servers reside and select Properties
data:image/s3,"s3://crabby-images/230d8/230d82f9f0934b942087ec2e241128cff0db2195" alt=""
- Click on Security tab
data:image/s3,"s3://crabby-images/1ccf2/1ccf21aaec89b3fbef6c97115258932519adea82" alt=""
- Click on Add
data:image/s3,"s3://crabby-images/e2bf0/e2bf01079bff4df0411ac65bee7f016598338376" alt=""
- Click on Object Types…
data:image/s3,"s3://crabby-images/81c20/81c20782dedce08657882b0fc7e32064fe83da59" alt=""
- Select Computers and click on OK
data:image/s3,"s3://crabby-images/79faa/79faadadd20d9cb571b8fb3c5637ac8ea05a1a3b" alt=""
- Provide name of the previously created Cluster and click on OK
data:image/s3,"s3://crabby-images/fc02d/fc02d2eb4107973f20f3b2556d18bf8a81072ab6" alt=""
- Click on Advanced
data:image/s3,"s3://crabby-images/bf376/bf3762a08cfb2f06dd46ededb2002bcddca62ae3" alt=""
- Select the added computer and click on Edit
data:image/s3,"s3://crabby-images/5bb22/5bb223fcb8ddff4f7cec636bebc1fcae063f0991" alt=""
- Select Create Computer objects permission and click on OK
data:image/s3,"s3://crabby-images/0f872/0f872d36bbcd961222cd6c444b281b2ca42f59b5" alt=""
- Click on OK
data:image/s3,"s3://crabby-images/6cca4/6cca476b3f0c5aa0dc44ca8316e4a53fb18b5337" alt=""
- Click on OK
Note: The SQL cluster computer account needs rights to create DNS records. The process of creating the Basic Availability Groups creates DNS “A” records for the Listeners.
data:image/s3,"s3://crabby-images/aca3d/aca3dec1547084189b384027ee7e6eda98eebf9c" alt=""
- On your local domain, make a right click and select Properties
data:image/s3,"s3://crabby-images/6c381/6c3813f25da16b67bf0ee8e4ebf7a2a60a60b652" alt=""
- Click on Security tab
data:image/s3,"s3://crabby-images/a7baf/a7baf8418084d520d95c8a1cd6447181f2254cee" alt=""
- Click on Add
data:image/s3,"s3://crabby-images/4d7e8/4d7e8b42bc8baf79fb32977646aed52950ce1470" alt=""
- Click on Object Types…
data:image/s3,"s3://crabby-images/eb3e0/eb3e0b2ecf66303a16c3b9269a65f25e9b0cce47" alt=""
- Select Computers and click on OK
data:image/s3,"s3://crabby-images/0f8dc/0f8dcb82b8fc1152e2df994b962381d0cdd2e415" alt=""
- Provide the name of the Cluster and click on OK
data:image/s3,"s3://crabby-images/64223/64223c85c1704faa30d47fd7ba437d8ee9c0d4ed" alt=""
- Check the box Create all child objects and click on OK
4. Install SQL Server Standard 2017
- Launch Setup for source DVD
data:image/s3,"s3://crabby-images/e691c/e691c0f75e4986cb549532845e3c09f2f6b97125" alt=""
- Within Installation section, click on New SQL Server stand-alone installation or add features to an existing installation
data:image/s3,"s3://crabby-images/e6d04/e6d0411c0577e3777280848b01bb9b17bf2c0208" alt=""
- Click on Next
data:image/s3,"s3://crabby-images/d723b/d723b19f93f8db29f1571479553786dcb1607500" alt=""
- Accept the license terms and click on Next
data:image/s3,"s3://crabby-images/8d29e/8d29e0e80e6912924224c4dac5ec65617d7f6add" alt=""
- Check the box Use Microsoft Update to check for updates and click on Next
data:image/s3,"s3://crabby-images/1c782/1c7822f4e281f42ca8abf144e53cd4b9487b3e7c" alt=""
- Select SQL Server Replication (this will include Database Engine Services) and click on Next
data:image/s3,"s3://crabby-images/b567f/b567fbaf55bdcdf61e0373a10e2d31527a94397b" alt=""
- Click on Next
data:image/s3,"s3://crabby-images/040a5/040a5f9de4c3b3b20476d5ca4d65c310fe9a1c66" alt=""
- For SQL Server Database Engine Account Name, select the drop box and click on Browse
data:image/s3,"s3://crabby-images/b0942/b09420de5859c6d3b2a964b54a68bcf29a7886ff" alt=""
- Provide the name of the service Account and click on OK
data:image/s3,"s3://crabby-images/6eeb3/6eeb3debbf61cd87617bc8de9b72123b592834de" alt=""
- Provide the password for the service account and click on Collation tab
data:image/s3,"s3://crabby-images/f6eff/f6eff298b7f84d3cd176d216acf098f489eab33c" alt=""
- Click on Customize
data:image/s3,"s3://crabby-images/b9fa9/b9fa90df6ff872b506991e24ded21b267394a1ba" alt=""
- Select option as above and click on OK
data:image/s3,"s3://crabby-images/2fd1b/2fd1b88e0a7108df3473800bb1df0bf227424525" alt=""
- Click on Next
data:image/s3,"s3://crabby-images/ecd4e/ecd4e69a9702d0dd25eaa6c351c53c6132cc104d" alt=""
- I added my Current User and the service account. Click on Next
data:image/s3,"s3://crabby-images/7353b/7353baf72c9d0cf1ae5bd3824f61f1f830310d93" alt=""
- Click on Install
data:image/s3,"s3://crabby-images/17a64/17a64327796eb6af4cb8eca7f37e5864a4326552" alt=""
- Click on Close
data:image/s3,"s3://crabby-images/a15bd/a15bd9d491c5205b77f02db68533a13257676897" alt=""
- Click on Install SQL Server Management Tools
data:image/s3,"s3://crabby-images/80750/807505b0e9b96fa0d7f698a1a013f5497515abb8" alt=""
- Download and install the latest version of SQL Server Management Studio
data:image/s3,"s3://crabby-images/8772c/8772cd1ac6f7492302b8d0e529cf29269c25529b" alt=""
- Click on Install
5. Configure AlwaysOn High Availability
data:image/s3,"s3://crabby-images/4e928/4e9287b601d4ab66a1913ea14566d79a495baf7d" alt=""
- Open SQL Server 2017 Configuration Manager
data:image/s3,"s3://crabby-images/5d206/5d206662dbf67a97f661af8b6e0d9fb424573331" alt=""
- Select SQL Server, make a right click and select Properties
data:image/s3,"s3://crabby-images/247a7/247a75bedb2fbcb2bbe4753139b671b5523f2ee3" alt=""
- Click on AlwaysOn High Availability tab
data:image/s3,"s3://crabby-images/9025e/9025e1bdeb5322a729d2890f7f4363bbd9afdd46" alt=""
- Check the box Enable AlwaysOn Availability Groups and click on OK
data:image/s3,"s3://crabby-images/752f8/752f83979cc4e4d432a8a22d4e57213aec602287" alt=""
- Click on OK
Note: The above steps need to be done on each Node
6. Configure Quorum
data:image/s3,"s3://crabby-images/e7f42/e7f42cd5a3b5b105a6c1a60955db7c0222c55966" alt=""
- Within Failover Cluster Manager console, select the Cluster, make a right click and select More Actions > Configure Cluster Quorum Settings
data:image/s3,"s3://crabby-images/a82bd/a82bd4cf1fb3129110018ac2de27d20d8c459459" alt=""
- Click on Next
data:image/s3,"s3://crabby-images/c5c92/c5c92bc7314308efb229787ae730956ebe4a8695" alt=""
- Select radio button Select the quorum witness and click on Next
data:image/s3,"s3://crabby-images/b26ea/b26ea52e24b7129404d33717f9d64ce6c0e613b4" alt=""
- Select radio button Configure a cloud witness and click on Next
data:image/s3,"s3://crabby-images/bf715/bf71547b8776a85b77a6fcb41bb009bb86e0655c" alt=""
- Provide the account name, the account key and click on Next
data:image/s3,"s3://crabby-images/2eac6/2eac649bee5d04a50ca095162b5104bdfa990c9a" alt=""
- Click on Next
data:image/s3,"s3://crabby-images/e4853/e48534fd2264abcd7e400aab9d521c8906b49fef" alt=""
- Click on Finish
data:image/s3,"s3://crabby-images/ab928/ab9289b1c8dd0d789f83a2122107875e36bf4139" alt=""
- Ensure Witness shows Cloud Witness
Our SQL Basic Availability Group is now created we will see in the next article how to create a BAG for Citrix WorkSpace Environment Management.
Stay tuned …