相信在此之前,大家对Remoting 这个东西都有一定的了解,而MS 推出 Remoting 技术为了使开发基于分布式应用更加简单。
下面,我将用一个简单的实例来说明Remoting 是如何工作的。
首先,从设计结构来讲,我们会在物理分为俩层:Client 端 和 Server端。它们可在同一台机器,也可以在不同的机器上分别部署。
此二者仅仅是架构(结构)的应用,但是实际上,我们所要作的是通过我们的这种架构实现我们的业务与应用分离。
所以,我们需要有一个业务层(这个业务层与三层架构中的业务层并无相关性)。(Common )
因此,我们的程序结构包括:Client , Common , Server 三个工程。
下面,我们来具体阐述各个层的具体需要做什么?
Server , 注册远程通道以及对象
Common , 具体的方法实现。
Client , 获取远程对象,调用Common 的方法。
具体代码,如下:
1. Server 端
public
class
Server
{
public static int Main(string [] args)
{
TcpChannel chan1 = new TcpChannel(8085);
ChannelServices.RegisterChannel(chan1);
RemotingConfiguration.RegisterWellKnownServiceType(
typeof(DataOperation),
"DataOperation",
WellKnownObjectMode.Singleton
);
System.Console.WriteLine("Press Enter key to exit");
System.Console.ReadLine();
return 0;
}
}
{
public static int Main(string [] args)
{
TcpChannel chan1 = new TcpChannel(8085);
ChannelServices.RegisterChannel(chan1);
RemotingConfiguration.RegisterWellKnownServiceType(
typeof(DataOperation),
"DataOperation",
WellKnownObjectMode.Singleton
);
System.Console.WriteLine("Press Enter key to exit");
System.Console.ReadLine();
return 0;
}
}
2. Common 层
public
class
DataOperation : MarshalByRefObject
{
// #region IDataOperater Members
public string AddNewData()
{
return " Method can be called by remoting! " ;
}
// #endregion
}
{
// #region IDataOperater Members
public string AddNewData()
{
return " Method can be called by remoting! " ;
}
// #endregion
}
3. Client 端
public
class
Client
{
public static void Main(string[] args)
{
//使用TCP通道得到远程对象
TcpChannel chan1 = new TcpChannel();
ChannelServices.RegisterChannel(chan1);
//Test My Remoting Object
DataOperation IObj = (DataOperation)Activator.GetObject(
typeof(RemotingSamples.DataOperation),
"tcp://localhost:8085/DataOperation");
if (IObj != null) {
System.Console.WriteLine(IObj.AddNewData());
}
}
}
{
public static void Main(string[] args)
{
//使用TCP通道得到远程对象
TcpChannel chan1 = new TcpChannel();
ChannelServices.RegisterChannel(chan1);
//Test My Remoting Object
DataOperation IObj = (DataOperation)Activator.GetObject(
typeof(RemotingSamples.DataOperation),
"tcp://localhost:8085/DataOperation");
if (IObj != null) {
System.Console.WriteLine(IObj.AddNewData());
}
}
}
通过这样一个简单的Demo 相信会对一些想学习Remoting 新手朋友有一定的帮助。
以后我将会提供Remoting 一些其他方面的应用给大家作参考。