Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.


Note

Information on this page is intended as a basic guide to setting up and running the Standby SQL product.

It is not intended as a complete user manual, but rather as a helper document to address the more frequently asked questions/sources of confusion.


Please note: Dbvisit Standby SQL is currently in the state of rapid development, and thus there may (and will) be major feature and user interface changes in the future. Every effort will be made to keep this document up-to-date, however discrepancies between descriptions within and the latest build are to be expected.



Panel

On this page:

Table of Contents



Introduction

Dbvisit Standby SQL is a software product designed to provide fast & reliable Disaster Recovery (DR) setup for Microsoft SQL Server. In addition to being feature-rich, Standby SQL is first and foremost intended to be extremely simple to both configure and use, even for non-expert users and “accidental DBAs”.

The Standby SQL software is composed of two components: Standby SQL Agent and Standby SQL Control Center.

The Standby SQL Agent is an application that must be deployed on the database host, i.e. the location of the SQL Server Instance. This Agent is what connects to your Instance & Databases and liaises with the Control Center (more on this below) to perform all the actions that Standby SQL provides. You will therefore need to install the Standby SQL Agent at least twice - once on each of the SQL Server Instance locations that you are planning to use. If both of the Instances you intend to use are on the same host/location, a single Agent installation is sufficient, however such an arrangement would not allow for true DR, as the single host represents a single point of failure for both of your Instances.

The Standby SQL Control Center is the brains of the operation, the central command & communications hub that works with and directs/coordinates any number of Standby SQL Agents. It also includes a webserver and the browser-based GUI used to setup/control the product. It is therefore recommended that this be installed on an independent, third location, separate from any of the SQL Server Instance hosts you intend to use. If you must install the Control Center on the same location as one of the Instances, you should use the location for the Standby Instance.


Basic Concepts

Dbvisit Standby SQL works on the basis of a Disaster Recovery Configuration (DRC), which is a defined relationship between a set of Databases within two SQL Server Instances. This “Database Set” can then be assigned either a Primary or Standby role.

A Primary Database is one which is active (i.e. online) and in-use. Almost always, this will be your intended source of information, e.g. a production database. This is the Database you are interested in protecting via a DR configuration.

A Standby Database is one which is not active (i.e. in a recovering state), and is intended to be the target for the Primary Database to replicate to, e.g. your “backup” database. This is the Database that should be kept in-sync with the Primary, and the one which you expect to be able to switch to in case of an emergency.


Installation

Both of the Windows & Linux installers ask for the same basic user input, and install the same basic components. The only exceptions to this will be discussed briefly below.

You may select to install either the Standby SQL Agent or the Standby SQL Control Center, or both. For your SQL Server Instance locations, you need only install the Agent. As mentioned above, it is recommended you install the Control Center separately on a third location, otherwise you may install it on your Standby location at the same time as the Agent.

Brief additional descriptions for some of the installer input fields:

  • Control Center Web Server Port: this is the port that the browser-based GUI will become available on after installation. For example, if you are accessing the GUI locally (i.e. from the same host where the Control Center is installed), you would access it by going to https://localhost:[THISPORT].

  • Agent Communications Port: this port is used by both the Standby SQL Agents & Control Center for communication between each other. Ensure this port is open, and is set the same installation-wide.

  • Linux-specific: If you answer No to the “do you want to automatically set up services?” question, the setup script will present you with a list of the required “actions to complete installation” once it is finished. Please run the commands displayed to start the required services. You can refer to the full Linux installation guide here: https://dbvisit.atlassian.net/wiki/spaces/DRI/pages/2048851973/Linux+Installation.

  • Windows-specific: User Domain/User/Password - the user specified here needs to have access rights to the SQL Server Instance if you want to use Windows Authorization later on to connect to the Instance. Otherwise, you can ignore these and manually connect to the Instance later using SQL Server Mixed-Mode Authentication.


Linux Installation

This section will provide you with a quick overview of installing Dbvisit Standby for SQL on a Linux based system

Note

This is still under construction

 You can run the installer as Dbvisit user and run the services as root  or install the software and services as same user running mssql server service 

  • Create UNIX users user which the Dbvisit Standby SQL services you will run, e.g.

    No Format
    # useradd --system dbvisit


  • Create base software folder where the Dbvisit Standby for SQL will be installed into, example /usr/dbvisit

    No Format
    # mkdir /usr/dbvisit
    # chown -R dbvisit:dbvisit /usr/dbvisit


  • Download the software to your system

    Example below the installation file is places in the temporary "install_files" folder under the user home directory

    No Format
    ~/install_files/linux-standbysql-v0.8.5DEV-4-gac1bcc39.1.tar.gz


  • Extract the files into a temporary location, e.g.

    No Format
    cd ~/install_files/
    tar xzf linux-standbysql-v0.8.5DEV-4-gac1bcc39.1.tar.gz


  • Run the setup program as the user that will run the Dbvisit Standby for SQL software.

    No Format
    dbvisit@dbv1:~/install_files $ ls
    linux-v0.8.5DEV-4-gac1bcc3.tar.gz
    
    dbvisit@dbv1:~/install_files $ tar xzf linux-v0.8.5DEV-4-gac1bcc3.tar.gz
    
    dbvisit@dbv1:~/install_files [dbvisit@sqlrhl02 ~]$ tar xzf linux-standbysql-v0.9.1.tar.gz
    
    
    [dbvisit@sqlrhl02 ~]$ ls
    linux-standbysql-v0.8.5DEV-4-gac1bcc39.1.tar.gz  setup-standby-v0.89.5DEV1DEV-41-gac1bcc3g4680e722
    
    [dbvisit@sqlrhl02 dbvisit@dbv1:~/install_files $ ~]$ ./setup-standby-v0.89.5DEV1DEV-41-gac1bcc3g4680e722
    +---------------------------------------------------------------------------------------------------+
    |     ____  __         _      _ __     _____ __                  ____             _____ ____    __  |
    |    / __ \/ /_ _   __(_)____(_) /_   / ___// /_____ _____  ____/ / /_  __  __   / ___// __ \  / /  |
    |   / / / / __ \ | / / / ___/ / __/   \__ \/ __/ __ `/ __ \/ __  / __ \/ / / /   \__ \/ / / / / /   |
    |  / /_/ / /_/ / |/ / (__  ) / /_    ___/ / /_/ /_/ / / / / /_/ / /_/ / /_/ /   ___/ / /_/ / / /___ |
    | /_____/_.___/|___/_/____/_/\__/   /____/\__/\__,_/_/ /_/\__,_/_.___/\__, /   /____/\___\_\/_____/ |
    |                                                                    /____/        Copyright @2020  |
    +---------------------------------------------------------------------------------------------------+
    
    Welcome to Dbvisit Standby SQL setup version v0.89.5DEV1DEV-41-gac1bcc3g4680e722.
    
    ? Which directory should the software be installed into? /usr/dbvisit
    ? Which components do you wish to use on this host? Control Center, Agent
    
    - - - You are now configuring the Dbvisit Standby SQL Control Center - - -
    
    The Control Center will listen on the following discovered addresses:
     -  127.0.0.1
     -  17210.17.0.2.8
     -  192.168.56.105
     -  192.168.122.1
    ? Control Center Web Server Port: 12345
    ? Agent Communications Port: 4222
    
    - - - Dbvisit Standby SQL Control Center configuration finished - - -
    
    
    - - - You are now configuring the Dbvisit Standby SQL Agent - - -
    
    ? Default location for SQL Server backup files /usr/dbvisit/standby/backup
    ? Resolvable Host Name: dbv1sqlrhl02.sqlkiwi.co.nz
    ? Control Center Address: 127.0.0.1
    ? Agent Communications Port: 4222
    
    - - - Dbvisit Standby SQL Agent configuration finished - - -
    
    
    - - - Ready to perform installation - - -
    
    ? Do you wish to proceed with the setup using the supplied configuration options? Proceed with setup
    
    - - - Performing installation - - -
    
    Copying software files to '/usr/dbvisit/standby'...
    Writing Control Center configuration file '/usr/dbvisit/standby/conf/standbycontrol.ini'...
    Writing Agent configuration file '/usr/dbvisit/standby/conf/standbyagent.ini'...
    
    - - - Installation successful! - - -
    
    
    To enable the installed Dbvisit Standby SQL components to run as system services, you will need to execute some commands as the "root" user in order to complete the setup.
    
    To install the system service(s), you can run, substituting the name of the user to run as if it is different from the current user:
    	 as if it is different from the current user:
    	sudo /usr/dbvisit/standby/bin/standbycontrol service install --user dbvisit
    	sudo /usr/dbvisit/standby/bin/standbyagent service install --user dbvisit
    To start the system service(s), you can run:
    	sudo /usr/dbvisit/standby/bin/standbycontrol service start
    	sudo /usr/dbvisit/standby/bin/standbyagent service start


Software installation is successful. Install and run the system services as root 

No Format
sudo /usr/dbvisit/standby/bin/standbycontrol service install --user 
oracle
rootsudo 
sudo
/usr/dbvisit/standby/bin/standbyagent service install --user 
oracle To start the system service(s), you can run:
root


No Format
sudo /usr/dbvisit/standby/bin/standbycontrol service start
	
sudo /usr/dbvisit/standby/bin/standbyagent service start

Services

Assuming you choose to allow the setup program to manage OS services, and that you’re using a Linux distribution that uses systemd for OS services, you can use systemctl to control the service(s).

To check whether the Agent service is running: 

No Format
sudo systemctl status standbyagent.service


Example, to check where the Control Center service is running: 

No Format
sudo systemctl status standbycontrol.service


Log files

Once the service has started, there should be a log file and some repository files present in the DBVISIT_BASE/standby/log folder

Upgrade

  1. Uninstall (we don’t currently support upgrading repositories so they must be removed when upgrading)

  2. Remove the files extracted from the installation package

    NOTE - you choose the location of these files when you extract them - there is no default

    No Format
    rm -r Dbvisit/


  3. Run the setup program again


Uninstall

There is no automated uninstall procedure currently.

  1. Stop services

    No Format
    sudo /usr/dbvisit/standby/bin/standbyagent service stop
    sudo /usr/dbvisit/standby/bin/standbycontrol service stop


  2. Uninstall services

    No Format
    sudo /usr/dbvisit/standby/bin/standbyagent service uninstall
    sudo /usr/dbvisit/standby/bin/standbycontrol service uninstall


  3. Remove logs and repositories

    NOTE - if you changed the default path during installation, you will have to make sure you use that when you run the command below

    No Format
    sudo rm -rf /usr/dbvisit/standby


Windows Installation

This section will provide you with a quick overview of installing Dbvisit Standby for SQL on a Windows-based system. The windows installation is similar to Dbvisit standby installation and it is easy and straightforward.

Step 1

Double click the Standby.msi [ 1 ] file which will lead to the setup wizard and click Next [ 2 ]

Step 2

Accept the license agreement and move to the next step

Step 3

This will prompt you by default to install both Dbvisit Standby SQL Control Center [ 1 ] and the Dbvisit Standby SQL Agent [ 2 ]. The location is by default C:\Program Files\Dbvisit\standby [ 3 ]. You can browse to a different location and point the installation to a different drive/folder.

Step 4

The Control Center or the GUI component will listen to the discovered addresses [ 1 ]. The control center webserver port is by default 12345 [ 2 ] and the Agent communication port is 4222 [ 3 ]

Step 5

This is a very important part of the installation. 

  1. The resolvable Host Name is automatically populated 
  2. The Control Center Address will be based on the server in which the web interface is installed. In the below case the Control center is installed in the same host.
  3. Username and Password credentials for the host in which the standby component is installed.

 

Step 6

If the credentials and details are provided correctly in step 5 the installation should proceed without issues and the services would also be started 

Step 7

When installing components in the primary server, you don't have to install the SQL Control Center. You just have to install the Dbvisit Standby SQL Agent.


Configuration

Once everything is installed, you can begin configuring the product for your needs by accessing the browser-based GUI, available at the Control Center’s installation address + the Web Server port you specified during installation (as mentioned above). For example: https://localhost:12345.

For now, you can login using any username and the password “password” - user management is coming soon.

Dbvisit Standby SQL has no command line client - the browser GUI is the only way to use & configure the product. This GUI is always available as long as the Control Center process is running.

Registering Hosts & Instances

Begin by registering a Host and any Instances on it - the GUI will prompt you to do so.

A Host is a location with a Standby SQL Agent installed and running - this should have been done during installation above. Any available Host will auto-announce: this means it will automatically show up in the Discovered Hosts panel. If your desired Host is not shown here, this means something went wrong during installation - the most common reason is specifying the wrong Agent Communications port, or not having this port correctly open/routed through your network.

Step1

The below Figure will show the discovered hosts in the central console.

Step2

You will have to register the discovered host, when you click on Register Host you will see the below options

  1. This is the communication port between your Primary and Standby host.
  2. The default location where all your full backups(taken during the CSD) and the transaction log backups will be present. This location must be changed to a different location where there is enough space for backups to be present.
  3. 4. This depends on the authentication type of your SQL server instance and also depends on which you want to use to register the host with Dbvisit central console.

Step3

I have chosen the Windows Authentication and you get the below results

  1. The SQL Server instance name.
  2. Confirm if the test connection was successful and the Dbvisit components are able to connect to the SQL server instance.
  3. Available user databases.
  4. Click Confirm&Register host to register it to the central console.

Step4

Both the primary and standby host has been registered with the central console. We recommend using the same authentication type to register both primary and standby hosts.

Database Configurations

After registering the hosts you will see a new option on the left pane called "Dashboard" when you click on it you can use the New Database configurations

This will pop up with options of selecting the databases from the primary host and the instances from the standby host in which you want to restore the databases.

Choose the SQLServer  Instance from the host in which you want to restore the database to.

The location for the backups can be customised in both primary and standby or this will take the default location provided during the registration of the hosts.

In the below figure, it can be seen that the Database Configuration has been created for two databases (AdventureWorksDW2019 and ZEE) and these databases are ONLINE in the primary server DBWINSQL01. There is no standby database created. To create the standby database click on "Create one now?" this will lead to the next window for creating the standby database.

You can change the datafile location in the standby by providing a different location [ 1 ]and then click start [ 2 ]

Once the process is started you can see the status of the task under Tasks & Events Timeline[ 2 ]. The status of the standby database will be shown as restoring [ 1 ] 

Clicking on the tasks you can see the progress along with steps performed for the particular task.

Usage

Once the standby is created you can now perform other actions to the database configuration. Below are the actions that can be performed for the database configurations.

  1. Backup & Send Logs
  2. Restore Logs
  3. Synchronize
  4. Switchover
  5. Failover
  6. Delete Standby Database
  7. Unlink Database


Let's go through these actions individually.

  1. Backup & Send Logs

This option would backup the transaction logs from the primary and send it to the standby server.

The action will appear in the Tasks & Events Timeline section and you can see that the task is successfully completed.

Restore Logs

After step 1 is completed, now the transaction logs must be applied to the standby database.

Synchronize

This action is performed when you want to take the backup of the primary transaction logs and then restore all the available logs to the standby there my syncing the database with primary.

From the below screenshot , we can see that the there were two transaction log backup files restored in the standby which was available to be restored.


Switchover

The switchover is basically reversing the roles between the primary and standby database. The standby database is restored with the latest backup and then it is open and online and the primary database status is changed to restoring status.

Once the action is successfully completed, the database roles are switched, the primary goes to the restoring status [ 2 ] and the standby database status is now online [ 1 ].


Delete Standby Database

This option is to remove the standby database from the SQL Server instance. This option is available only for Beta testers and will be removed from the final product


Failover

This action is performed when your primary server is down or your SQL Server instance is down with an unrecoverable state. Failover will bring the database in standby online.

Once the failover is completed. The old standby server assumes the primary role and the database is online [ 1 ]. The old primary database and server go to the failover state [ 2 ] and becomes the standby.

The logs indicated below.

You can clean up the new standby server and recreate the standby database. Please remember this would clean up the former Primary database along with the backups. This will enable you to recreate the standby database on the old primary server. Once this action is completed you can just switch over the database to return to the pre-failover state.

After the cleanup is done, the next step is to unlink the database from the configuration. The database must be added again to the configuration before you can re-run the CSD operations.

After the above operation, the database is no longer under the Database configurations page and you have to add it again from the new primary which is DBVWINSQL02.

Once the configuration is created, the standby database can be created again.



Related pages

Filter by label (Content by label)
showLabelsfalse
spacesDSFSQSG
showSpacefalse
sorttitle
typepage
cqllabel = "documentation-space-sample" and type = "page" and space = "DSFSQSG"
labelsdocumentation-space-sample