一个最简单的.NET Remoting构建的分布式应用程序示例
2006-07-13 14:51
691 查看
服务器端代码
文件名:Server.cs
using System;
using System.Runtime.Remoting;
using System.Runtime.Remoting.Channels;
using System.Runtime.Remoting.Channels.Tcp;
using System.Runtime.Remoting.Channels.Http;
namespace RemotingSamples
{
public class Server
{
public static int Main(string [] args)
{
TcpChannel chan1 = new TcpChannel(8085);
HttpChannel chan2 = new HttpChannel(8086);
ChannelServices.RegisterChannel(chan1);
ChannelServices.RegisterChannel(chan2);
RemotingConfiguration.RegisterWellKnownServiceType
(
typeof(OrderNumber),
"SayHello",
WellKnownObjectMode.Singleton
);
System.Console.WriteLine("Press Enter key to exit");
System.Console.ReadLine();
return 0;
}
}
}
远程对象代码
文件名:OrderNumber.cs
using System;
using System.Collections.Generic;
using System.Text;
namespace RemotingSamples
{
public class OrderNumber : MarshalByRefObject
{
private int djIncNumber;
public OrderNumber()
{
System.Console.WriteLine("服务器端已经被激活……");
}
public int IncOrderNumber()
{
djIncNumber = djIncNumber + 1;
Console.WriteLine("服务被客户端调用{0}次", djIncNumber);
return djIncNumber;
}
}
}
客户端代码
文件名:Client.cs
using System;
using System.Runtime.Remoting;
using System.Runtime.Remoting.Channels;
using System.Runtime.Remoting.Channels.Tcp;
using System.Runtime.Remoting.Channels.Http;
using System.IO;
namespace RemotingSamples
{
public class Client
{
public static void Main(string[] args)
{
//使用TCP通道得到远程对象
TcpChannel chan1 = new TcpChannel();
ChannelServices.RegisterChannel(chan1);
OrderNumber obj1 = (OrderNumber)Activator.GetObject(
typeof(RemotingSamples.OrderNumber),
"tcp://localhost:8085/SayHello");
if (obj1 == null)
{
System.Console.WriteLine(
"Could not locate TCP server");
System.Console.ReadLine();
}
//使用HTTP通道得到远程对象
HttpChannel chan2 = new HttpChannel();
ChannelServices.RegisterChannel(chan2);
OrderNumber obj2 = (OrderNumber)Activator.GetObject(
typeof(RemotingSamples.OrderNumber),
"http://localhost:8086/SayHello");
if (obj2 == null)
{
System.Console.WriteLine(
"Could not locate HTTP server");
System.Console.ReadLine();
}
Console.WriteLine(
"Client1 TCP HelloMethod {0}",
obj1.IncOrderNumber());
Console.WriteLine(
"Client2 HTTP HelloMethod {0}",
obj2.IncOrderNumber());
Console.ReadLine();
}
}
}
文件名:Server.cs
using System;
using System.Runtime.Remoting;
using System.Runtime.Remoting.Channels;
using System.Runtime.Remoting.Channels.Tcp;
using System.Runtime.Remoting.Channels.Http;
namespace RemotingSamples
{
public class Server
{
public static int Main(string [] args)
{
TcpChannel chan1 = new TcpChannel(8085);
HttpChannel chan2 = new HttpChannel(8086);
ChannelServices.RegisterChannel(chan1);
ChannelServices.RegisterChannel(chan2);
RemotingConfiguration.RegisterWellKnownServiceType
(
typeof(OrderNumber),
"SayHello",
WellKnownObjectMode.Singleton
);
System.Console.WriteLine("Press Enter key to exit");
System.Console.ReadLine();
return 0;
}
}
}
远程对象代码
文件名:OrderNumber.cs
using System;
using System.Collections.Generic;
using System.Text;
namespace RemotingSamples
{
public class OrderNumber : MarshalByRefObject
{
private int djIncNumber;
public OrderNumber()
{
System.Console.WriteLine("服务器端已经被激活……");
}
public int IncOrderNumber()
{
djIncNumber = djIncNumber + 1;
Console.WriteLine("服务被客户端调用{0}次", djIncNumber);
return djIncNumber;
}
}
}
客户端代码
文件名:Client.cs
using System;
using System.Runtime.Remoting;
using System.Runtime.Remoting.Channels;
using System.Runtime.Remoting.Channels.Tcp;
using System.Runtime.Remoting.Channels.Http;
using System.IO;
namespace RemotingSamples
{
public class Client
{
public static void Main(string[] args)
{
//使用TCP通道得到远程对象
TcpChannel chan1 = new TcpChannel();
ChannelServices.RegisterChannel(chan1);
OrderNumber obj1 = (OrderNumber)Activator.GetObject(
typeof(RemotingSamples.OrderNumber),
"tcp://localhost:8085/SayHello");
if (obj1 == null)
{
System.Console.WriteLine(
"Could not locate TCP server");
System.Console.ReadLine();
}
//使用HTTP通道得到远程对象
HttpChannel chan2 = new HttpChannel();
ChannelServices.RegisterChannel(chan2);
OrderNumber obj2 = (OrderNumber)Activator.GetObject(
typeof(RemotingSamples.OrderNumber),
"http://localhost:8086/SayHello");
if (obj2 == null)
{
System.Console.WriteLine(
"Could not locate HTTP server");
System.Console.ReadLine();
}
Console.WriteLine(
"Client1 TCP HelloMethod {0}",
obj1.IncOrderNumber());
Console.WriteLine(
"Client2 HTTP HelloMethod {0}",
obj2.IncOrderNumber());
Console.ReadLine();
}
}
}
相关文章推荐
- C# 创建、部署和调用WebService的简单示例 webservice 可以用于分布式应用程序之间的交互,和不同程序之间的交互。 概念性的东西就不说太多,下面开始创建一个简单的webservi
- 使用Hprose制作一个简单的分布式应用程序
- 一步一个脚印学习WCF之二构建一个简单的WCF应用程序前必须掌握的WCF基础术语---地址(Addresses)
- 构建一个 hibernate 简单示例
- [zz]构建一个分布式操作系统的简单方案—答陈硕的“分布式系统中的进程标识”一文
- 使用 Pitney Bowes 定位服务构建一个简单的图片定位应用程序
- 一步一个脚印学习WCF之二构建一个简单的WCF应用程序前必须掌握的WCF基础术语---契约(Contract)
- Android高效的应用程序开发工具集1---ant构建一个简单的Android工程
- Net Remoting-分布式应用程序构建
- 一步一个脚印学习WCF之二构建一个简单的WCF应用程序前必须掌握的WCF基础术语---契约的名称与命名空间
- 用 JFace和SWT 构建一个简单的应用程序
- 构建一个分布式操作系统的简单方案—答陈硕的“分布式系统中的进程标识”一文
- 使用rpcgen构建分布式程序的一个简单例子
- 在 Eclipse Workbench 之外使用 Eclipse GUI,第 1 部分: 单独使用 JFace 和 SWT构建一个简单的文件资源管理器应用程序
- 构建一个分布式操作系统的简单方案—答陈硕的“分布式系统中的进程标识”一文
- 构建一个简单的Silverlight应用程序
- 使用rpcgen构建分布式程序的一个简单例子
- 使用ant工具——构建一个简单的Hibernate应用程序
- 构建一个简单的Three.js 示例
- 构建一个简单的ios应用程序