詳解Remoting序列化及租約
今天就先談談Remoting序列化的問題:首先,Remoting序列化是為了方便網絡傳輸,把遠程對象轉化為網絡可傳輸的形式。Remoting序列化可以實現多種形式:序列化為xml、序列化為二進制等等。當然使用序列化需要添加一個標記【Serializable】,而且可以用SerializableAttribute,或是實現ISerializable接口。下面放個序列化的代碼Demo:
1: [Serializable]
2: public class SumOf
3: {
4: public SumOf()
5: {
6: }
7:
8: public DecimalList Members = new DecimalList();
9:
10: public decimal Sum,Avg;
11:
12: public void Calculate()
13: {
14: this.Sum = 0;
15: foreach (decimal m in Members)
16: {
17: Sum += m;
18: }
19: this.Avg = Sum / Members.Count;
20:
21: }
22:
23: }
24: [Serializable]
25: public class DecimalList : List<decimal>
26: {
27: }
1.對象的生命周期
我們先來認識一下什么是對象,對象就是內存里的數據結構。先說客戶機檢測服務器是否可用,那我們就要驗證遠程對象是否還存在。這個很簡單,我們只要調用遠程對象,如果遠程對象不可用,會出現異常,那說明服務器不可用。接著說服務器檢測客戶機是否可用,使用垃圾回收機制驗證,只對Singleton對象和客戶端激活對象有效。
2.什么是租約
租約是在服務器記錄的一個時間,如果超過這個時間,對象會被回收。
3、續約:為了讓對象繼續存在就必須使用續約
(1)隱式續約:每次調用遠程對象上的方法的時候自動進行。
(2)顯示續約:使用ILease.Renew()方法實現。
(3)發起租約:租約管理者自動續約。ILease.Register()
租約的配置:InitialLeaseTime 租約時間,默認值 300 。RenewOnCallTime檢查時間 默認值120 。SponsorshipTimeout過期時間 默認值120。LeaseManagerPollTime租約管理者臨行時間 默認值10
如何顯示租約信息:
1: ILease lease = (ILease)obj.GetLifetimeService();
2:
3: if (lease != null)
4: {
5: Console.WriteLine("Lease Configuration:");
6: Console.WriteLine("InitialLeaseTime: " +
7: lease.InitialLeaseTime);
8: Console.WriteLine("RenewOnCallTime: " +
9: lease.RenewOnCallTime);
10: Console.WriteLine("SponsorshipTimeout: " +
11: lease.SponsorshipTimeout);
12: Console.WriteLine(lease.CurrentLeaseTime);
13: }
如何配置租約信息:
1代碼方式
1: public override Object InitializeLifetimeService()
2: {
3:
4: ILease lease = (ILease)base.InitializeLifetimeService();
5: // Normally, the initial lease time would be much longer.
6: // It is shortened here for demonstration purposes.
7: if (lease.CurrentState == LeaseState.Initial)
8: {
9: lease.InitialLeaseTime = TimeSpan.FromSeconds(3);
10: lease.SponsorshipTimeout = TimeSpan.FromSeconds(10);
11: lease.RenewOnCallTime = TimeSpan.FromSeconds(2);
12: }
13: return lease;
14: }
2配置文件方式1: <lifetime
2: leaseTime="7M"
3: sponsorshipTimeout="7M"
4: renewOnCallTime="7M"
5: />
本文來自零末的博客園文章《Remoting學習歷程(2)》
【編輯推薦】