11

我有一个与网站关联的连续网络作业,并且我在共享模式下运行该网站。我不想使用 Always On 选项,因为我的应用程序并不真正需要。我只想在对我的网站进行调用时处理该消息。

我的问题是,即使我每 5 分钟在我的网站上不断调用一个虚拟的保持活动方法,该方法在几分钟后向该 Web 作业监控的队列发布一条消息,该工作仍然会停止。

我的 webjob 是一个使用 WebJob SDK 构建的简单控制台应用程序,其代码如下

JobHost host = new JobHost(new JobHostConfiguration(storageConnictionSttring));
host.RunAndBlock();

消息处理函数如下所示:

public static void ProcessKeepAliveMessages([QueueTrigger("keepalive")] KeepAliveTrigger message)
{
    Console.WriteLine("Keep Alive message called on :{0}", message.MessageTime);
}

该工作的消息日志基本上说

[03/05/2015 18:51:02 > 4660f6: SYS INFO] WebJob is stopping due to website shutting down

我不介意这种情况是否发生,但是当网站开始下一个保持活动状态的调用时,webjob 没有启动。所有消息都排队,直到我进入管理仪表板或 SCM 门户,如下所示

https://mysite.scm.azurewebsites.net/api/continuouswebjobs

我可以看到这样的状态:

[{"status":"Starting","detailed_status":"4660f6 - Starting\r\n","log_url":"https://mysite.scm.azurewebsites.net/vfs/data/jobs/continuous/WebJobs/job_log.txt","name":"WebJobs","run_command":"mysite.WebJobs.exe","url":"https://mysite.scm.azurewebsites.net/api/continuouswebjobs/WebJobs","extra_info_url":"https://mysite.scm.azurewebsites.net/azurejobs/#/jobs/continuous/WebJobs","type":"continuous","error":null,"using_sdk":true,"settings":{}}]

如果有人可以帮助我了解这里出了什么问题,我将不胜感激。

4

2 回答 2

20

我遇到了类似的问题。我有一个网站(共享模式)和一个关联的网络作业(连续类型)。查看 webjob 日志,我发现作业在大约 15 分钟后进入停止状态。不活动并停止对触发消息做出反应。这似乎与连续工作概念的概念相矛盾,但显然,要使其真正连续运行,您必须订阅付费网站。你得到你所付出的...

也就是说,我的网站大约每隔几天需要使用一次,并且以共享模式运行非常有意义。我不介意该站点需要一些额外的时间才能开始 - 只要它自动重新启动即可。webjob 的问题是一旦停止它就不会自行重启。所以,我的目标是用网站重新启动它。

我注意到,只需查看 Azure 管理门户中的网络作业即可启动它。按照这种思路,我发现获取 webjob 属性足以将其切换到运行状态。唯一的技巧是如何以编程方式获取属性,以便重新启动网站也会重新启动 webjob。

因为获取 webjob 属性的调用必须经过身份验证,所以第一步是转到 Azure 管理门户并下载网站发布配置文件。在发布配置文件中,您可以找到身份验证凭据:用户名(通常为 $<website_name>)和 userPWD(密码哈希)。把它们抄下来。

这是一个函数,它将获取 webjob 属性并将其唤醒(如果尚未运行):

class Program
{
    static void Main(string[] args)
    {
        string websiteName = "<website_name>";
        string webjobName = "<webjob_name>";
        string userName = "<from_publishing_profile>";
        string userPWD = "<from_publishing_profile>";
        string webjobUrl = string.Format("https://{0}.scm.azurewebsites.net/api/continuouswebjobs/{1}", websiteName, webjobName);
        var result = GetWebjobState(webjobUrl, userName, userPWD);
        Console.WriteLine(result);
        Console.ReadKey(true);
    }

    private static JObject GetWebjobState(string webjobUrl, string userName, string userPWD)
    {
        HttpClient client = new HttpClient();
        string auth = "Basic " + Convert.ToBase64String(Encoding.UTF8.GetBytes(userName + ':' + userPWD));
        client.DefaultRequestHeaders.Add("authorization", auth);
        client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
        var data = client.GetStringAsync(webjobUrl).Result;
        var result = JsonConvert.DeserializeObject(data) as JObject;
        return result;
    }
}

您可以使用类似的功能来获取您网站中的所有网络作业(使用端点https://<website_name>.scm.azurewebsites.net/api/webjobs)。您还可以查看返回的 JObject 以验证 webjob 的实际状态和其他属性。

于 2015-03-08T04:19:59.513 回答
14

如果您希望 WebJob 不会停止,您需要确保您的scm站点是活动的。

因此,keep-alive 请求应该转到https://sitename.scm.azurewebsites.net,并且这些请求需要进行身份验证(使用您的部署凭据进行基本身份验证)。

于 2015-03-06T19:12:37.753 回答