Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Overview

Web Jobs is a feature of Azure App Services that run a program or script in the same instance as a web app, API app, or mobile app. There is no additional cost to use Web Jobs.

Aptify Azure Enablement comes with the ability to run the existing schedule tasks entity (configured in Aptify Smart Client) on Azure Portal as a Web Job.The Current WebJobs.

This document provides the information on how to setup new web jobs and configure existing schedule tasks to run as Azure WebJobs. This topic is divided into three parts:

Table of Contents
minLevel3
maxLevel3
style
separator

The current scope of the WebJobs is as follows:

  1. Most of the existing schedule task functionalities are available in Azure Web jobs.

  2. Only Once, Daily, Weekly, Monthly, Monthly Relative types of frequency frequencies are supported.

  3. The Scale of the job will always be “Single Instance” and Type “Continuous” on Azure Portal

Below points are not in the scope of WebJobs:

  1. Run History Tab on Scheduled Task records will not be updated.

  2. Service should always be “Schedule Web Job Only“ on Scheduled Task record to run the task as WebJob.

  3. The checkbox “Delete The functionality of the checkbox “Delete the task if it is not scheduled to run again“ again” is not in scope for now.The Scale of the job will always be “Single Instance“ and Type “Continuous“ on Azure Portal, more is discussed in the document below:

  4. Frequency types Run when computer is idle and Run when service starts is not supported.

Note

Below screen shots are for reference purpose only. Please provide the details specific to your environment. 

Part 1: Code File Config Changes

...

  1. Open the Zipped Folder Containing the code files. <<path and name of the file>>Extract the APTIFY_700_Database zipped file and go to the Core Database Setup->Utility->WebJobManualDeploy folder.

  2. Search for WebJobManualDeploy.exe.config and open the same in Note Pad Notepad or Note Pad Notepad ++.

  3. The Configure the tags “AzureWebJobDashboard“ and “AzureWebJobStorageboth are to be configured with with your Azure tenant Storage Account Connection String.

  4. Under the AppSettings appSettings tag, the value for key=”frequency” ” frequency” will be any one of the following: all, once, daily, weekly, monthly, monthlyRelative. This is for the type of job which is needed to be scheduled on portal. For example, a code with frequency daily will only run the task which are of type daily in database. It is to be noted that this setting is case sensitive.

  5. App Insights has been configured for these web jobs and logs can be found in App Insight log file. But to To enable the app insights, Instrumentation Key is required (Line 25 of the picture below). Refer to Configuring Serilog with Azure Application Insights.

    Image Removed
  6. To get instrumentation key for App Insights, log into Azure portal and select the service Application Insights.

    Image Removed
  7. Select the Application Insights for which you want to configure the logs.

    Image Removed
  8. Under the overview tab you will find the Instrumentation key.

    Image Removed
  9. to know more about App Insight.

  10. The below keys are required by web job to log into the database:

    1. UserDatabase = “Aptify”

    2. EntitiesDatabase = “Aptify“

    3. SqlLogin SQLLogin and Password are the credentials to log into the database.

    4. Server = Managed instance Endpoint (See Point 10-12)

      Image Removed

      Points 6.d.i to 6.d.iii)

      Image Added
      1. To get managed instance endpoint, log

    into
      1. in to the Azure portal and select

    Sql
      1. SQL Managed Instances Service.

        Image Modified
      2. Select the instance to be connected with the

    web jobs
      1. WebJobs.

        Image Modified
      2. Once you select the instance you will find Networking under Security and Endpoint on the right pane of the screen as

    shown
      1. highlighted in below screenshot

    below
      1. .

        Image Modified
  11. Once all the changes are done in config file, save it and close it. Now Select all the code files and zip them, give the zipped file a meaning full name. After this we are done with the code file changesmeaningful name.

Part 2: Creating/Updating Schedule Task Record in Smart Client

...

  1. Open Smart Client, Collapse collapse Process Pipeline Application and Right Click on right click Scheduled Task Service, then click “New New Scheduled Tasks Records“Records

  2. Under the new scheduled task record, there are few mandatory settings which are needed to get this task run by Azure Web JobWebJobs. These are as follows:-

    1. Service: This will always be Alway select option “Schedule Web Job Only

    2. Web Job Enabled: This checkbox must be checked (Once you select service as Schedule Web Job Only , this will be automatically checked)selected.

    3. Is Enabled: This checkbox should must also be checked alsoselected.

...

Info

Note: All other functionalities (Start Date, End Date, Repeat Task etc.) on “New Scheduled Tasks Record” remains the same. Also existing Scheduled

...

Tasks can be modified to run by Azure Web

...

Jobs. To do

...

so,

...

change the

...

service to “Schedule Web Job Only“ and make sure the “Web Job Enabled

...

checkbox is

...

selected.

Part 3: Deploying the zipped code file on Azure Portal

...

  1. Open Microsoft Azure Portal, on the home page, click App Services.

  2. Select the App Service in through which your web job will run.

  3. After selecting App Service, on the newly opened right pane, select “WebJobs“ under “Settings

  4. Under WebJobs, Click on + Signclick + sign to add a new web job. A new pane will open Add WebJob opens on the right part side of the screen under . Under Name, give any meaningful name for the job.

  5. Under File Upload, click upload button and a new window will get openedopens. Now select the zipped file which you have created in Part 1.

  6. Set the Scale to Single Instance.

  7. Click on OK now and wait for some time. After that the job will be visible under the dashboard and it will be OK, it may take few seconds for the job to be visible on the dashboard in Running Status. Now it This will ensure that the scheduled tasks will start executing the scheduled task as per their schedule.

    Image RemovedImage Added