


Detailed explanation of the steps to deploy Github projects to the server
Github is currently the largest open source community in the world. Many programmers will host their own code on Github to take advantage of its convenient version control and collaboration functions. However, the project on Github is just code, and deploying it to the server for running requires some extra work. This article will introduce you to the specific steps.
1. Log in to the server
Use SSH to connect remotely and enter the command:
ssh root@your_server_ip
2. Install the necessary software
Install Git and Node.js on the server. Taking the Ubuntu system as an example, execute the following command:
sudo apt-get update sudo apt-get install git sudo apt-get install nodejs
3. Create a Git repository on the server
Create an empty directory on the server and put it in it Initialize a Git repository and execute the following command:
mkdir myapp cd myapp git init --bare
4. Set up Git Hooks
Add a post-receive hook in the Git repository to automatically deploy the application, execute The following command:
cd hooks touch post-receive sudo chmod +x post-receive nano post-receive
Enter the following content in the open text editor:
#!/bin/bash git --work-tree=/var/www/html/myapp --git-dir=/root/myapp.git checkout -f cd /var/www/html/myapp sudo npm install
The script will automatically check out the code to /var/www/html/myapp and execute npm install command to install project dependencies.
5. Configure Webhooks on Github
Log in to Github, click the Webhooks option in the project's Settings page, and then click the Add webhook button. Enter the server's IP address and the path of the post-receive hook in the Payload URL, for example: http://your_server_ip:8000/hooks/post-receive. Select application/json in Content type and click Add webhook.
6. Add the server address in the local code
Modify the package.json file in the local code and add the following content:
{ "scripts": { "start": "node app.js", "deploy": "git push deploy master" }, "config": { "deploy": { "production": { "user": "root", "host": "your_server_ip", "ref": "origin/master", "repo": "ssh://git@your_server_ip:/root/myapp.git", "path": "/var/www/html/myapp", "ssh_options": ["StrictHostKeyChecking=no", "PasswordAuthentication=no"], "post-deploy": "npm install && pm2 restart app" } } } }
Among them, the deploy script will push the code to the myapp.git warehouse on the server; some configuration items are defined in config/deploy/production, including the IP address of the server, the path of the project, the path of the hook, etc.
7. Execute code deployment
Execute the following command in the local code directory:
npm run deploy production
This command will push the code to the server and trigger The post-receive hook automatically deploys the code to the /var/www/html/myapp directory.
8. Start the application
Go to the /var/www/html/myapp directory and execute the following command to start the application:
npm start
The application should now run on the server! If the application fails to start, you need to check that the dependencies are installed correctly and that the application is configured correctly.
Summary:
The above are the steps to deploy the project on Github to the server. Although this process may seem tedious, using this approach allows for efficient code deployment and collaboration. At the same time, it also provides us with great learning opportunities, allowing us to have a deeper understanding of Git, Node.js and other technologies.
The above is the detailed content of Detailed explanation of the steps to deploy Github projects to the server. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Running the H5 project requires the following steps: installing necessary tools such as web server, Node.js, development tools, etc. Build a development environment, create project folders, initialize projects, and write code. Start the development server and run the command using the command line. Preview the project in your browser and enter the development server URL. Publish projects, optimize code, deploy projects, and set up web server configuration.

Under the BeegoORM framework, how to specify the database associated with the model? Many Beego projects require multiple databases to be operated simultaneously. When using Beego...

GiteePages static website deployment failed: 404 error troubleshooting and resolution when using Gitee...

Which libraries in Go are developed by large companies or well-known open source projects? When programming in Go, developers often encounter some common needs, ...

The problem of using RedisStream to implement message queues in Go language is using Go language and Redis...

The H5 page needs to be maintained continuously, because of factors such as code vulnerabilities, browser compatibility, performance optimization, security updates and user experience improvements. Effective maintenance methods include establishing a complete testing system, using version control tools, regularly monitoring page performance, collecting user feedback and formulating maintenance plans.

There are two ways to convert XML to Excel: use built-in Excel features or third-party tools. Third-party tools include XML to Excel converter, XML2Excel, and XML Candy.

Resource management in Go programming: Mysql and Redis connect and release in learning how to correctly manage resources, especially with databases and caches...
