Labels

admin (1) aix (1) alert (1) always-on (2) Architecture (1) aws (3) Azure (1) backup (3) BI-DWH (10) Binary (3) Boolean (1) C# (1) cache (1) casting (3) cdc (1) certificate (1) checks (1) cloud (3) cluster (1) cmd (7) collation (1) columns (1) compilation (1) configurations (7) Connection-String (2) connections (6) constraint (6) copypaste (2) cpu (2) csv (3) CTE (1) data-types (1) datetime (23) db (547) DB2 (1) deadlock (2) Denali (7) device (6) dotNet (5) dynamicSQL (11) email (5) encoding (1) encryption (4) errors (124) excel (1) ExecutionPlan (10) extended events (1) files (7) FIPS (1) foreign key (1) fragmentation (1) functions (1) GCP (2) gMSA (2) google (2) HADR (1) hashing (3) in-memory (1) index (3) indexedViews (2) insert (3) install (10) IO (1) isql (6) javascript (1) jobs (11) join (2) LDAP (2) LinkedServers (8) Linux (15) log (6) login (1) maintenance (3) mariadb (1) memory (4) merge (3) monitoring (4) MSA (2) mssql (444) mssql2005 (5) mssql2008R2 (20) mssql2012 (2) mysql (36) MySQL Shell (5) network (1) NoSQL (1) null (2) numeric (9) object-oriented (1) offline (1) openssl (1) Operating System (4) oracle (7) ORDBMS (1) ordering (2) Outer Apply (1) Outlook (1) page (1) parameters (2) partition (1) password (1) Performance (103) permissions (10) pivot (3) PLE (1) port (4) PostgreSQL (14) profiler (1) RDS (3) read (1) Replication (12) restore (4) root (1) RPO (1) RTO (1) SAP ASE (48) SAP RS (20) SCC (4) scema (1) script (8) security (10) segment (1) server (1) service broker (2) services (4) settings (75) SQL (74) SSAS (1) SSIS (19) SSL (8) SSMS (4) SSRS (6) storage (1) String (35) sybase (57) telnet (2) tempdb (1) Theory (2) tips (120) tools (3) training (1) transaction (6) trigger (2) Tuple (2) TVP (1) unix (8) users (3) vb.net (4) versioning (1) windows (14) xml (10) XSD (1) zip (1)

SAP RS - Create a new Replication

Before declaring a Replication

We should have:

  • Primary database and Replicate database/s.
  • Instances were set in sql.ini.
  • RSSD database.

Create a primary database

use master
go
 
-- Create devices
disk init name="RepTestPrimaryDdevice", physname="/sybvol01/sap16/data/RepTestPrimaryDdevice1.dat", size="100M"
GO
 
disk init name="RepTestPrimaryDdeviceLog", physname="/sybvol01/sap16/data/RepTestPrimaryDdeviceLog1.dat", size="100M"
GO
 
-- Create a Database
create database RepTestPrimary on RepTestPrimaryDdevice='100M' log on RepTestPrimaryDdeviceLog='100M'
GO
 
use RepTestPrimary
go
-- Create a Segment
sp_addsegment RepTestPrimarySeg, RepTestPrimary, RepTestPrimaryDdevice
GO

Create a replicate database

use master
go
 
-- Create devices
disk init name="RepTestReplicateDdevice", physname="/sybvol01/sap16/data/RepTestReplicateDdevice1.dat", size="100M"
GO
 
disk init name="RepTestReplicateDdeviceLog", physname="/sybvol01/sap16/data/RepTestReplicateDdeviceLog1.dat", size="100M"
GO
 
-- Create a Database
create database RepTestReplicate on RepTestReplicateDdevice='100M' log on RepTestReplicateDdeviceLog='100M'
GO
 
use RepTestReplicate
go
-- Create a Segment
sp_addsegment RepTestReplicateSeg, RepTestReplicate, RepTestReplicateDdevice
GO

Create a replicated table

use RepTestPrimary
go
 
create table dbo.FirstTable (ID numeric(10, 0) not null, IntColumn int null, StrColumn varchar(20) null)
go
alter table dbo.FirstTable add constraint pkFirstTable primary key (ID)
go
 
-- =============================================================
use RepTestReplicate
go
 
create table dbo.FirstTable (ID numeric(10, 0) not null, IntColumn int null, StrColumn varchar(20) null)
go
alter table dbo.FirstTable add constraint pkFirstTable primary key (ID)
go

  • The replicated table must have a primary key!

Create connections to the primary and replicated server

cd /sybvol01/sap16rs/REP-16_0/install/
./rs_init

Add a database to the replication system

2.  Configure a Server product

Choose: "2. Configure a Server product"

Choose: "1. Replication Server"

Choose: "2. Add a database to the replication system"

In windows:


Replication Server Information


Choose: "1. Replication Server Information"

Choose: "1. Replication Server Name"Choose: "RS SA password"

Ctrl-a Accept and Continue


In windows:


Database Information

Add the primary database


Choose: "2. Database Information"

Choose: "1. SQL Server name"
For the primary database: set "5. Will the database be replicated" to "yes".
Ctrl-a Accept and Continue

Choose: "3. SA password"

Choose: "4. Database name"

Choose: "7. Maintenance password"

Choose: "3. Database Replication Agent"

Choose: "2. RS password"


Change RS user to sa.


Ctrl-a Accept and Continue


Ctrl-a Accept and Continue, Approve to run the task.

Execute the Replication Server tasks now? y
Running task: check the SQL Server.
Task succeeded: check the SQL Server.
Running task: verify users and their passwords.
Verified that 'sa' can log into Replication Server 'RSFOG2'.
Verified that 'sa' can log into Replication Server 'RSFOG2'.
Task succeeded: verify users and their passwords.
Running task: check the database.
Verified that database 'RepL16TestPrimary' exists.
Verified that SQL Server 'SERVERNAME' supports replication.
Added maintenance user login 'RepL16TestPrimary_maint' to database 'RepL16TestP
rimary'.
Verified that maintenance user 'RepL16TestPrimary_maint' can log into SQL Serve
r 'SERVERNAME'.
Task succeeded: check the database.
Running task: configure database for primary data.
Loading script 'rs_install_primary.sql' into database 'RepL16TestPrimary'.
.....Done
Loaded script 'rs_install_primary.sql' successfully.
Done
Granting permissions on the lastcommit functions and rs_marker.
Granting permissions on the lastcommit functions.
Granted maintenance user permissions on the lastcommit functions and rs_marker.

Granted replication role to maintenance user
Task succeeded: configure database for primary data.
Running task: configure the Replication Agent.
Task succeeded: configure the Replication Agent.
Running task: set connection to the database.
Adding database 'RepL16TestPrimary' to the replication system.
Successfully executed 'create connection'. Database 'RepL16TestPrimary' is now
managed by Replication Server 'RSFOG2'.
Task succeeded: set connection to the database.
Running task: start the Replication Agent.
Task succeeded: start the Replication Agent.

Configuration completed successfully.
Press <return> to continue.

Add a replicate database

Do the same as for the primary database, with the following changes:

  1. For the replicate databases: set "5. Will the database be replicated" to "no".
  2. "Database Replication Agent" definition is not required.

Ctrl-a Accept and Continue, Approve to run the task.


Execute the Replication Server tasks now? y
Running task: check the SQL Server.
Task succeeded: check the SQL Server.
Running task: verify users and their passwords.
Verified that 'sa' can log into Replication Server 'RSFOG2'.
Task succeeded: verify users and their passwords.
Running task: check the database.
Verified that database 'RepL16TestReplicate' exists.
Added maintenance user login 'RepL16TestReplicate_maint' to database 'RepL16Tes
tReplicate'.
Verified that maintenance user 'RepL16TestReplicate_maint' can log into SQL Ser
ver 'SERVERNAME'.
Task succeeded: check the database.
Running task: configure database for replicate data.
Loading script 'rs_install_replicate.sql' into database 'RepL16TestReplicate'.
...Done
Loaded script 'rs_install_replicate.sql' successfully.
Done
Granting permissions on the lastcommit functions.
Granted maintenance user permissions on the lastcommit functions.
Granted replication role to maintenance user
Task succeeded: configure database for replicate data.
Running task: set connection to the database.
Adding database 'RepL16TestReplicate' to the replication system.
Successfully executed 'create connection'. Database 'RepL16TestReplicate' is no
w managed by Replication Server 'RSFOG2'.
Task succeeded: set connection to the database.

Configuration completed successfully.
Press <return> to continue.

In windows:


Create replication definition, publication and subscription

Create a replication definition


Replication definition is defined at the primary database.

Connect to the RS:
isql64 -S RSFOG2 -Usa -Ppassword -w2048

create replication definition RepL16TestDef
with primary at SERVERNAME.RepL16TestPrimary
with all tables named 'FirstTable'
(ID numeric,
IntColumn int,
StrColumn varchar(20))
primary key(ID)
replicate minimal columns
go

Expected output:
Replication definition 'RepL16TestDef' is created.

Create a publication


Publication is defined at the primary database.

Connect to the RS:
isql64 -S RSFOG2 -Usa -Ppassword -w2048

create publication RepL16TestPub with primary at SERVERNAME.RepL16TestPrimary
go

Expected output:
-- Publication 'RepL16TestPub' for SERVERNAME.RepL16TestPrimary is created.


Create a subscription

Subscription is defined at the replicate database.

Connect to the RS:
isql64 -S RSFOG2 -Usa -Ppassword -w2048

create subscription RepL16TestSub for RepL16TestDef with replicate at SERVERNAME.RepL16TestReplicate
go

Expected output:
Subscription 'RepL16TestSub' is in the process of being created.

check subscription RepL16TestSub for RepL16TestDef with replicate at SERVERNAME.RepL16TestReplicate
go

Expected output:
Subscription RepL16TestSub is VALID at the replicate.
Subscription RepL16TestSub is VALID at the primary.

Validation and checks for the connections and the definitions


Connect to the RS:

isql64 -S RSFOG2 -Usa -Ppassword -w2048


1> admin who

2> go

Spid Name State Info

---- --------------- -------------------- ------------------------------------------------------------

...

304 DSI EXEC Awaiting Command 109(1) SERVERNAME.RepL16TestPrimary

299 DSI Awaiting Message 109 SERVERNAME.RepL16TestPrimary

301 DIST Awaiting Wakeup 109 SERVERNAME.RepL16TestPrimary

303 SQT Awaiting Wakeup 109:1 DIST SERVERNAME.RepL16TestPrimary

300 SQM Awaiting Message 109:1 SERVERNAME.RepL16TestPrimary

298 SQM Awaiting Message 109:0 SERVERNAME.RepL16TestPrimary

302 REP AGENT Awaiting Command SERVERNAME.RepL16TestPrimary

311 DSI EXEC Awaiting Command 110(1) SERVERNAME.RepL16TestReplicate

310 DSI Awaiting Message 110 SERVERNAME.RepL16TestReplicate

309 SQM Awaiting Message 110:0 SERVERNAME.RepL16TestReplicate

...


Connect to the RSSD in the ASE:

isql64 -S SERVERNAME -Usa -Ppassword -w2048 -X


1> use RSFOG2_RSSD

2> go

1> select * from rs_databases

2> go

dsname dbname dbid dist_status src_status ....

----------------- -------------------- ----------- ----------- ----------- ....

...

SERVERNAME RepL16TestPrimary 109 1 1 ....

SERVERNAME RepL16TestReplicate 110 1 0 ....

...

(8 rows affected)

  • rs_helpdb can also be good: exec rs_helpdb.


Add database and table to replication

Connect to the primary database in the ASE:
isql64 -S SERVERNAME -Usa -Ppassword -w2048 -X

1> USE RepL16TestPrimary
2> go

1> -- displays the current replication status of a table:
2> sp_setreptable FirstTable
3> go

The replication status for 'FirstTable' is currently false, owner_off, primary key = 'pkFirstTable'.
(return status = 0)

1> -- add table to replication
2> sp_setreptable FirstTable, true
3> go
The replication status for 'FirstTable' is set to true, owner_off.
(return status = 0)

1> -- displays the current replication status of a table:
2> sp_setreptable FirstTable
3> go
The replication status for 'FirstTable' is currently true, owner_off, primary key = 'pkFirstTable'.
(return status = 0)

1> -- check replication status for database:
2> sp_reptostandby RepL16TestPrimary
3> go
The replication status for database 'RepL16TestPrimary' is 'NONE'.
The replication mode for database 'RepL16TestPrimary' is 'off'.
(return status = 0)

1> -- activate replication status for database
2> sp_reptostandby RepL16TestPrimary, 'all'
3> go
Warning: The execution of the stored procedure sp_reptostandby will take time to process all the tables and all the text/image columns in database 'RepL16TestPrimary'.
The replication status for database 'RepL16TestPrimary' has been set to 'ALL'.
(return status = 0)

1> -- check replication status for database
2> sp_reptostandby RepL16TestPrimary
3> go
The replication status for database 'RepL16TestPrimary' is 'ALL'.
The replication mode for database 'RepL16TestPrimary' is 'off'.
(return status = 0)


Grant permissions to maint user on replicated DB

Connect to the replicate database in the ASE:

isql64 -S SERVERNAME -Usa -Ppassword -w2048 -X

use RepL16TestReplicate
go
GRANT INSERT ON dbo.FirstTable TO RepL16TestReplicate_maint
go
GRANT UPDATE ON dbo.FirstTable TO RepL16TestReplicate_maint
go
GRANT DELETE ON dbo.FirstTable TO RepL16TestReplicate_maint
go


Activate Rep Agent

-- Connect to the primary database and to the RSSD in the ASE:
isql64 -S SERVERNAME -Usa -Ppassword -w2048 -X


1> use RepL16TestPrimary
2> go

1> -- let RepAgent sends changes to the replicate database
2> sp_config_rep_agent RepL16TestPrimary, send_warm_standby_xacts, true
3> go

Parameter_Name Default_Value Config_Value Run_Value
----------------------- ------------- ------------ ---------
send warm standby xacts false true false
(1 row affected)
Replication Agent configuration changed for database 'RepL16TestPrimary'. The changes will take effect the next time the Replication Agent thread is started.
(return status = 0)

1> -- config connect dataserver to the ASE name
2> sp_config_rep_agent RepL16TestPrimary, 'connect dataserver', 'SERVERNAME'
3> go

Parameter_Name Default_Value Config_Value Run_Value
------------------ ------------- ------------ ------------
connect dataserver SERVERNAME SERVERNAME SERVERNAME 
(1 row affected)

Replication Agent configuration changed for database 'RepL16TestPrimary'. The changes will take effect the next time the Replication Agent thread is started.
(return status = 0)

1> sp_config_rep_agent RepL16TestPrimary, 'enable', 'RSFOG2', 'sa', 'password'
2> go
Msg 18382, Level 16, State 1:
Server 'SERVERNAME', Procedure 'sp_config_rep_agent', Line 664:
Database 'RepL16TestPrimary' is already configured to use Replication Agent. Request to enable Replication Agent has been ignored.
(return status = 1)
→ Bebause it already done in rs_init. No problem. 

1> -- stop RepAgent
2> sp_stop_rep_agent RepL16TestPrimary
3> go
The Replication Agent thread for database 'RepL16TestPrimary' is being stopped.
(return status = 0)


1> use RSFOG2_RSSD
2> go
1> rs_zeroltm 'SERVERNAME', 'RepL16TestPrimary'
2> go
Locater has been reset to zero.
(return status = 0)

1> use RepL16TestPrimary
2> go
1> dbcc settrunc(ltm, valid)
2> go
secondary trunc page secondary trunc state dbrepstat generation id database id database name ltl version
-------------------- --------------------- --------- ------------- ----------- ------------------------------ -----------
25757 1 175 0 14 RepL16TestPrimary 760

1> -- truncate the log
2> dump tran RepL16TestPrimary with no_log
3> go

1> -- grant permissions
2> grant role replication_role to sa
3> go

1>
2> -- start RepAgent
3> sp_start_rep_agent RepL16TestPrimary
4> go
Replication Agent thread is started for database 'RepL16TestPrimary'.
(return status = 0)


View information about all definitions and declarations


In the primary database:

sp_config_rep_agent RepL16TestPrimary
go

sp_help_rep_agent "RepL16TestPrimary"
go

sp_displaylogin sa
go

In the Replication Server:

admin who
go

admin who_is_down
go



In RSSD:

rs_helpdbrep DETestDB_repdef, win16, DETestDBPrimary
go

rs_helpcheckrepdef
go

rs_helprep DETestDB_repdef
go

rs_helpdbsub DETestDB_pub_subscript, ubuntu16, DETestDB
go

select * from rs_subscriptions A
go

select * from rs_dbreps B
go

select * from rs_sites --B
go

select * from rs_databases --C
go


Check the replication


Connect to the primary database and to the replicate database in the ASE:
isql64 -S SERVERNAME -Usa -Ppassword -w2048 -X

  1. Insert data to the primary table.
  2. Check if it was replicated in the replicate database.

1> use RepL16TestPrimary
2> go
1> INSERT INTO dbo.FirstTable ( ID, IntColumn, StrColumn ) VALUES ( 1, 1, 'Str 1' )
2> go
(1 row affected)
1> select * from dbo.FirstTable
2> go
ID IntColumn StrColumn
------------- ----------- --------------------
1 1 Str 1
(1 row affected)
1> use RepL16TestReplicate
2> go
1> select * from dbo.FirstTable
2> go
ID IntColumn StrColumn
------------- ----------- --------------------
1 1 Str 1
(1 row affected)



1 comment:

  1. Nice article, having a useful information.
    Implant media provides CDs, DVDs, Blu-Rays, Data Discs, Videos or Audio CDs replicated and printed, we’ll find a solution at the best price and fastest turnaround possible.
    we are a leading CD/DVD Replication in allover Australia.

    ReplyDelete