Подтвердить что ты не робот

SignalR - работает при развертывании на сервере, но останавливается через несколько часов (MVC)

РЕДАКТИРОВАТЬ. Просмотрите нижнюю часть этого сообщения для обновлений.

Реализация My SignalR отлично работает на моей локальной системе. Но когда я развернул его на своем сервере, он, похоже, не работает. Проект MVC.

My signalR jQuery выглядит следующим образом:

var clientHub = $.connection.gamehub;

$(function () {

    var signalRHubInitialized = false;

    var image = $("#Ico");

    var count = 0;

    initializeSignalRHubStore();

    function initializeSignalRHubStore() {

        if (signalRHubInitialized)
            return;

        try {

            clientHub.client.broadcastMessage = function (message) {
                if (message === "Refresh")
                    reloadIndexPartial();
            };

            $.connection.hub.start().done(function () {
                clientHub.server.initialize($("#NotifierEntity").val());
                signalRHubInitialized = true;
            });

        } catch (err) {
            signalRHubInitialized = false;
        }
    };

    function reloadIndexPartial() {
        //$.post('@(Url.Action("LivePartial", "Scrim", null, Request.Url.Scheme))')
        var id = $("#SeriesDetail_Id").val();
        $.post('/Scrim/LivePartial/' + id)
            .done(function (response) {
                try {
                    count = count + 1;
                    var favicon = new Favico({
                        animation: 'pop',
                        image: image
                    });
                    favicon.badge(count);
                }
                catch (exception) {

                }
                $("#summary-wrapper").html("");
                $("#summary-wrapper").html(response);
                if (!signalRHubInitialized)
                    initializeSignalRHubStore();
            });
    };
});

Я загрузил Fiddler, чтобы посмотреть, что происходит:

/signalr/hubs возвратили HTTP200

GET http://sitename.com/signalr/hubs HTTP/1.1
Host: sitename.com
Connection: keep-alive
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.113 Safari/537.36
Accept: */*
Referer: http://sitename.com/scrim/Live/2835
Accept-Encoding: gzip, deflate
Accept-Language: en-US,en;q=0.8
Cookie: _gat=1; _ga=GA1.2.1342148401.1475084375; _gid=GA1.2.2092796788.1503865866

переговоры возвращены в HTTP200

GET http://sitename.com/signalr/negotiate?clientProtocol=1.5&connectionData=%5B%7B%22name%22%3A%22gamehub%22%7D%5D&_=1505151041506 HTTP/1.1
Host: sitename.com
Connection: keep-alive
Accept: text/plain, */*; q=0.01
X-Requested-With: XMLHttpRequest
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.113 Safari/537.36
Content-Type: application/json; charset=UTF-8
Referer: http://sitename.com/scrim/Live/2835
Accept-Encoding: gzip, deflate
Accept-Language: en-US,en;q=0.8
Cookie: _gat=1; _ga=GA1.2.1342148401.1475084375; _gid=GA1.2.2092796788.1503865866

connect, did not return anything

GET http://sitename.com/signalr/connect?transport=serverSentEvents&clientProtocol=1.5&connectionToken=S8rqz2NPvVSJxbS1%2FpLm7yHTinGHWK1SnAwh8IfYA%2BP7nVb9RV%2FJzSFsf8Q%2BTv6Z%2Fae%2FIoZKlHKyeTxaEn3obg%2FVViYTB5HZxnrvKvtBZtQopvGPdj1i4o8Z9wGlCz3%2F&connectionData=%5B%7B%22name%22%3A%22gamehub%22%7D%5D&tid=10 HTTP/1.1
Host: sitename.com
Connection: keep-alive
Accept: text/event-stream
Cache-Control: no-cache
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.113 Safari/537.36
Referer: http://sitename.com/scrim/Live/2835
Accept-Encoding: gzip, deflate
Accept-Language: en-US,en;q=0.8
Cookie: _gat=1; _ga=GA1.2.1342148401.1475084375; _gid=GA1.2.2092796788.1503865866

начать возвращать HTTP200

GET http://sitename.com/signalr/start?transport=serverSentEvents&clientProtocol=1.5&connectionToken=S8rqz2NPvVSJxbS1%2FpLm7yHTinGHWK1SnAwh8IfYA%2BP7nVb9RV%2FJzSFsf8Q%2BTv6Z%2Fae%2FIoZKlHKyeTxaEn3obg%2FVViYTB5HZxnrvKvtBZtQopvGPdj1i4o8Z9wGlCz3%2F&connectionData=%5B%7B%22name%22%3A%22gamehub%22%7D%5D&_=1505151041507 HTTP/1.1
Host: sitename.com
Connection: keep-alive
Accept: text/plain, */*; q=0.01
X-Requested-With: XMLHttpRequest
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.113 Safari/537.36
Content-Type: application/json; charset=UTF-8
Referer: http://sitename.com/scrim/Live/2835
Accept-Encoding: gzip, deflate
Accept-Language: en-US,en;q=0.8
Cookie: _gat=1; _ga=GA1.2.1342148401.1475084375; _gid=GA1.2.2092796788.1503865866

Отправить возвращен HTTP200

POST http://sitename.com/signalr/send?transport=serverSentEvents&clientProtocol=1.5&connectionToken=S8rqz2NPvVSJxbS1%2FpLm7yHTinGHWK1SnAwh8IfYA%2BP7nVb9RV%2FJzSFsf8Q%2BTv6Z%2Fae%2FIoZKlHKyeTxaEn3obg%2FVViYTB5HZxnrvKvtBZtQopvGPdj1i4o8Z9wGlCz3%2F&connectionData=%5B%7B%22name%22%3A%22gamehub%22%7D%5D HTTP/1.1
Host: sitename.com
Connection: keep-alive
Content-Length: 2227
Accept: text/plain, */*; q=0.01
Origin: http://sitename.com
X-Requested-With: XMLHttpRequest
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.113 Safari/537.36
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
Referer: http://sitename.com/scrim/Live/2835
Accept-Encoding: gzip, deflate
Accept-Language: en-US,en;q=0.8
Cookie: _gat=1; _ga=GA1.2.1342148401.1475084375; _gid=GA1.2.2092796788.1503865866

data=%7B%22H%22%3A%22gamehub%22%2C%22M%22%3A%22Initialize%22%2C%22A%22%3A%5B%22%7B%5C%22SqlQuery%5C%22%3A%5C%22SELECT+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BId%5D+AS+%5BId%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BGameGuid%5D+AS+%5BGameGuid%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BDate%5D+AS+%5BDate%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BTeamOneScore%5D+AS+%5BTeamOneScore%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BTeamZeroScore%5D+AS+%5BTeamZeroScore%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BTeamOneId%5D+AS+%5BTeamOneId%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BTeamZeroId%5D+AS+%5BTeamZeroId%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BGameVariantId%5D+AS+%5BGameVariantId%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BMapId%5D+AS+%5BMapId%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BDuration%5D+AS+%5BDuration%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BSeriesId%5D+AS+%5BSeriesId%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BResult%5D+AS+%5BResult%5D%2C+%5C%5Cr%5C%5Cn++++%5BExtent1%5D.%5BActive%5D+AS+%5BActive%5D%5C%5Cr%5C%5Cn++++FROM+%5Bdbo%5D.%5BGame%5D+AS+%5BExtent1%5D%5C%5Cr%5C%5Cn++++WHERE+(%5BExtent1%5D.%5BActive%5D+%3D+1)+AND+(%5BExtent1%5D.%5BSeriesId%5D+%3D+%40p__linq__0)%5C%22%2C%5C%22SqlConnectionString%5C%22%3A%5C%22Data+Source%3DWIN-1J1JAEOEU33%3BInitial+Catalog%3DSiteName%3BIntegrated+Security%3DTrue%3BMultipleActiveResultSets%3DTrue%3B%5C%22%2C%5C%22SqlParameters%5C%22%3A%5B%7B%5C%22CompareInfo%5C%22%3A0%2C%5C%22XmlSchemaCollectionDatabase%5C%22%3A%5C%22%5C%22%2C%5C%22XmlSchemaCollectionOwningSchema%5C%22%3A%5C%22%5C%22%2C%5C%22XmlSchemaCollectionName%5C%22%3A%5C%22%5C%22%2C%5C%22DbType%5C%22%3A11%2C%5C%22LocaleId%5C%22%3A0%2C%5C%22ParameterName%5C%22%3A%5C%22p__linq__0%5C%22%2C%5C%22Precision%5C%22%3A0%2C%5C%22Scale%5C%22%3A0%2C%5C%22SqlDbType%5C%22%3A8%2C%5C%22SqlValue%5C%22%3A%7B%5C%22IsNull%5C%22%3Afalse%2C%5C%22Value%5C%22%3A2835%7D%2C%5C%22UdtTypeName%5C%22%3A%5C%22%5C%22%2C%5C%22TypeName%5C%22%3A%5C%22%5C%22%2C%5C%22Value%5C%22%3A2835%2C%5C%22Direction%5C%22%3A1%2C%5C%22IsNullable%5C%22%3Afalse%2C%5C%22Offset%5C%22%3A0%2C%5C%22Size%5C%22%3A0%2C%5C%22SourceColumn%5C%22%3A%5C%22%5C%22%2C%5C%22SourceColumnNullMapping%5C%22%3Afalse%2C%5C%22SourceVersion%5C%22%3A512%7D%5D%7D%22%5D%2C%22I%22%3A0%7D

Я добавил это в свою веб-конфигурацию:

<modules runAllManagedModulesForAllRequests="true"></modules>

Просматривая все ответы, кажется, что все работает правильно, но страница Im on не обновляется при добавлении новой записи в базу данных.

В моей локальной системе разработки мой проект настроен с использованием IIS, он работает безупречно.

Может ли кто-нибудь указать мне в правильном направлении, пожалуйста.

EDIT: теперь у меня это работает на сервере. Но похоже, что он работает сразу после его развертывания в течение нескольких часов. Затем после этого он перестает работать. Поэтому я должен предположить, что соединение signalr находится на каком-то этапе и теперь восстанавливается?

Вот мой класс RegisterServices:

private static IContainer RegisterServices(ContainerBuilder builder)
{
    builder.RegisterControllers(Assembly.GetExecutingAssembly());

    builder.RegisterApiControllers(Assembly.GetExecutingAssembly());

    builder.RegisterType<ContextEntities>()
           .As<DbContext>()
           .InstancePerRequest();

    builder.RegisterType<DbFactory>()
        .As<IDbFactory>()
        .InstancePerRequest();

    builder.RegisterType<UnitOfWork>()
        .As<IUnitOfWork>()
        .InstancePerRequest();

    // Services

    builder.RegisterType<MembershipService>()
    .As<IMembershipService>()
    .InstancePerRequest();

    builder.RegisterType<CacheService>()
    .As<ICacheService>()
    .InstancePerRequest();

    builder.RegisterType<GameHub>().ExternallyOwned();

    Container = builder.Build();

    return Container;
}

Вот страница, где используется signalr: http://halodatahive.com/Scrim/Live/2845

Кажется, я теряю ссылку на соединение signalr через несколько часов после развертывания.

EDIT: если я перерабатываю свой APP POOL, страница с сигналом начинает снова работать.

4b9b3361

Ответ 1

Вот что я использовал для решения проблемы. Кажется, что примерно через 1 час он каким-то образом отключился. Я положил этот код за несколько часов назад, и он все еще работает. Спасибо @Noren за их помощь в чате раньше!

EDIT: Это, похоже, не помогло решить проблему.

$.connection.hub.disconnected(function() {
    setTimeout(function() {
      $.connection.hub.start();
    }, 5000); // Restart connection after 5 seconds.
});

EDIT: Думаю, я дам обновленную информацию о том, как я получил эту работу. Вместо использования SqlDependency для запуска SignalR, который я только что назвал Clients.All.broadcastMessage("Refresh"); в запланированной задаче, я работал на сервере при вызове _unitOfWork.Commit().

Что-то заставило SqlDependency перестать работать, и единственный способ заставить его забрать его снова - это переработать пул приложений.

Ответ 2

Я видел что-то подобное раньше. В моем случае это были события RabbitMQ, которые были потеряны, потому что IIS откручивал приложение.

Является ли ваше приложение не очень часто попадающим? У IIS есть тенденция отжимать приложения, которые он не считает необходимыми, чтобы экономить ресурсы. Возможно, поэтому он перестает работать через несколько часов, и вы можете перерабатывать его, чтобы вернуть его.

См. этот ответ.

Ответ 3

сначала добавьте папку Hubs и NotificationsHubs.cs в корневом каталоге

Hubs

в NotificationsHubs.cs

[HubName("NotificationsHubs")]
public class NotificationsHubs : Hub
{

    public static Thread NotificationsThread;
    public void Send(string token, string UserAgent, string IP)
    {
        var serverVars = Context.Request.GetHttpContext().Request.ServerVariables;
        string SignalRIp = serverVars["REMOTE_ADDR"];

        string T = Context.Request.Headers["User-Agent"].ToLower();
        if ((T == cryptClass.crypt.Decrypt(UserAgent))  && (SignalRIp == cryptClass.crypt.Decrypt(IP)))
        {
            var connection = SignalRConnections.Connections.SingleOrDefault(c => c.Token == Guid.Parse(token));
            if (connection != null)
            {
                connection.Context = this.Context;
            }

            if (NotificationsThread == null || !NotificationsThread.IsAlive)
            {
               NotificationsThread = new Thread(new ThreadStart(NotificationsCheck));
                NotificationsThread.Start();
            }
        }

NotificationsCheck - это пользовательская функция


в NotificationController

public ActionResult Notifications()
{
    NotificationsModule.messageBL = _messageBL;
    long UserID = GetCurrentUser();
    Notification _Notification = new Notification();
    _Notification.GetToken = SignalRConnections.GetToken(UserID);
    _Notification.UserAgent = cryptClass.crypt.Encrypt(Request.UserAgent.ToLower());
    _Notification.IP = cryptClass.crypt.Encrypt(Request.UserHostAddress);
    return View(_Notification);
}

in Notifications.cshtml view

добавить этот JS файл

    <script src="~/Scripts/jquery.signalR-2.2.1.js")"></script>
    <script src="~/signalr/hubs"></script>

$(function () {

    // Reference the auto-generated proxy for the hub.
    var chat = $.connection.NotificationsHubs;
    // Create a function that the hub can call back to display messages.
    chat.client.addNewMessageToPage = function (Title, Body, Icon) {
        // Add the message to the page.
        notifyMe(Title, Body, Icon);
    };

    $.connection.hub.start().done(function () {
        chat.server.send('@Model.GetToken', '@Model.UserAgent', '@Model.IP');
        $('#sendmessage').click(function () {
            // Call the Send method on the hub.
            chat.server.send();
        });
    });
});

notifyMe(Title, Body, Icon); - пользовательская функция jquery