问题
I've deployed a simple react app to azure app service and it won't start:
How do I get the app to run index.html?
回答1:
If you deployed to a Node Linux Web App the default document would be hostingstart.html
located in /home/site/wwwroot/
.
According to this:
When you create a Node.js app, by default, it's going to use hostingstart.html as the default document unless you configure it to look for a different file. You can use a JavaScript file to configure your default document. Create a file called index.js in the root folder of your site
So go to your ssh terminal, navigate to /home/site/wwwroot
. Create index.js there with the following code:
var express = require('express');
var server = express();
var options = {
index: 'index.html'
};
server.use('/', express.static('/home/site/wwwroot', options));
server.listen(process.env.PORT);
NOTE: Be sure to run npm install --save express also in this folder else your app service will crash on startup
Restart, it will configure index.html as the default document for your app.
回答2:
You don't need to install express and configure index.js as mentioned in other answers since that needs config change and not sure whether app scaling event will retain those installations in new instance.
Easy way is to use pm2 since that is already part of stack. Pass the below startup command for the app
pm2 serve /home/site/wwwroot --no-daemon
Once we restart, it should pick the pages from the docroot (/home/site/wwwroot)
回答3:
add this command in your azure dashboard > Configuration > Startup Command
pm2 serve /home/site/wwwroot --no-daemon
and restart your server. This fixed it for me!
回答4:
So thanks to Burke Holland. The easiest is to create a build folder running
npm run build
Then you copy your build folder into your destination and add a "ecosystem.config.js" file.
module.exports = {
apps: [
{
script: "npx serve -s"
}
]
};
See this link for more information: https://burkeknowswords.com/this-is-how-to-easily-deploy-a-static-site-to-azure-96c77f0301ff
Note: This works for a deployment to a Node Linux App Service instance in Azure. No client side routing configuration needed with this approach!
For Windows App service you can create a config file for configuring your client side routing.
来源:https://stackoverflow.com/questions/56624277/react-app-not-starting-in-azure-app-service