新聞中心

        EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 基于云存儲實(shí)現(xiàn)用Windows Azure Storage增強(qiáng)應(yīng)用程序的引擎

        基于云存儲實(shí)現(xiàn)用Windows Azure Storage增強(qiáng)應(yīng)用程序的引擎

        作者: 時(shí)間:2018-09-11 來源:網(wǎng)絡(luò) 收藏

        本文引用地址:http://www.104case.com/article/201809/388914.htm

          現(xiàn)在,我們需要一個(gè)簡單的包裝來與我們的隊(duì)列交互。從本質(zhì)上說,我們需要能夠?qū)⑾⒉迦腙?duì)列,獲取任何掛起的消息并清除該隊(duì)列(請參見圖 3)。

          圖 3 用于與隊(duì)列交互的包裝

        namespace HollywoodHackers..Queue 
        { 
          public class StdQueueT> : 
          Base where T : QueueMessageBase, new() 
          { 
            protected CloudQueue queue; 
            protected CloudQueueClient client; 
         
            public StdQueue(string queueName) 
            { 
              client = new CloudQueueClient 
              (Base.QueueBaseUri, StorageBase.Credentials); 
              queue = client.GetQueueReference(queueName); 
              queue.CreateIfNotExist(); 
            } 
            public void AddMessage(T message) 
            { 
              CloudQueueMessage msg = 
              new CloudQueueMessage(message.ToBinary()); 
              queue.AddMessage(msg); 
            } 
            public void DeleteMessage(CloudQueueMessage msg) 
            { 
              queue.DeleteMessage(msg); 
            } 
            public CloudQueueMessage GetMessage() 
            { 
              return queue.GetMessage(TimeSpan.FromSeconds(60)); 
            } 
          } 
          public class ToastQueue : StdQueueToastQueueMessage> 
          { 
            public ToastQueue() 
              : base(toasts) 
            { 
            } 
          } 
        }

        我們還需要為表存儲設(shè)置一個(gè)包裝,以便在用戶登錄到站點(diǎn)之前可以存儲用戶通知。可以使用 PartitionKey(行集合的標(biāo)識符)和 RowKey(可唯一標(biāo)識特定分區(qū)中的每個(gè)單獨(dú)行)組織表數(shù)據(jù)。選擇 PartitionKey 和 RowKey 使用的數(shù)據(jù)是在使用表存儲時(shí)所做的最重要的設(shè)計(jì)決策之一。

          這些特點(diǎn)允許跨存儲節(jié)點(diǎn)進(jìn)行負(fù)載平衡,并在應(yīng)用程序中提供內(nèi)置的可伸縮性選項(xiàng)。不考慮數(shù)據(jù)的數(shù)據(jù)中心關(guān)聯(lián)性,使用同一分區(qū)鍵的表存儲中的行將保留在相同的物理數(shù)據(jù)存儲中。因?yàn)獒槍γ總€(gè)用戶存儲對應(yīng)的消息,所以分區(qū)鍵將是 UserName,而 RowKey 則成為標(biāo)識每行的 GUID(請參見圖 4)。

          圖 4 表存儲的包裝

        namespace HollywoodHackers.Storage.Repositories 
        { 
          public class UserTextNotificationRepository : StorageBase 
          { 
            public const string EntitySetName = 
            UserTextNotifications; 
            CloudTableClient tableClient; 
            UserTextNotificationContext notificationContext; 
            public UserTextNotificationRepository() 
              : base() 
            { 
              tableClient = new CloudTableClient 
              (StorageBase.TableBaseUri, StorageBase.Credentials); 
              notificationContext = new UserTextNotificationContext 
              (StorageBase.TableBaseUri,StorageBase.Credentials); 
         
              tableClient.CreateTableIfNotExist(EntitySetName); 
            } 
            public UserTextNotification[] 
            GetNotificationsForUser(string userName) 
            { 
              var q = from notification in 
                  notificationContext.UserNotifications 
                  where notification.TargetUserName == 
                  userName select notification; 
              return q.ToArray(); 
            } 
            public void AddNotification 
            (UserTextNotification notification) 
            { 
              notification.RowKey = Guid.NewGuid().ToString(); 
              notificationContext.AddObject 
              (EntitySetName, notification); 
              notificationContext.SaveChanges(); 
            } 
          } 
        }



        關(guān)鍵詞: Windows Storage Azure 云存儲

        評論


        相關(guān)推薦

        技術(shù)專區(qū)

        關(guān)閉
        主站蜘蛛池模板: 营山县| 兴化市| 兴海县| 容城县| 松江区| 祁门县| 涿鹿县| 建德市| 桃园县| 青浦区| 天长市| 盐城市| 宜阳县| 甘洛县| 万州区| 贵州省| 营山县| 桃江县| 九龙坡区| 错那县| 阿瓦提县| 乌鲁木齐县| 祁阳县| 乐平市| 兰溪市| 巴林右旗| 开原市| 三江| 广水市| 河东区| 东阿县| 通州市| 西林县| 中卫市| 武平县| 永州市| 岚皋县| 苗栗市| 鸡西市| 聊城市| 揭东县|