Trying to leverage a linked Server and received the following error:
OLE DB provider "SQLNCLI10" for linked server "PANEL_REMOTE" returned message "The partner transaction manager has disabled its support for remote/network transactions.".
Msg 7391, Level 16, State 2, Line 5
The operation could not be performed because OLE DB provider "SQLNCLI10" for linked server "PANEL_REMOTE" was unable to begin a distributed transaction.
-------------------
Verify RPC and RPC out is set to True in the Linked Server properties.
Code Snippet was:
I had declared the table variable @temp2 (yada)
declare @dynamic_sql NVARCHAR(MAX)
declare @prefix NVARCHAR(MAX)
SET @prefix = N'LinkedServerName.'
SET @dynamic_sql = N'' + CHAR(13) +
' INSERT INTO @temp2 EXEC ' + @prefix + 'DBName.dbo.StoredProcName '
exec (@dynamic_sql)
Still received the error message Msg 7391, Level 16, State 2, Line 5
-------------
Changed the call to use OpenQuery...
declare @dynamic_sql NVARCHAR(MAX)
SET @dynamic_sql = N'' + CHAR(13) +
' INSERT INTO @temp ' + CHAR(13) +
' SELECT * FROM OPENQUERY(LinkedServerName, ' + '''' + 'DBName.dbo.StoredProcName ' + '''' + ')'
And it worked successfully...
Monday, September 12, 2011
Friday, September 2, 2011
SQL 2008 R2 Mirroring End Points - Different NICs
Leveraging dedicated NIC's for SQL Mirror NIC traffic (other than SQL Server system traffic).
Example:
SQL Services run on 10.X.X.Y on Principal and 10.X.X.Z on Mirror)
SQL Mirror traffic:
Mirror Node will run on 192.168.0.2
Principal Node will run on 192.168.000.1
Mirror Node:
CREATE ENDPOINT [DB_Mirror]
AUTHORIZATION [SURVEYSAMPLING\matt_fitzgerald]
STATE=STARTED
AS TCP (LISTENER_PORT = 5030, LISTENER_IP = (192.168.000.2))
FOR DATA_MIRRORING (ROLE = PARTNER, AUTHENTICATION = WINDOWS NEGOTIATE
, ENCRYPTION = REQUIRED ALGORITHM RC4)
GO
GRANT CONNECT ON ENDPOINT::DB_Mirror TO [DOMAINNAME\sqlserverServiceAccount]
--------------------
Principal Node
CREATE ENDPOINT [DB_Mirror]
AUTHORIZATION [SURVEYSAMPLING\matt_fitzgerald]
STATE=STARTED
AS TCP (LISTENER_PORT = 5030, LISTENER_IP = (192.168.000.1))
FOR DATA_MIRRORING (ROLE = PARTNER, AUTHENTICATION = WINDOWS NEGOTIATE
, ENCRYPTION = REQUIRED ALGORITHM RC4)
GO
GRANT CONNECT ON ENDPOINT::DB_Mirror TO [DOMAINNAME\sqlserverServiceAccount]
-----------
Restore the database on mirror node along with one transaction log...
restore database dbname
from disk = '' WITH NORECOVERY, stats = 10
Restore log dbname from disk='' with norecovery, stats=10
--On mirror node
alter database DBNAME
set partner = 'TCP://192.168.000.1:5030'
--On Principal Node
alter database entrycheck
set partner = 'TCP://192.168.000.2:5030'
By default this will create a Sync mirror.
Example:
SQL Services run on 10.X.X.Y on Principal and 10.X.X.Z on Mirror)
SQL Mirror traffic:
Mirror Node will run on 192.168.0.2
Principal Node will run on 192.168.000.1
Mirror Node:
CREATE ENDPOINT [DB_Mirror]
AUTHORIZATION [SURVEYSAMPLING\matt_fitzgerald]
STATE=STARTED
AS TCP (LISTENER_PORT = 5030, LISTENER_IP = (192.168.000.2))
FOR DATA_MIRRORING (ROLE = PARTNER, AUTHENTICATION = WINDOWS NEGOTIATE
, ENCRYPTION = REQUIRED ALGORITHM RC4)
GO
GRANT CONNECT ON ENDPOINT::DB_Mirror TO [DOMAINNAME\sqlserverServiceAccount]
--------------------
Principal Node
CREATE ENDPOINT [DB_Mirror]
AUTHORIZATION [SURVEYSAMPLING\matt_fitzgerald]
STATE=STARTED
AS TCP (LISTENER_PORT = 5030, LISTENER_IP = (192.168.000.1))
FOR DATA_MIRRORING (ROLE = PARTNER, AUTHENTICATION = WINDOWS NEGOTIATE
, ENCRYPTION = REQUIRED ALGORITHM RC4)
GO
GRANT CONNECT ON ENDPOINT::DB_Mirror TO [DOMAINNAME\sqlserverServiceAccount]
-----------
Restore the database on mirror node along with one transaction log...
restore database dbname
from disk = '' WITH NORECOVERY, stats = 10
Restore log dbname from disk='' with norecovery, stats=10
--On mirror node
alter database DBNAME
set partner = 'TCP://192.168.000.1:5030'
--On Principal Node
alter database entrycheck
set partner = 'TCP://192.168.000.2:5030'
By default this will create a Sync mirror.
Subscribe to:
Posts (Atom)