一、Reentrant Grains
二、请求上下文
三、激活垃圾收集
四、外部任务和Grains
五、序列化
六、代码生成
七、在Silo内的应用程序引导
八、拦截器
九、取消令牌
十、Powershell客户端
十一、Grains版本控制
十二、Event Sourcing
十三、多群集支持

一、Reentrant Grains

Grain类有以下两个方法

Task Foo()
{
await task1; // line 1
return Do2(); // line 2
} Task Bar()
{
await task2; // line 3
return Do2(); // line 4
}

如果将这个grain标记为[Reentrant],下面的执行顺序是可能会发生:第1行,第3行,第2行和第4行。

如果将这个grain没有标记为[Reentrant],唯一可能的执行将是第1行,第2行,第3行,第4行或者第3行第4行第1行第2行(这个grain是单线程执行的)

二、请求上下文

1,RequestContext包含两个方法:

void Set(string key,object value)用于在请求上下文中存储一个值。该值可以是任何可序列化类型。 Object Get(string key)用于从当前请求上下文中检索一个值

2,例如,要将客户端中的跟踪标识设置为新的GUID,可以简单地调用:

RequestContext.Set("TraceId", new Guid());

在grain代码中(或在调度线程中运行在Orleans的其他代码),可以使用原始客户机请求的跟踪ID,例如,在写入日志时:

Logger.Info("Currently processing external request {0}", RequestContext.Get("TraceId"));

三、激活垃圾收集

1,激活垃圾收集的显式控制

①延迟激活GC

grain激活可以通过调用this.DelayDeactivation()方法来延迟自己的激活GC:

protected void DelayDeactivation(TimeSpan timeSpan)

②加快激活GC

通过调用this.DeactivateOnIdle()方法,grain激活还可以指示运行时在下次空闲时停用它。

 protected void DeactivateOnIdle()

如果目前没有处理任何消息,则谷物激活被认为是空闲的。 如果在grain正在处理消息时调用DeactivateOnIdle,则当前消息的处理完成后将立即停用。 如果有任何排队等待谷物的请求,它们将被转发到下一个激活。

DeactivateOnIdle优先于配置或DelayDeactivation中指定的任何激活垃圾收集设置。 请注意,此设置仅适用于所谓的grain激活,并不适用于此类grain的其他激活。

2,配置

①编程配置

默认Collection Age Limit(所有grain类型)可以通过以下方式设置:

  void GlobalConfiguration.Application.SetDefaultCollectionAgeLimit(TimeSpan ageLimit)

对于单独的grain类型,限制可以通过以下方式设置:

void GlobalConfiguration.Application.SetCollectionAgeLimit(Type type, TimeSpan ageLimit)

该限制也可以为grain类型重置,所以默认限制将适用于它,通过:

void GlobalConfiguration.Application.ResetCollectionAgeLimitToDefault(Type type)

②XML配置(不建议使用)

配置XML文件中的任何时间长度都可以使用指定时间单位的后缀:

后缀 单位
none millisecond(s)
ms millisecond(s)
s second(s)
m minute(s)
hr hour(s)

指定默认收集年龄限制

通过将OrleansConfiguation / Globals / Application / Defaults / Deactivation元素添加到OrleansConfiguration.xml文件,可以自定义适用于所有grain类型的默认集合期限。 允许的最低年龄限制是1分钟。

以下示例指定已空闲10分钟或更长时间的所有激活应被视为取消激活的条件。

<?xml version="1.0" encoding="utf-8"?>
<OrleansConfiguration xmlns="urn:orleans">
<Globals>
<Application>
<Defaults>
<Deactivation AgeLimit="10m"/>
</Defaults>
</Application>
</Globals>
</OrleansConfiguration>

指定每个类型的年龄限制

单个grain类型可以使用OrleansConfiguation / Globals / Application / GrainType / Deactivation元素来指定独立于全局默认的集合年龄限制。 允许的最低年龄限制是1分钟。

在以下示例中,空闲10分钟的激活有资格进行收集,除MyGrainAssembly.DoNotDeactivateMeOften类实例化的激活之外,除非空闲整整24小时,否则不被视为可收集:

<?xml version="1.0" encoding="utf-8"?>
<OrleansConfiguration xmlns="urn:orleans">
<Globals>
<Application>
<Defaults>
<Deactivation AgeLimit="10m"/>
</Defaults>
<GrainType Type="MyGrainAssembly.DoNotDeactivateMeOften">
<Deactivation AgeLimit="24hr"/>
</GrainType>
</Application>
</Globals>
</OrleansConfiguration>

四、外部任务和Grains

五、序列化

六、代码生成

七、在Silo内的应用程序引导

八、拦截器

九、取消令牌

十、Powershell客户端

十一、Grains版本控制

十二、Event Sourcing

十三、多群集支持

Orleans高级功能的更多相关文章

  1. Xen之初体验:XenMotion、 StorageMotion、Site Recovery、Power Management 各种新、高级功能免费

    Xenserver 的新版本6.2现在已经全面开源,省掉了原有的序列号,也能免费体验曾经标题中的付费高级功能. 安装镜像:http://downloadns.citrix.com.edgesuite. ...

  2. MVC5 Entity Framework学习之Entity Framework高级功能(转)

    在之前的文章中,你已经学习了如何实现每个层次结构一个表继承.本节中你将学习使用Entity Framework Code First来开发ASP.NET web应用程序时可以利用的高级功能. 在本节中 ...

  3. C#高级功能(四)扩展方法和索引

    扩展方法使你能够向现有类型“添加”方法,而无需创建新的派生类型.重新编译或以其他方式修改原始类型. 扩展方法是一种特殊的静态方法,但可以像扩展类型上的实例方法一样进行调用.扩展方法被定义为静态方法,但 ...

  4. C#高级功能(三)Action、Func,Tuple

    Action和Func泛型委托实际上就是一个.NET Framework预定义的委托,3.5引入的特性.基本涵盖了所有常用的委托,所以一般不用用户重新声明. Action系列泛型委托,是没有返回参数的 ...

  5. C#高级功能(二)LINQ 和Enumerable类

    介绍LINQ之前先介绍一下枚举器 Iterator:枚举器如果你正在创建一个表现和行为都类似于集合的类,允许类的用户使用foreach语句对集合中的成员进行枚举将会是很方便的.我们将以创建一个简单化的 ...

  6. C#高级功能(一)Lambda 表达式

    Lambda 表达式是一种可用于创建委托或表达式目录树类型的匿名函数. 通过使用 lambda 表达式,可以写入可作为参数传递或作为函数调用值返回的本地函数. Lambda 表达式对于编写 LINQ ...

  7. iOS开发——UI篇Swift篇&玩转UItableView(二)高级功能

    UItableView高级功能 class UITableViewControllerAF: UIViewController, UITableViewDataSource, UITableViewD ...

  8. delphi实现ado的高级功能

    ADO是Microsoft存取通用数据源的标准引擎.ADO通过封装OLE DB而能够存取不同类型的数据,让应用程序能很方便地通过统一的接口处理各种数据库.ADO由一组COM对象组成,每一个不同的原生A ...

  9. Unity3D之Mecanim动画系统学习笔记(十一):高级功能应用

    动作游戏 还记得读书的时候熬夜打<波斯王子>的时光,我们的王子通过跳跃穿过墙壁的小洞.在高层建筑上进行攀爬和跳跃,还有在操作失误掉下高楼和触发必死机关后使用时之沙的时光倒流功能回归死亡之前 ...

随机推荐

  1. SVG2PNG(前台和后台将SVG转换为PNG)--amcharts导出png

    在项目中用到了amcharts,amcharts图标统计插件是利用SVG实现的,其自带下载png功能,但是不支持IE以下浏览器.因此研究了SVG转换为png,最终实现的效果是将amcharts生成一张 ...

  2. media属性

    media=“screen”是什么意思?? media 属性规定目标 URL 是为什么类型的媒介/设备进行优化的. 该属性用于规定目标 URL 是为特殊设备(比如 iPhone).语音或打印媒介设计的 ...

  3. 使用光盘搭建本地yum源

    刚装好的系统,想安装一些常用软件和一些包组的时候,就可以使用安装光盘搭建本地yum 第一步:挂载安装光盘 mount /dev/cdrom /mnt 第二步:编辑repo yum源文件 [root@l ...

  4. I/O 接口及其编址方式

    I/O 接口电路也简称接口电路.它是主机和外围设备之间交换信息的连接部件(电路).它在主机和外围设备之间的信息交换中起着桥梁和纽带作用.设置接口电路的必要性:a) 解决主机CPU 和外围设备之间的时序 ...

  5. 经典SQL语句大全(转)

    SQL语句参考,包含Access.MySQL 以及 SQL Server 基础 创建数据库 CREATE DATABASE database-name 删除数据库 drop database dbna ...

  6. 09-伪数组 arguments

    arguments代表的是实参.有个讲究的地方是:arguments只在函数中使用. (1)返回函数实参的个数:arguments.length 例子: fn(2,4); fn(2,4,6); fn( ...

  7. gulp自动化构建教程

    gulp及gulpfile.js编写示例    本文主要记录一个gulpfile.js示例,以免以后用的时候遗忘.但首先还是要了解gulp是什么以及如何使用. 一.什么是gulp 简单来说:就是压缩前 ...

  8. 使用navicat premium将数据库从Oracle迁移到SQL Server,或从Oracle迁移到MySQL

    有时候我们有迁移数据库的需求,例如从Oracle迁移到SQL Server,或者从MySQL迁移到Oracle. 很多江湖好汉一时不知如何手工操作,所幸的是Navicat提供了迁移的自动化操作界面. ...

  9. css 中两个class之间没有空格与有空格有什么区别

    第一个匹配: <div class="ul item"></div>:无法匹配:<div class="ul"></d ...

  10. Java NIO系列教程(一)java NIO简介

    这个系列的文章,我们开始玩一玩IO方面的知识,对于IO和NIO,我们经常会接触到,了解他们的基本内容,对于我们的工作会有特别大的帮助.这篇博文我们仅仅是介绍IO和NIO的基本概念,以及一些关键词. 基 ...