Boujour, je souhaite me servir d'un serveur de distribution et de plusieurs base de données stockées sur d'autres serveurs distants de publication et fesant un réplication dans le serveur principale(distribution), avec ce que j'ai comprit de la réplication ici :

http://msdn.microsoft.com/fr-fr/library/bb510645.aspx

C'est comme sa que sa fonctionne.

Maintenant je ne souhaite pas faire sa avec les outils logiciels de SQL Server,
je souhaite utiliser le C# avec VS2010.

J'ai donc trouver le code pour creer une distribution :

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
 
void CreerDistrib()
{
          // Set the server and database names
            string distributionDbName = "MaBDD";
            string publisherName = "";  //???????
            string publicationDbName = "CentralServer";
 
            DistributionDatabase distributionDb;
            ReplicationServer distributor;
            DistributionPublisher publisher;
            ReplicationDatabase publicationDb;
 
            // Create a connection to the server using Windows Authentication.
            ServerConnection conn = new ServerConnection(publisherName);
 
            try
            {
                // Connect to the server acting as the Distributor 
                // and local Publisher.
                conn.Connect();
 
                // Define the distribution database at the Distributor,
                // but do not create it now.
                distributionDb = new DistributionDatabase(distributionDbName, conn);
                distributionDb.MaxDistributionRetention = 96;
                distributionDb.HistoryRetention = 120;
 
                // Set the Distributor properties and install the Distributor.
                // This also creates the specified distribution database.
                distributor = new ReplicationServer(conn);
                distributor.InstallDistributor((string)null, distributionDb);
 
                // Set the Publisher properties and install the Publisher.
                publisher = new DistributionPublisher(publisherName, conn);
                publisher.DistributionDatabase = distributionDb.Name;
                publisher.WorkingDirectory = @"\\" + publisherName + @"\repldata";
                publisher.PublisherSecurity.WindowsAuthentication = true;
                publisher.Create();
 
                // Enable AdventureWorks as a publication database.
                publicationDb = new ReplicationDatabase(publicationDbName, conn);
 
                publicationDb.EnabledTransPublishing = true;
                publicationDb.EnabledMergePublishing = true;
 
                ret = true;
            }
            catch (Exception ex)
            {
                ret = false;
                // Implement appropriate error handling here.
                throw new ApplicationException("An error occured when installing distribution and publishing.", ex);
            }
            finally
            {
                conn.Disconnect();
            }
}
Mais il y a des choses que je ne comprend pas, que mettre pour "publisherName" que j'ai mit ici a une chaine vide ?

Ensuite comment me connecter à cette distribution et créer la publication au préalable ?


pour faire simple voila ce que je voudrais au final :


schéma Réplication Customisé


Merci d'avance de vos conseils.

KevDeta