• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

C# ShardLocation类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了C#中ShardLocation的典型用法代码示例。如果您正苦于以下问题:C# ShardLocation类的具体用法?C# ShardLocation怎么用?C# ShardLocation使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。



ShardLocation类属于命名空间,在下文中一共展示了ShardLocation类的20个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的C#代码示例。

示例1: FindShardByLocationGlobalOperation

 /// <summary>
 /// Constructs request to get shard with specific location for given shard map from GSM.
 /// </summary>
 /// <param name="shardMapManager">Shard map manager object.</param>
 /// <param name="operationName">Operation name, useful for diagnostics.</param>
 /// <param name="shardMap">Shard map for which shard is being requested.</param>
 /// <param name="location">Location of shard being searched.</param>
 internal FindShardByLocationGlobalOperation(ShardMapManager shardMapManager, string operationName, IStoreShardMap shardMap, ShardLocation location) :
     base(shardMapManager.Credentials, shardMapManager.RetryPolicy, operationName)
 {
     _shardMapManager = shardMapManager;
     _shardMap = shardMap;
     _location = location;
 }
开发者ID:CrossPoint,项目名称:elastic-db-tools,代码行数:14,代码来源:FindShardByLocationGlobalOperation.cs


示例2: CreateOrGetEmptyShard

        /// <summary>
        /// 建立 new shard, 或取得現有空的 shard (i.e. a shard 可能還沒 mapper ).
        /// 空的 shard 可能存在的原因是因為,創建和初始化的時候,我們無法 mapping 他
        /// </summary>
        private static Shard CreateOrGetEmptyShard(RangeShardMap<int> shardMap)
        {
            // 假如已經有了,則取得空的 shard
            Shard shard = FindEmptyShard(shardMap);
            if (shard == null)
            {
                // 為 Null,表示沒有空的,所以要建立

                // 更改 shard name
                string databaseName = string.Format(ShardNameFormat, shardMap.GetShards().Count());

                // 假如資料庫不存在,則建立資料庫
                // 假如存在,則會返回
                if (!SqlDatabaseUtils.DatabaseExists(Configuration.ShardMapManagerServerName, databaseName))
                {
                    SqlDatabaseUtils.CreateDatabase(Configuration.ShardMapManagerServerName, databaseName);
                }

                // 建立 schema 和相關的資料到 db
                // 並使用初始化腳本初始化,如果資料庫已經存在,會發生問題
                //
                SqlDatabaseUtils.ExecuteSqlScript(
                    Configuration.ShardMapManagerServerName, databaseName, InitializeShardScriptFile);

                // 產生shard Location , 並取得 Shard
                ShardLocation shardLocation = new ShardLocation(Configuration.ShardMapManagerServerName, databaseName);
                shard = ShardManagementUtils.CreateOrGetShard(shardMap, shardLocation);
            }

            return shard;
        }
开发者ID:SkyChang,项目名称:Elastic-DB-Tools,代码行数:35,代码来源:CreateShardSample.cs


示例3: CheckShardLocalOperation

 /// <summary>
 /// Constructs request for obtaining all the shard maps and shards from an LSM.
 /// </summary>
 /// <param name="operationName">Operation name.</param>
 /// <param name="shardMapManager">Shard map manager.</param>
 /// <param name="location">Location of the LSM.</param>
 internal CheckShardLocalOperation(
     string operationName,
     ShardMapManager shardMapManager,
     ShardLocation location) :
     base(shardMapManager.Credentials, shardMapManager.RetryPolicy, location, operationName)
 {
 }
开发者ID:CrossPoint,项目名称:elastic-db-tools,代码行数:13,代码来源:CheckShardLocalOperation.cs


示例4: RegisterNewShard

        // Enter a new shard - i.e. an empty database - to the shard map, allocate a first tenant to it 
        // and kick off EF intialization of the database to deploy schema
        // public void RegisterNewShard(string server, string database, string user, string pwd, string appname, int key)
        public void RegisterNewShard(string server, string database, string connstr, int key)
        {
            Shard shard;
            ShardLocation shardLocation = new ShardLocation(server, database);

            if (!this.ShardMap.TryGetShard(shardLocation, out shard))
            {
                shard = this.ShardMap.CreateShard(shardLocation);
            }

            SqlConnectionStringBuilder connStrBldr = new SqlConnectionStringBuilder(connstr);
            connStrBldr.DataSource = server;
            connStrBldr.InitialCatalog = database;

            // Go into a DbContext to trigger migrations and schema deployment for the new shard.
            // This requires an un-opened connection.
            using (var db = new ElasticScaleContext<int>(connStrBldr.ConnectionString))
            {
                // Run a query to engage EF migrations
                (from b in db.Blogs
                 select b).Count();
            }

            // Register the mapping of the tenant to the shard in the shard map.
            // After this step, DDR on the shard map can be used
            PointMapping<int> mapping;
            if (!this.ShardMap.TryGetMappingForKey(key, out mapping))
            {
                this.ShardMap.CreatePointMapping(key, shard);
            }
        }
开发者ID:xdansmith,项目名称:elastic-db-tools,代码行数:34,代码来源:Sharding.cs


示例5: CreateOrGetEmptyShard

        /// <summary>
        /// Creates a new shard, or gets an existing empty shard (i.e. a shard that has no mappings).
        /// The reason why an empty shard might exist is that it was created and initialized but we 
        /// failed to create a mapping to it.
        /// </summary>
        private static Shard CreateOrGetEmptyShard(RangeShardMap<int> shardMap)
        {
            // Get an empty shard if one already exists, otherwise create a new one
            Shard shard = FindEmptyShard(shardMap);
            if (shard == null)
            {
                // No empty shard exists, so create one

                // Choose the shard name
                string databaseName = string.Format(ShardNameFormat, shardMap.GetShards().Count());

                // Only create the database if it doesn't already exist. It might already exist if
                // we tried to create it previously but hit a transient fault.
                if (!SqlDatabaseUtils.DatabaseExists(Configuration.ShardMapManagerServerName, databaseName))
                {
                    SqlDatabaseUtils.CreateDatabase(Configuration.ShardMapManagerServerName, databaseName);
                }

                // Create schema and populate reference data on that database
                // The initialize script must be idempotent, in case it was already run on this database
                // and we failed to add it to the shard map previously
                SqlDatabaseUtils.ExecuteSqlScript(
                    Configuration.ShardMapManagerServerName, databaseName, InitializeShardScriptFile);

                // Add it to the shard map
                ShardLocation shardLocation = new ShardLocation(Configuration.ShardMapManagerServerName, databaseName);
                shard = ShardManagementUtils.CreateOrGetShard(shardMap, shardLocation);
            }

            return shard;
        }
开发者ID:snowstormlife,项目名称:blizElasticScale,代码行数:36,代码来源:CreateShardSample.cs


示例6: UpgradeStoreLocalOperation

 /// <summary>
 /// Constructs request to upgrade store hosting LSM.
 /// </summary>
 /// <param name="shardMapManager">Shard map manager object.</param>
 /// <param name="location">Store location to upgrade.</param>
 /// <param name="operationName">Operation name, useful for diagnostics.</param>
 /// <param name="targetVersion">Target version to upgrade.</param>
 internal UpgradeStoreLocalOperation(
     ShardMapManager shardMapManager,
     ShardLocation location,
     string operationName,
     Version targetVersion) :
     base(shardMapManager.Credentials, shardMapManager.RetryPolicy, location, operationName)
 {
     _targetVersion = targetVersion;
 }
开发者ID:CrossPoint,项目名称:elastic-db-tools,代码行数:16,代码来源:UpgradeStoreLocalOperation.cs


示例7: LabeledDbDataReader

        internal LabeledDbDataReader(MultiShardException exception, ShardLocation shardLocation, DbCommand cmd)
            : this(shardLocation, cmd)
        {
            if (null == exception)
            {
                throw new ArgumentNullException("exception");
            }

            this.Exception = exception;
        }
开发者ID:xdansmith,项目名称:elastic-db-tools,代码行数:10,代码来源:LabeledDbDataReader.cs


示例8: MultiShardException

        /// <summary>
        /// Initializes a new instance of the <see cref="MultiShardException"/> class with
        /// the specified shard location, error message and exception encountered.
        /// </summary>
        /// <param name="shardLocation"> specifies the location of the shard where the exception occurred.</param>
        /// <param name="message"> specifices the message that explains the reason for the exception.</param>
        /// <param name="inner"> specifies the exception encountered at the shard.</param>
        /// <exception cref="T:System.ArgumentNullException">The <paramref name="shardLocation"/> is null </exception>
        public MultiShardException(ShardLocation shardLocation, string message, Exception inner)
            : base(message, inner)
        {
            if (null == shardLocation)
            {
                throw new ArgumentNullException("shardLocation");
            }

            _shardLocation = shardLocation;
        }
开发者ID:xdansmith,项目名称:elastic-db-tools,代码行数:18,代码来源:MultiShardException.cs


示例9: StoreOperationLocal

 /// <summary>
 /// Constructs an instance of SqlOperationLocal.
 /// </summary>
 /// <param name="credentials">Credentials for connecting to SMM databases.</param>
 /// <param name="retryPolicy">Retry policy for requests.</param>
 /// <param name="location">Shard location where the operation is to be performed.</param>
 /// <param name="operationName">Operation name.</param>
 internal StoreOperationLocal(
     SqlShardMapManagerCredentials credentials,
     TransientFaultHandling.RetryPolicy retryPolicy,
     ShardLocation location,
     string operationName)
 {
     _credentials = credentials;
     _retryPolicy = retryPolicy;
     this.OperationName = operationName;
     this.Location = location;
 }
开发者ID:xdansmith,项目名称:elastic-db-tools,代码行数:18,代码来源:StoreOperationLocal.cs


示例10: CreateDetachShardGlobalOperation

 /// <summary>
 /// Constructs request for Detaching the given shard and mapping information to the GSM database.
 /// </summary>
 /// <param name="shardMapManager">Shard map manager object.</param>
 /// <param name="operationName">Operation name.</param>
 /// <param name="location">Location to be detached.</param>
 /// <param name="shardMapName">Shard map from which shard is being detached.</param>
 /// <returns>The store operation.</returns>
 public virtual IStoreOperationGlobal CreateDetachShardGlobalOperation(
     ShardMapManager shardMapManager,
     string operationName,
     ShardLocation location,
     string shardMapName)
 {
     return new DetachShardGlobalOperation(
         shardMapManager,
         operationName,
         location,
         shardMapName);
 }
开发者ID:xdansmith,项目名称:elastic-db-tools,代码行数:20,代码来源:StoreOperationFactory.cs


示例11: DefaultStoreShard

 /// <summary>
 /// Constructs the storage representation from client side objects.
 /// </summary>
 /// <param name="id">Shard Id.</param>
 /// <param name="version">Shard version.</param>
 /// <param name="shardMapId">Identify of shard map.</param>
 /// <param name="location">Data source location.</param>
 /// <param name="status">Status of the shard.</param>
 internal DefaultStoreShard(
     Guid id,
     Guid version,
     Guid shardMapId,
     ShardLocation location,
     int status)
 {
     this.Id = id;
     this.Version = version;
     this.ShardMapId = shardMapId;
     this.Location = location;
     this.Status = status;
 }
开发者ID:CrossPoint,项目名称:elastic-db-tools,代码行数:21,代码来源:DefaultStoreShard.cs


示例12: ReplaceMappingsLocalOperation

 /// <summary>
 /// Constructs request for replacing the LSM mappings for given shard map with the input mappings.
 /// </summary>
 /// <param name="shardMapManager">Shard map manager.</param>
 /// <param name="location">Location of the LSM.</param>
 /// <param name="operationName">Operation name.</param>
 /// <param name="shardMap">Local shard map.</param>
 /// <param name="shard">Local shard.</param>
 /// <param name="rangesToRemove">Optional list of ranges to minimize amount of deletions.</param>
 /// <param name="mappingsToAdd">List of mappings to add.</param>
 internal ReplaceMappingsLocalOperation(
     ShardMapManager shardMapManager,
     ShardLocation location,
     string operationName,
     IStoreShardMap shardMap,
     IStoreShard shard,
     IEnumerable<ShardRange> rangesToRemove,
     IEnumerable<IStoreMapping> mappingsToAdd) :
     base(shardMapManager.Credentials, shardMapManager.RetryPolicy, location, operationName)
 {
     _shardMap = shardMap;
     _shard = shard;
     _rangesToRemove = rangesToRemove;
     _mappingsToAdd = mappingsToAdd;
 }
开发者ID:CrossPoint,项目名称:elastic-db-tools,代码行数:25,代码来源:ReplaceMappingsLocalOperation.cs


示例13: GetMappingsByRangeLocalOperation

        /// <summary>
        /// Constructs request for obtaining all the shard maps and shards from an LSM.
        /// </summary>
        /// <param name="shardMapManager">Shard map manager.</param>
        /// <param name="location">Location of the LSM.</param>
        /// <param name="operationName">Operation name.</param>
        /// <param name="shardMap">Local shard map.</param>
        /// <param name="shard">Local shard.</param>
        /// <param name="range">Optional range to get mappings from.</param>
        /// <param name="ignoreFailure">Ignore shard map not found error.</param>
        internal GetMappingsByRangeLocalOperation(
            ShardMapManager shardMapManager,
            ShardLocation location,
            string operationName,
            IStoreShardMap shardMap,
            IStoreShard shard,
            ShardRange range,
            bool ignoreFailure) :
            base(shardMapManager.Credentials, shardMapManager.RetryPolicy, location, operationName)
        {
            Debug.Assert(shard != null);

            _shardMap = shardMap;
            _shard = shard;
            _range = range;
            _ignoreFailure = ignoreFailure;
        }
开发者ID:CrossPoint,项目名称:elastic-db-tools,代码行数:27,代码来源:GetMappingsByRangeLocalOperation.cs


示例14: RegisterNewShard

        // Enter a new shard - i.e. an empty database - to the shard map, allocate a first tenant to it 
        public void RegisterNewShard(string server, string database, string connstr, int key)
        {
            Shard shard;
            ShardLocation shardLocation = new ShardLocation(server, database);

            if (!this.ShardMap.TryGetShard(shardLocation, out shard))
            {
                shard = this.ShardMap.CreateShard(shardLocation);
            }

            // Register the mapping of the tenant to the shard in the shard map.
            // After this step, DDR on the shard map can be used
            PointMapping<int> mapping;
            if (!this.ShardMap.TryGetMappingForKey(key, out mapping))
            {
                this.ShardMap.CreatePointMapping(key, shard);
            }
        }
开发者ID:CrossPoint,项目名称:elastic-db-tools,代码行数:19,代码来源:Sharding.cs


示例15: FailsValidationWhenAnyShardLocationsAreNull

        public void FailsValidationWhenAnyShardLocationsAreNull()
        {
            var sut = new AddInt32RangeMapShardsArgs
            {
                ConnectionString = @"Server = (localdb)\mssqllocaldb; Initial Catalog = SomeTestDb; Integrated Security = true; Application Name = Galen.CI.Azure.Sql.Sharding.App.Tests;",
                MapName = "MyTestIntRangeMapName",
                ShardLocations = new ShardLocations()
            };

            var validShardLocation = new ShardLocation
            {
                ServerName = @"(localdb)\.\SharedLocalDb",
                DatabaseName = "MyTestShardDb001"
            };

            sut.ShardLocations.Locations = new [] {validShardLocation, null};

            sut.Validate();
        }
开发者ID:GalenHealthcare,项目名称:Galen.Ef.Deployer,代码行数:19,代码来源:AddInt32RangeMapShardsArgsTests.cs


示例16: FindShardByLocationGlobal

 /// <summary>
 /// Request to get shard with specified location for a shard map from GSM.
 /// </summary>
 /// <param name="shardMap">Shard map for which to get shard.</param>
 /// <param name="location">Location for which to find shard.</param>
 /// <returns>Xml formatted request.</returns>
 internal static XElement FindShardByLocationGlobal(
     IStoreShardMap shardMap,
     ShardLocation location)
 {
     return new XElement(
         @"FindShardByLocationGlobal",
         StoreOperationRequestBuilder.s_gsmVersion,
         StoreObjectFormatterXml.WriteIStoreShardMap("ShardMap", shardMap),
         StoreObjectFormatterXml.WriteShardLocation("Location", location));
 }
开发者ID:CrossPoint,项目名称:elastic-db-tools,代码行数:16,代码来源:StoreOperationRequestBuilder.cs


示例17: OnShardMapperErrorLocal

 /// <summary>
 /// Returns the proper ShardManagementException corresponding to given error code in 
 /// <paramref name="result"/> for ShardMapper operations.
 /// </summary>
 /// <param name="result">Operation result object.</param>
 /// <param name="location">Location of LSM operation.</param>
 /// <param name="operationName">Operation being performed.</param>
 /// <param name="storedProcName">Stored procedure being executed.</param>
 /// <returns>ShardManagementException to be raised.</returns>
 internal static ShardManagementException OnShardMapperErrorLocal(
     IStoreResults result,
     ShardLocation location,
     string operationName,
     string storedProcName)
 {
     switch (result.Result)
     {
         case StoreResult.StoreVersionMismatch:
         case StoreResult.MissingParametersForStoredProcedure:
         default:
             return StoreOperationErrorHandler.OnCommonErrorLocal(
                 result,
                 location,
                 operationName,
                 storedProcName);
     }
 }
开发者ID:xdansmith,项目名称:elastic-db-tools,代码行数:27,代码来源:StoreOperationErrorHandler.cs


示例18: OnRecoveryErrorLocal

        /// <summary>
        /// Returns the proper ShardManagementException corresponding to given error code in 
        /// <paramref name="result"/> for ShardMap operations.
        /// </summary>
        /// <param name="result">Operation result object.</param>
        /// <param name="shardMap">Shard map object.</param>
        /// <param name="location">Location of operation.</param>
        /// <param name="errorCategory">Error category to use for raised errors.</param>
        /// <param name="operationName">Operation being performed.</param>
        /// <param name="storedProcName">Stored procedure being executed.</param>
        /// <returns>ShardManagementException to be raised.</returns>
        internal static ShardManagementException OnRecoveryErrorLocal(
            IStoreResults result,
            IStoreShardMap shardMap,
            ShardLocation location,
            ShardManagementErrorCategory errorCategory,
            string operationName,
            string storedProcName)
        {
            switch (result.Result)
            {
                case StoreResult.ShardMapDoesNotExist:
                    return new ShardManagementException(
                        errorCategory,
                        ShardManagementErrorCode.ShardMapDoesNotExist,
                        Errors._Store_ShardMap_DoesNotExistLocal,
                        shardMap.Name,
                        location,
                        storedProcName,
                        operationName);

                case StoreResult.StoreVersionMismatch:
                case StoreResult.MissingParametersForStoredProcedure:
                default:
                    return StoreOperationErrorHandler.OnCommonErrorLocal(
                        result,
                        location,
                        operationName,
                        storedProcName);
            }
        }
开发者ID:xdansmith,项目名称:elastic-db-tools,代码行数:41,代码来源:StoreOperationErrorHandler.cs


示例19: OnValidationErrorLocal

        /// <summary>
        /// Returns the proper ShardManagementException corresponding to given error code in 
        /// <paramref name="result"/> for ShardMap operations.
        /// </summary>
        /// <param name="result">Operation result object.</param>
        /// <param name="shardMap">Shard map object.</param>
        /// <param name="location">Location of LSM operation.</param>
        /// <param name="operationName">Operation being performed.</param>
        /// <param name="storedProcName">Stored procedure being executed.</param>
        /// <returns>ShardManagementException to be raised.</returns>
        internal static ShardManagementException OnValidationErrorLocal(
            IStoreResults result,
            IStoreShardMap shardMap,
            ShardLocation location,
            string operationName,
            string storedProcName)
        {
            switch (result.Result)
            {
                case StoreResult.ShardMapDoesNotExist:
                    return new ShardManagementException(
                        ShardManagementErrorCategory.Validation,
                        ShardManagementErrorCode.ShardMapDoesNotExist,
                        Errors._Store_Validate_ShardMapDoesNotExist,
                        shardMap.Name,
                        location,
                        operationName,
                        storedProcName);

                case StoreResult.ShardDoesNotExist:
                    return new ShardManagementException(
                        ShardManagementErrorCategory.Validation,
                        ShardManagementErrorCode.ShardDoesNotExist,
                        Errors._Store_Validate_ShardDoesNotExist,
                        location,
                        shardMap.Name,
                        operationName,
                        storedProcName);

                case StoreResult.ShardVersionMismatch:
                    return new ShardManagementException(
                        ShardManagementErrorCategory.Validation,
                        ShardManagementErrorCode.ShardVersionMismatch,
                        Errors._Store_Validate_ShardVersionMismatch,
                        location,
                        shardMap.Name,
                        operationName,
                        storedProcName);

                case StoreResult.MappingDoesNotExist:
                    return new ShardManagementException(
                        ShardManagementErrorCategory.Validation,
                        ShardManagementErrorCode.MappingDoesNotExist,
                        Errors._Store_Validate_MappingDoesNotExist,
                        location,
                        shardMap.Name,
                        operationName,
                        storedProcName);

                case StoreResult.MappingIsOffline:
                    return new ShardManagementException(
                        ShardManagementErrorCategory.Validation,
                        ShardManagementErrorCode.MappingIsOffline,
                        Errors._Store_Validate_MappingIsOffline,
                        location,
                        shardMap.Name,
                        operationName,
                        storedProcName);

                case StoreResult.StoreVersionMismatch:
                case StoreResult.MissingParametersForStoredProcedure:
                default:
                    return StoreOperationErrorHandler.OnCommonErrorLocal(
                        result,
                        location,
                        operationName,
                        storedProcName);
            }
        }
开发者ID:xdansmith,项目名称:elastic-db-tools,代码行数:79,代码来源:StoreOperationErrorHandler.cs


示例20: CreateUpgradeStoreLocalOperation

 /// <summary>
 /// Constructs a request to upgrade store location.
 /// </summary>
 /// <param name="shardMapManager">Shard map manager object.</param>
 /// <param name="location">Location to upgrade.</param>
 /// <param name="operationName">Operation name, useful for diagnostics.</param>
 /// <param name="targetVersion">Target version of store to deploy.</param>
 /// <returns>The store operation.</returns>
 public virtual IStoreOperationLocal CreateUpgradeStoreLocalOperation(
     ShardMapManager shardMapManager,
     ShardLocation location,
     string operationName,
     Version targetVersion)
 {
     return new UpgradeStoreLocalOperation(
         shardMapManager,
         location,
         operationName,
         targetVersion);
 }
开发者ID:xdansmith,项目名称:elastic-db-tools,代码行数:20,代码来源:StoreOperationFactory.cs



注:本文中的ShardLocation类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C# ShardMapManager类代码示例发布时间:2022-05-24
下一篇:
C# ShapeType类代码示例发布时间:2022-05-24
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap