无论是在 Web 角色还是工作角色实例上,方法都是相同的,因为它们本质上都是 Windows 2008 Server(只是 Web 角色运行 IIS,这也消耗了一些端口)。无论您想在哪个端口上挂起 wcf 服务,只需将它们定义为输入端点(每个端口一个端点),并决定哪个角色处理该端点。
只要您有可用的端口,您就可以拥有多个 ServiceHost。当前每个部署的输入端点总数为 25 个,内部端点总数为 25 个,因此这是您的绝对限制。当然,如果启用 RDP,可用端口数会下降。哦:关于协议:如果你想要 http 和 tcp,你需要定义两个端点,因为协议是用 Endpoint 定义定义的。
内部端点 WCF 服务几乎相同,但您可以取消安全性并使用 net.tcp 进行快速传输。负载平衡的一个区别是:
- 挂在输入端点上的 WCF 服务将在角色的所有实例之间进行负载平衡
- 挂在内部终结点上的 WCF 服务将不会进行负载平衡。
对于后一种情况:假设您的 Web 角色需要与内部端点上的 Worker 角色的 WCF 服务通信。您需要枚举所有实例,获取每个实例的 IP+端口,然后随机选择一个(或循环,或您选择的任何方法)。这是一个示例方法,它从给定角色和给定端点名称返回一个随机端点实例(代码来自 Michael Washam 的博客):
private String GetRandomServiceIP(String roleName, String endPointName)
{
var endpoints = RoleEnvironment.Roles[roleName].Instances.Select(i => i.InstanceEndpoints[endPointName]).ToArray();
var r = new Random(DateTime.Now.Millisecond);
int ipIndex = r.Next(endpoints.Count());
return endpoints[ipIndex].IPEndpoint.Address.ToString();
}
至于设置 WCF 服务和相关的 URI,我强烈建议使用最新的Windows Azure 培训工具包并通过Worker Role Communication动手实验室,其中详细介绍了如何设置 ServiceHost,两者都有输入端点和内部端点。