Sunday, January 8, 2012

Message[264] An attempt was made to send an email when no email session has been established

When we configure the database email, we can successfully send the test email.
How ever when we configure to set the alerts to send out email it will fail with the error
Message[264] An attempt was made to send an email when no email session has been established
which is found @ sql server agent error logs.

Fix :

select sql server agent -> right click -> properties -> alert system ->  check enable mail profile
-->  select mail system as Database Mail. --> Mail profile. --> ok  --> restart sql server agent




Error : The specified @server_name does not exist

When we rename the machine name by  default it will just rename the machine name ,where as the sql server still holds the reference to old machine name.When you try to add monitoring jobs or any thing else which needs to take the machine name in to consideration then it will try to look for the old machine name which is unable to access. This error is thrown at that instance.

Fix :

select @@servername , if it is different from machine name
then drop the old & add the new one.


sp_dropserver 'old machine name'
sp_addserver 'new machine name', local
restart the sql server

Saturday, January 7, 2012

SQL Server Configuration Manager Error: Connection to target machine could not be made in a timely fasion

I Faced this error when i was playing  with db mirroring & screwed up the database mirroring settings.
I was not able to open the sql server configuration manager .

Fix is :

go to start -> run -> type service.msc--> right click Windows Management Instrumentation & restart.



Monday, January 2, 2012

Sql Server Log Shipping

Sql server has log shipping as one of the disaster recovery solution. Log shipping provides the automated way of taking the log back ups on one server & restore them on another server.
Log shipping in general will have one primary server with Primary Database , Multiple secondary servers where the log will be shipped to & monitor server used to monitor the activities & raise the alerts when some thing goes wrong. We can use either primary server (or) secondary server to serve the purpose of Monitoring , How ever if some thing goes wrong on the server  then there could be chance to loose the monitoring as well, that's why it is suggested to have a seperate dedicated server for monitoring.

When logshipping is configured ,   4 jobs will be created on the primary , secondary & monitor servers.

1) Back up  job is created on  primary server -  purpose of this job  is to take a database back up

2) Copy job is created on secondary server - purpose of this job  is to copy the back up database to secondary server location

3) Restore job is created on secondary server - purpose of this job is to restore the back up log file that is copied over to secondary server in step 2

4) Alert Job is created on either secondary server (or) monitor server based on where the monitoring is configured , purpose of this job is to alert if some thing goes wrong in the process.

Sql server agent which runs these jobs should have read/ write permission to the location where the back ups will be taken  , copied to.

In this presentation i will show the implementation of logshipping by taking  one default instance & other named instance on the same machine.

1) create a database on primary server.

 CREATE DATABASE [testdb] ON  PRIMARY
( NAME = N'testdb', FILENAME = N'E:\SQLDATA\testdb.mdf' , SIZE = 2048KB , MAXSIZE = UNLIMITED, FILEGROWTH = 1024KB )
 LOG ON
( NAME = N'testdb_log', FILENAME = N'G:\SQLLOG\testdb_log.ldf' , SIZE = 1024KB , MAXSIZE = 2048GB , FILEGROWTH = 10%)
GO

2)  take back up of the database

 BACKUP DATABASE [testdb] TO  DISK = N'E:\SQLBACKUPS\testdb.bak' WITH NOFORMAT, NOINIT, 
 NAME = N'testdb-Full Database Backup', SKIP, NOREWIND, NOUNLOAD,  STATS = 10
GO

3) restore the database on second server 
RESTORE DATABASE [testdb] FROM  DISK = N'E:\SQLBACKUPS\testdb.bak' WITH  FILE = 1,
  MOVE N'testdb' TO N'E:\SQLDATA\INST1\testdb.mdf',  
  MOVE N'testdb_log' TO N'G:\SQLLOG\INST1\testdb.ldf',
    STANDBY = N'E:\SQLBACKUPS\INST1\ROLLBACK_UNDO_testdb.BAK',  NOUNLOAD,  STATS = 10
GO

4) configuring the primary database : right click the database -> properties -> transaction logshipping
  set the network path where the backups has to be taken. Edit job to schedule the time how frequent the back ups has to be taken.
 5)  Add the secondary server instance , here we can add as many secondary servers as we want .
 6) Restore Transaction Log can be set to  No recovery mode (or) stand by mode . Advantage with stand by mode is the database can be used in read only mode . This is useful for reporting purposes.

7)  Configure the Monitor server , here i am using the named instance as both secondary & monitor server.

















8) Now we will have 4 sql jobs one on primary & rest on secondary servers.

































9) Thats all,  Logshipping is configured.

Monitoring Logshipping :
  Logshipping can be monitor 3 ways

  1) GUI :  Right click on the server instance -> reports -> transaction logshipping
  2) system stored procedures.

      sp_help_log_shipping_monitor_primary 'satishbudati-pc', 'testdb'
     sp_help_log_shipping_monitor_secondary 'satishbudati-pc\inst1', 'testdb'

 3) msdb tables :
 
  select * from msdb..log_shipping_monitor_primary
  select * from msdb..log_shipping_monitor_secondary

Additional Reading Material : http://sqlcat.com/sqlcat/b/technicalnotes/archive/2009/02/24/scheduling-sub-minute-log-shipping-in-sql-server-2008.aspx