Esempio n. 1
0
        static async Task Main(string[] args)
        {
            int minWorker, minIOC;

            // Get the current settings.
            ThreadPool.GetMinThreads(out minWorker, out minIOC);
            // Change the minimum number of worker threads to four, but
            // keep the old setting for minimum asynchronous I/O
            // completion threads.
            if (ThreadPool.SetMinThreads(200, 200))
            {
            }

            //var options = new RedisIdConfigOptions();
            options.SetConfig();
            IDistributedIdService idService = new RedisIdService(options);

            idService = new RedisIdService(options);
            var tableName = "User";

            idService.InitStartId(tableName, 1);
            for (var i = 0; i < 10; i++)
            {
                await Task.Run(() => {
                    GetIds(10000);
                });

                await Task.Run(async() => {
                    await GetIdsAsync(10000);
                });
            }
            Console.ReadKey();
        }
Esempio n. 2
0
        static void GetIds(int count)
        {
            //var options = new RedisIdConfigOptions();
            //options.SetConfig();
            IDistributedIdService idService = new RedisIdService(options);
            var       tableName             = "User";
            Stopwatch watch = new Stopwatch();

            watch.Start();
            for (var i = 0; i < count; i++)
            {
                var id = idService.GetDistributedId(tableName);
                //Console.WriteLine($"第{(i + 1)}个Id:{id}");
                // Console.WriteLine(id);
            }
            watch.Stop();
            Console.WriteLine($"同步获取{count}Id,总用时{watch.ElapsedMilliseconds}毫秒");
        }