當前位置: 首頁>>代碼示例>>C#>>正文


C# ConnectionMultiplexer.LogLocked方法代碼示例

本文整理匯總了C#中StackExchange.Redis.ConnectionMultiplexer.LogLocked方法的典型用法代碼示例。如果您正苦於以下問題:C# ConnectionMultiplexer.LogLocked方法的具體用法?C# ConnectionMultiplexer.LogLocked怎麽用?C# ConnectionMultiplexer.LogLocked使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在StackExchange.Redis.ConnectionMultiplexer的用法示例。


在下文中一共展示了ConnectionMultiplexer.LogLocked方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: ResolveEndPointsAsync

#pragma warning disable 1998 // NET40 is sync, not async, currently
        internal async Task ResolveEndPointsAsync(ConnectionMultiplexer multiplexer, TextWriter log)
        {
            Dictionary<string, IPAddress> cache = new Dictionary<string, IPAddress>(StringComparer.OrdinalIgnoreCase);
            for (int i = 0; i < endpoints.Count; i++)
            {
                var dns = endpoints[i] as DnsEndPoint;
                if (dns != null)
                {
                    try
                    {
                        IPAddress ip;
                        if (dns.Host == ".")
                        {
                            endpoints[i] = new IPEndPoint(IPAddress.Loopback, dns.Port);
                        }
                        else if (cache.TryGetValue(dns.Host, out ip))
                        { // use cache
                            endpoints[i] = new IPEndPoint(ip, dns.Port);
                        }
                        else
                        {
                            multiplexer.LogLocked(log, "Using DNS to resolve '{0}'...", dns.Host);
#if NET40
                            var ips = Dns.GetHostAddresses(dns.Host);
#else
                            var ips = await Dns.GetHostAddressesAsync(dns.Host).ObserveErrors().ForAwait();
#endif
                            if (ips.Length == 1)
                            {
                                ip = ips[0];
                                multiplexer.LogLocked(log, "'{0}' => {1}", dns.Host, ip);
                                cache[dns.Host] = ip;
                                endpoints[i] = new IPEndPoint(ip, dns.Port);
                            }
                        }
                    }
                    catch (Exception ex)
                    {
                        multiplexer.OnInternalError(ex);
                        multiplexer.LogLocked(log, ex.Message);
                    }
                }
            }
        }
開發者ID:ltines,項目名稱:StackExchange.Redis,代碼行數:45,代碼來源:ConfigurationOptions.cs

示例2: BeginConnect

        internal SocketToken BeginConnect(EndPoint endpoint, ISocketCallback callback, ConnectionMultiplexer multiplexer, TextWriter log)
        {
            var socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
            SetFastLoopbackOption(socket);
            socket.NoDelay = true;
            try
            {
                CompletionType connectCompletionType = CompletionType.Any;
                this.ShouldForceConnectCompletionType(ref connectCompletionType);

                var formattedEndpoint = Format.ToString(endpoint);
                if (endpoint is DnsEndPoint)
                {
                    // A work-around for a Mono bug in BeginConnect(EndPoint endpoint, AsyncCallback callback, object state)
                    DnsEndPoint dnsEndpoint = (DnsEndPoint)endpoint;
                    CompletionTypeHelper.RunWithCompletionType(
                        (cb) =>
                        {
                            multiplexer.LogLocked(log, "BeginConnect: {0}", formattedEndpoint);
                            return socket.BeginConnect(dnsEndpoint.Host, dnsEndpoint.Port, cb, Tuple.Create(socket, callback));
                        },
                        (ar) =>
                        {
                            multiplexer.LogLocked(log, "EndConnect: {0}", formattedEndpoint);
                            EndConnectImpl(ar, multiplexer, log);
                            multiplexer.LogLocked(log, "Connect complete: {0}", formattedEndpoint);
                        },
                        connectCompletionType);
                }
                else
                {
                    CompletionTypeHelper.RunWithCompletionType(
                        (cb) => {
                            multiplexer.LogLocked(log, "BeginConnect: {0}", formattedEndpoint);
                            return socket.BeginConnect(endpoint, cb, Tuple.Create(socket, callback));
                        },
                        (ar) => {
                            multiplexer.LogLocked(log, "EndConnect: {0}", formattedEndpoint);
                            EndConnectImpl(ar, multiplexer, log);
                            multiplexer.LogLocked(log, "Connect complete: {0}", formattedEndpoint);
                        },
                        connectCompletionType);
                }
            } 
            catch (NotImplementedException ex)
            {
                if (!(endpoint is IPEndPoint))
                {
                    throw new InvalidOperationException("BeginConnect failed with NotImplementedException; consider using IP endpoints, or enable ResolveDns in the configuration", ex);
                }
                throw;
            }
            var token = new SocketToken(socket);
            return token;
        }
開發者ID:liweisx,項目名稱:StackExchange.Redis,代碼行數:55,代碼來源:SocketManager.cs

示例3: EndConnectImpl

 private void EndConnectImpl(IAsyncResult ar, ConnectionMultiplexer multiplexer, TextWriter log)
 {
     Tuple<Socket, ISocketCallback> tuple = null;
     try
     {
         tuple = (Tuple<Socket, ISocketCallback>)ar.AsyncState;
         bool ignoreConnect = false;
         ShouldIgnoreConnect(tuple.Item2, ref ignoreConnect);
         if (ignoreConnect) return;
         var socket = tuple.Item1;
         var callback = tuple.Item2;
         socket.EndConnect(ar);
         var netStream = new NetworkStream(socket, false);
         var socketMode = callback == null ? SocketMode.Abort : callback.Connected(netStream, log);
         switch (socketMode)
         {
             case SocketMode.Poll:
                 multiplexer.LogLocked(log, "Starting poll");
                 OnAddRead(socket, callback);
                 break;
             case SocketMode.Async:
                 multiplexer.LogLocked(log, "Starting read");
                 try
                 { callback.StartReading(); }
                 catch (Exception ex)
                 {
                     ConnectionMultiplexer.TraceWithoutContext(ex.Message);
                     Shutdown(socket);
                 }
                 break;
             default:
                 ConnectionMultiplexer.TraceWithoutContext("Aborting socket");
                 Shutdown(socket);
                 break;
         }
     }
     catch(ObjectDisposedException)
     {
         multiplexer.LogLocked(log, "(socket shutdown)");
         if (tuple != null)
         {
             try
             { tuple.Item2.Error(); }
             catch (Exception inner)
             {
                 ConnectionMultiplexer.TraceWithoutContext(inner.Message);
             }
         }
     }
     catch(Exception outer)
     {
         ConnectionMultiplexer.TraceWithoutContext(outer.Message);
         if (tuple != null)
         {
             try
             { tuple.Item2.Error(); }
             catch (Exception inner)
             {
                 ConnectionMultiplexer.TraceWithoutContext(inner.Message);
             }
         }
     }
 }
開發者ID:liweisx,項目名稱:StackExchange.Redis,代碼行數:63,代碼來源:SocketManager.cs

示例4: EndConnectImpl

        private void EndConnectImpl(IAsyncResult ar, ConnectionMultiplexer multiplexer, TextWriter log, Tuple<Socket, ISocketCallback> tuple)
        {
            try
            {
                bool ignoreConnect = false;
                ShouldIgnoreConnect(tuple.Item2, ref ignoreConnect);
                if (ignoreConnect) return;
                var socket = tuple.Item1;
                var callback = tuple.Item2;
#if CORE_CLR
                multiplexer.Wait((Task)ar); // make it explode if invalid (note: already complete at this point)
#else
                socket.EndConnect(ar);
#endif
                var netStream = new NetworkStream(socket, false);
                var socketMode = callback?.Connected(netStream, log) ?? SocketMode.Abort;
                switch (socketMode)
                {
                    case SocketMode.Poll:
                        multiplexer.LogLocked(log, "Starting poll");
                        OnAddRead(socket, callback);
                        break;
                    case SocketMode.Async:
                        multiplexer.LogLocked(log, "Starting read");
                        try
                        { callback.StartReading(); }
                        catch (Exception ex)
                        {
                            ConnectionMultiplexer.TraceWithoutContext(ex.Message);
                            Shutdown(socket);
                        }
                        break;
                    default:
                        ConnectionMultiplexer.TraceWithoutContext("Aborting socket");
                        Shutdown(socket);
                        break;
                }
            }
            catch (ObjectDisposedException)
            {
                multiplexer.LogLocked(log, "(socket shutdown)");
                if (tuple != null)
                {
                    try
                    { tuple.Item2.Error(); }
                    catch (Exception inner)
                    {
                        ConnectionMultiplexer.TraceWithoutContext(inner.Message);
                    }
                }
            }
            catch(Exception outer)
            {
                ConnectionMultiplexer.TraceWithoutContext(outer.Message);
                if (tuple != null)
                {
                    try
                    { tuple.Item2.Error(); }
                    catch (Exception inner)
                    {
                        ConnectionMultiplexer.TraceWithoutContext(inner.Message);
                    }
                }
            }
        }
開發者ID:491134648,項目名稱:StackExchange.Redis,代碼行數:65,代碼來源:SocketManager.cs


注:本文中的StackExchange.Redis.ConnectionMultiplexer.LogLocked方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。