-
Notifications
You must be signed in to change notification settings - Fork 199
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Deploy very slow using NodeJs #229
Comments
This issue is idle because it has been open for 14 days with no activity. |
Triaged and added to backlog. |
I was also running into this. Deployments were taking more than 30 mins to complete. The reason is that Kudu takes the ZIP it receives, then extracts it, and copies all files into
Luckily there's a setting that allows you to start the app directly from the ZIP package rather than all this unzipping and copying:
After changing this setting, it took less than a minute for my app to be deployed!! 🚀 https://docs.microsoft.com/en-us/azure/app-service/deploy-run-package#enable-running-from-package |
@dennisameling You should mention that |
I am new to Azure web apps, and when I push to GitHub it takes 30 minutes for the 'workflow' to complete. The workflow file was created automatically by Azure when creating the Web App a few weeks ago. I updated the actions to use
Below is the contents of my workflow file:
The only remaining warning is this one:
|
@kw214 is it still happening? Are you using workflow file similar to https://github.com/Azure/actions-workflow-samples/blob/master/AppService/node.js-webapp-on-azure.yml? |
@oshihirii could you try using https://github.com/Azure/actions-workflow-samples/blob/master/AppService/node.js-webapp-on-azure.yml as a reference for your workflow file and see if it works? Also see if setting the appsetting WEBSITE_RUN_FROM_PACKAGE="1" helps. |
Would be great if this could be fixed, I have a few apps I gave up on Azure with over the years as they all build on netlify in < 1 minute. Just this evening revisited to see if improved and it isn't yet. |
I am new to workflow files, so am nervous to try the file you suggested because it is so different to my existing file (pasted in my comment above). Also, there was a question above about whether WEBSITE_RUN_FROM_PACKAGE="1" works in a Linux environment or not. My environment is the test Linux one. |
@oshihirii WEBSITE_RUN_FROM_PACKAGE="1" should work for Linux environment as well. Let me know if it doesn't work. |
in upload artifacts include only build directory
|
@hharb3 can you please add an explanation of what the code you posted will achieve and how/why? |
Using the file you suggested as a foundation: I modified it so that it had some values that were in my original file. (My original file was automatically generated by Azure and added into my GitHub repo). The modified code I used is at the end of this post for reference. I also followed your suggestion to enable:
To do that, I had to download and install Azure CLI on my Windows machine and run the following in
As a result of these changes, the build and deploy time has been reduced from over 30 minutes to 1 minute 4 seconds. For reference, my new workflow file code is below. I've added comments to distinguish changes I made between my original and the suggested file. name: Deploy Node.js to Azure Web App
# this was '[push]' in the suggested file
on:
push:
branches:
- main
# CONFIGURATION
# For help, go to https://github.com/Azure/Actions
#
# 1. Set up the following secrets in your repository:
# AZURE_WEBAPP_PUBLISH_PROFILE
#
# 2. Change these variables for your configuration:
env:
AZURE_WEBAPP_NAME: <my-app-name> # set this to your application's name
AZURE_WEBAPP_PACKAGE_PATH: '.' # set this to the path to your web app project, defaults to the repository root
NODE_VERSION: '18.x' # set this to the node version to use
jobs:
build-and-deploy:
name: Build and Deploy
runs-on: ubuntu-latest
environment: production # this was 'dev' in the suggested file
steps:
- uses: actions/checkout@v3 # this was '@master' in the suggested file
- name: Use Node.js ${{ env.NODE_VERSION }} # this was 'Set up Node.js version' in my original file
uses: actions/setup-node@v3 # this was 'v1' in the suggested file
with:
node-version: ${{ env.NODE_VERSION }}
- name: npm install, build, and test
# this section was different in my original file
run: |
# Build and test the project, then
# deploy to Azure Web App.
npm prune --production
npm install
npm run build --if-present
# npm run test --if-present
- name: 'Deploy to Azure WebApp'
uses: azure/webapps-deploy@v2
with:
app-name: ${{ env.AZURE_WEBAPP_NAME }}
slot-name: 'Production' # <-- this property wasn't in suggested file
# publish-profile: ${{ secrets.AZURE_WEBAPP_PUBLISH_PROFILE }} <--- in suggested file
publish-profile: ${{ secrets.AZUREAPPSERVICE_PUBLISHPROFILE_**** }} # taken from original file
package: ${{ env.AZURE_WEBAPP_PACKAGE_PATH }}
# For more information on GitHub Actions for Azure, refer to https://github.com/Azure/Actions
# For more samples to get started with GitHub Action workflows to deploy to Azure, refer to https://github.com/Azure/actions-workflow-samples Caveat/Disclaimer: Because I am not familiar with how these workflow files actually work, I'm not sure if it caused any undesired consequences that I am not aware of. |
@oshihirii Great to see that you were able to improve the deployment time. If there is no further issue I will go ahead and close this one. |
Just wanted to confirm here that I've been using this on Linux for a few months and it works just fine 👍🏼
@shpraka before closing this issue, could we at least add something about this to the README of this Action? The default experience is absolutely tedious as it takes 30+ mins to deploy something without this setting. Thanks! https://docs.microsoft.com/en-us/azure/app-service/deploy-run-package#enable-running-from-package |
Can I also suggest that the default yaml file that is created by Azure for node web applications is updated to include:
|
@dennisameling @oshihirii thanks for your feedback. We will update the readme on the repo. We have also noted the feedback on yaml for Azure and will work on it. |
Updated the readme as part #287 |
Thanks @shpraka! Appreciate it! |
Zip deploy with |
@sven5 it does work with both Debian and Ubuntu machines (16.04, Bullseye 11.0) |
@dennisameling You should never, ever, deploy your node modules folder to production. Any given package can open up a security vulnerability even if you are not using that function in your code. Use a build solution like Webpack or similar. |
@sgollapudi77 as @StephanBis said the "Deploy to Azure Web App" step takes a significant amount of time. For most of our projects this step still takes over 15 minutes to complete. Some help for this step would be greatly appreciated. |
I dont understand how this can not get solved properly. If you anyone in the team would create a project with a few packages and create an azure app with deploy through github actions, the deploy-step in the default yaml-workflow would take significant time, due to how it is set up. Either microsoft/github thinks this is fine, or they dont understand the problem, its been 100s of comments over years. Using any other service is at least 10x faster. |
@sgollapudi77 Can we get an update on this thread? It is still very much an issue, deploy to azure web app taking an insane amount of time. We have tried using run from webpackage = 1 but that appears to set wwwroot into a read-only state, and thus makes our app unreadable from the zip. So then falling back to the original method of unzipping / deploying the artifact takes 1h 48m, using azure/webapps-deploy@v3. |
The amount of money Microsoft is missing out on because of this issue must be absolutely incredible. I have avoided deploying to Azure many times over the last few years because for some unexplained reason, Microsoft engineers and project managers can't figure out how to make deploying to Azure actually functional while dozens of other companies can do it just fine. |
Because DotNet?Sent from my iPhoneOn Mar 13, 2024, at 2:51 PM, amsimon ***@***.***> wrote:
@sgollapudi77
The amount of money Microsoft is missing out on because of this issue must be absolutely incredible.
I have avoided deploying to Azure many times over the last few years because for some unexplained reason, Microsoft engineers and project managers can't figure out how to make deploying to Azure actually functional while dozens of other companies can do it just fine.
—Reply to this email directly, view it on GitHub, or unsubscribe.You are receiving this because you were mentioned.Message ID: ***@***.***>
|
Hello, if someone have troubles like I had there is a way without using zip and unzip
This way took only 10 minutes, 5 minutes to build and other 5 to deploy. Also you have to add startup command in your configuration: |
The real problem for me is that we send node modules up. I’d like to deploy the app and then npm update on the server.The issue is the app host resets the container because a ports not listening in certain amount of time that can’t be tweaked to any significant number.Sent from my iPhoneOn Mar 13, 2024, at 3:07 PM, Yerden Bulanbayev ***@***.***> wrote:
Hello, if someone have troubles like I had there is a way without using zip and unzip
name: Build and deploy Node.js app to Azure Web App
env:
AZURE_WEBAPP_PACKAGE_PATH: './build'
on:
push:
branches:
- main
workflow_dispatch:
jobs:
build-and-deploy:
runs-on: ubuntu-latest
steps:
- uses: ***@***.***
- name: Set up Node.js version
uses: ***@***.***
with:
node-version: '18.x'
- name: npm install, build, and test
run: |
npm install
npm run build --if-present
npm run test --if-present
- name: 'Deploy to Azure Web App'
id: deploy-to-webapp
uses: ***@***.***
with:
app-name: 'app-name'
slot-name: 'Production'
publish-profile: ${{ secrets.AZUREAPPSERVICE_PUBLISHPROFILE_YOUR_SECRET }}
package: ${{ env.AZURE_WEBAPP_PACKAGE_PATH }}
This way took only 10 minutes, 5 minutes to build and other 5 to deploy.
Also you have to add startup command in your configuration:
pm2 serve /home/site/wwwroot/ --no-daemon --spa
image.png (view on web)
—Reply to this email directly, view it on GitHub, or unsubscribe.You are receiving this because you were mentioned.Message ID: ***@***.***>
|
Shouldn't your startup command be |
@amsimon |
The alternative for me was to use docker for deployment. name: Deploy To Azure
#on:
# push:
# tags:
# - 'v*'
env:
NODE_VERSION: '14.x'
jobs:
build-and-deploy:
name: Build and Deploy
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
with:
token: ${{ secrets.GH_TOKEN }}
submodules: true
- name: Use Node.js ${{ env.NODE_VERSION }}
uses: actions/setup-node@v1
with:
node-version: ${{ env.NODE_VERSION }}
- uses: pnpm/[email protected]
name: Install pnpm
with:
version: 7
run_install: false
- name: Docker login
uses: azure/docker-login@v1
with:
login-server: xxx.azurecr.io
username: ${{ secrets.AZURE_REGISTRY_USERNAME }}
password: ${{ secrets.AZURE_REGISTRY_PASSWORD }}
- name: Docker build
run: |
docker build . -t xxx.azurecr.io/imagename:${{ github.sha }}
docker push xxx.azurecr.io/imagename:${{ github.sha }}
- name: Deploy to Azure WebApp
uses: azure/webapps-deploy@v2
with:
app-name: ${{ secrets.AZURE_WEBAPP_NAME }}
publish-profile: ${{ secrets.AZURE_WEBAPP_PUBLISH_PROFILE }}
images: 'xxx.azurecr.io/imagename:${{ github.sha }}' |
I apologize for all the inconvenience due to this issue. We will start working on resolving this issue on priority. Thanks! |
When you do SSR on your app using NextJs or Remix frameworks you have to deploy with node_modules which is a pain right now with Azure deployment. |
We can't use WEBSITE_RUN_FROM_PACKAGE="1" because it makes the whole wwwroot/deploy folder readonly, with NextJs persistent cache it is impossible to clear the cache with this setting. Microsoft folks please rewrite Kudo Sync tool that's terribly slow right now, pls. |
Zipping the package and un-zipping it definitely is a step in the right direction but the real issue as someone mentioned before is that Kuru unzips everything in one place and then copies it over to the right path. Relevant line from the logs: Kudu sync from: '/tmp/zipdeploy/extracted' to: '/home/site/wwwroot' Since node modules can have tens of thousands of file, this takes A LOT of time. The WEBSITE_RUN_FROM_PACKAGE="1" is just not a solution. If you are running a node.js backend app, this is a really big problem. |
To anyone coming to this package here are a couple of pointers that will definitely improve you build speeds:
In my case, I'm deploying a node.js express-based app that serves static content (a react app) as well as act as an API server for the SPA. Doing the above steps cut down my build time from ~30 mins to about ~1 min. |
@ShilpiRachna1 What is the progress on this issue? Deploys are at 50 minutes long for a simple Node app right now which is completely unacceptable. |
Same issue here, mora than 20 min to deploy a Hello Word nextJS app. |
Waiting for some solution, for now only possible one is to move to container mode OR to clean node_modules manually
|
Hi everyone using Next.js, I was struggling with this same issue deploying my Next.js application to an azure app service. I managed to drastically reduce the deploy time to 1m 4s. SolutionI am now using the standalone feature from Next.js and only copy the required files to my artifact. I set a custom start command to use pm2 to start my app with the server.js file inside the standalone folder. next.config.js/** @type {import("next").NextConfig} */
const config = {
output: "standalone",
};
export default config; Workflow filename: Build and deploy to Production
on:
push:
branches:
- main
workflow_dispatch:
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Node.js version
uses: actions/setup-node@v3
with:
node-version: '20.x'
- name: npm install, build, and test
run: |
npm install
npm run build --if-present
npm run test --if-present
- name: Zip artifact for deployment
run: |
mkdir -p release
cp next.config.js release
cp -r public release
cp package.json release
cp -r .next/standalone release
cp -r .next/static release
zip -r release.zip release
- name: Upload artifact for deployment job
uses: actions/upload-artifact@v4
with:
name: node-app
path: release.zip
deploy:
runs-on: ubuntu-latest
needs: build
environment:
name: 'Production'
url: ${{ steps.deploy-to-webapp.outputs.webapp-url }}
permissions:
id-token: write #This is required for requesting the JWT
steps:
- name: Download artifact from build job
uses: actions/download-artifact@v4
with:
name: node-app
- name: Unzip artifact for deployment
run: unzip release.zip
- name: Login to Azure
uses: azure/login@v2
with:
client-id: ${{ secrets.AZUREAPPSERVICE_CLIENTID}}
tenant-id: ${{ secrets.AZUREAPPSERVICE_TENANTID }}
subscription-id: ${{ secrets.AZUREAPPSERVICE_SUBSCRIPTIONID}}
- name: 'Deploy to Azure Web App'
id: deploy-to-webapp
uses: azure/webapps-deploy@v3
with:
app-name: 'app'
slot-name: 'Production'
startup-command: 'pm2 start release/standalone/server.js --no-daemon'
package: . |
Is there any update? Unfortunately WEBSITE_RUN_FROM_PACKAGE="1" is not an option for us. |
Update: We are working on replacing kudusync with parallel rsync. It would take some more time for us to test and deploy this change. Tentative ETA: End of January. dhapdhap123 - working to combine build and deploy steps as well. |
FYI - Standalone can be used only for static sites, if you do SSR it won't work out. |
@PauloRodrigues33 Did this improve the deployment time? And if so by how much? |
this really sucks. spent 2 days, still no joy. takes hours and then you get the module not found error even after a successful deployment. have followed all instructions. at Module._extensions..js (node:internal/modules/cjs/loader:1422:10) Frustrated, i deleted the linux webapp and setup a windows plan. That worked with the zip method. but then, i ran into the issue that there is no default setup for IIS and you end up with this error: You do not have permission to view this directory or page. when you access the app. SURELY this should be easier than it is here? |
@ShilpiRachna1 Its Jan mid, are you guys on track for Jan end release as shared before? Please share an update on this, just a file sync logic on app service deployment task taking more than 20 mins is not acceptable and not expected this from Microsoft. Just wondering how this is getting passed from basic testing with hello world node SSR projects like NextJs or Remix etc. |
14 minutes to build, 25 minutes to deploy and it's not over.
The text was updated successfully, but these errors were encountered: