This tutorial describes how to quickly set up jsreport server on Azure Web App through docker and start creating pdf or excel reports in no time.
Note that jsreport runs also on VMs, cloud services or container instances without limitations.
The first you need to open azure portal and hit "Create a Resource" -> "Create Web App". Then fill the mandatory fields and select publish to the "Docker Container".
Continue to the next page and fill deployment from the Single Container and image downloaded from the Docker Hub. The current official jsreport image is jsreport/jsreport:3.0.1
, but always get the latest version number in the dockerhub.
Now you can skip the next steps and directly hit "Review + create" and submit the deployment. When the deployment is ready, go to the resource web app.
Creating application takes usually several minutes so be patient. You should be able to open web application in the browser afterwards.
The easiest way to configure jsreport is to use the environment variables which can be set right in the Application Settings
in the azure portal.
Let's enable jsreport authentication for example by setting the following variables
extensions_authentication_admin_username=admin
extensions_authentication_admin_password=xxx
extensions_authentication_cookieSession_secret=yoursecret
After hitting save, the changes should be propagated in couple of seconds. When reloading the app in the browser, you should see a login screen.
This was just one of the many configuration options you may need. Please find more configuration options in the documentation.
You would soon realize that the stored templates are lost if you restart the app service. This is because the jsreport stores the data by default right in the container. You may rather want to store templates in an external disk or full database. You can find all the availible options including SQL server, Mongo or Azure Storage blobs in the template store documentation, but now we just map azure file share to the web app.
The first you need to create Azure storage account and a File share in it.
Note selecting the "Premium performance" layer improves twice the speed for big imports and templates editing. However, the templates are cached in memory so this doesn't have any effect on the rendering time and the standard storage account should be just fine in the most of the cases.
Then you need to map the file share to the web app.
The azure web app by default doesn't store or show logs from the container where jsreport runs. This is opt-in which you can enable in the App Service logs.
Afterwards you can inspect jsreport logs in the Log stream.