本文整理匯總了C#中ActorSystem.AsInstanceOf方法的典型用法代碼示例。如果您正苦於以下問題:C# ActorSystem.AsInstanceOf方法的具體用法?C# ActorSystem.AsInstanceOf怎麽用?C# ActorSystem.AsInstanceOf使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類ActorSystem
的用法示例。
在下文中一共展示了ActorSystem.AsInstanceOf方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: RemoteDeploySpec
public RemoteDeploySpec()
: base(@"
akka {
loglevel = INFO
log-dead-letters-during-shutdown = false
// actor.provider = ""Akka.Remote.RemoteActorRefProvider, Akka.Remote""
remote.helios.tcp = {
hostname = localhost
port = 0
}
actor.deployment {
/router1 {
router = round-robin-pool
nr-of-instances = 3
}
/router2 {
router = round-robin-pool
nr-of-instances = 3
}
/router3 {
router = round-robin-pool
nr-of-instances = 0
}
}
}
")
{
_remoteSystem = ActorSystem.Create("RemoteSystem", Sys.Settings.Config);
_remoteAddress = _remoteSystem.AsInstanceOf<ExtendedActorSystem>().Provider.DefaultAddress;
var remoteAddressUid = AddressUidExtension.Uid(_remoteSystem);
}
示例2: ConsistentHashingRoutingLogic
/// <summary>
/// Initializes a new instance of the <see cref="ConsistentHashingRoutingLogic"/> class.
/// </summary>
/// <param name="system">The actor system that owns the router with this logic.</param>
/// <param name="virtualNodesFactor">The number of virtual nodes to use on the hash ring.</param>
/// <param name="hashMapping">The consistent hash mapping function to use on incoming messages.</param>
public ConsistentHashingRoutingLogic(ActorSystem system, int virtualNodesFactor,
ConsistentHashMapping hashMapping)
{
_system = system;
_log = new Lazy<ILoggingAdapter>(() => Logging.GetLogger(_system, this), true);
_hashMapping = hashMapping;
_selfAddress = system.AsInstanceOf<ExtendedActorSystem>().Provider.DefaultAddress;
_vnodes = virtualNodesFactor == 0 ? system.Settings.DefaultVirtualNodesFactor : virtualNodesFactor;
}
示例3: MultiNodeSpec
protected MultiNodeSpec(
RoleName myself,
ActorSystem system,
ImmutableList<RoleName> roles,
Func<RoleName, ImmutableList<string>> deployments)
: base(new XunitAssertions(), system)
{
_myself = myself;
_log = Logging.GetLogger(Sys, this);
_roles = roles;
_deployments = deployments;
var node = new IPEndPoint(Dns.GetHostAddresses(ServerName)[0], ServerPort);
_controllerAddr = node;
AttachConductor(new TestConductor(system));
_replacements = _roles.ToImmutableDictionary(r => r, r => new Replacement("@" + r.Name + "@", r, this));
InjectDeployments(system, myself);
_myAddress = system.AsInstanceOf<ExtendedActorSystem>().Provider.DefaultAddress;
Log.Info("Role [{0}] started with address [{1}]", myself.Name, _myAddress);
MultiNodeSpecBeforeAll();
}
示例4: InjectDeployments
protected void InjectDeployments(ActorSystem system, RoleName role)
{
var deployer = system.AsInstanceOf<ExtendedActorSystem>().Provider.Deployer;
foreach (var str in _deployments(role))
{
var deployString = _replacements.Values.Aggregate(str, (@base, r) =>
{
var indexOf = @base.IndexOf(r.Tag, StringComparison.Ordinal);
if (indexOf == -1) return @base;
string replaceWith;
try
{
replaceWith = r.Addr;
}
catch (Exception e)
{
// might happen if all test cases are ignored (excluded) and
// controller node is finished/exited before r.addr is run
// on the other nodes
var unresolved = "akka://unresolved-replacement-" + r.Role.Name;
Log.Warning(unresolved + " due to: {0}", e.ToString());
replaceWith = unresolved;
}
return @base.Replace(r.Tag, replaceWith);
});
foreach (var pair in ConfigurationFactory.ParseString(deployString).AsEnumerable())
{
if (pair.Value.IsObject())
{
var deploy =
deployer.ParseConfig(pair.Key, new Config(new HoconRoot(pair.Value)));
deployer.SetDeploy(deploy);
}
else
{
throw new ArgumentException(String.Format("key {0} must map to deployment section, not simple value {1}",
pair.Key, pair.Value));
}
}
}
}