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!

GitHub has a far-reaching impact on software development and collaboration: 1. It is based on Git's distributed version control system, which improves code security and development flexibility; 2. Through functions such as PullRequest, it improves team collaboration efficiency and knowledge sharing; 3. Tools such as GitHubActions help optimize the development process and improve code quality.

The methods of sharing, managing and contributing code on GitHub include: 1. Create a repository and push code, and write README and LICENSE files; 2. Use branches, tags and merge requests to manage code; 3. Fork the repository, modify and submit PullRequest contribution code. Through these steps, developers can effectively use GitHub to improve development efficiency and collaboration capabilities.

Git is a distributed version control system, and GitHub is a Git-based collaboration platform. Git is used for version control and code management, while GitHub provides additional collaboration features such as code review and project management.

Git is a distributed version control system, and GitHub is an online platform based on Git. Git is used for version control, branch management and merger, and GitHub provides code hosting, collaboration tools and social networking capabilities.

Git is a back-end version control system, and GitHub is a front-end collaboration platform based on Git. Git manages code version, GitHub provides user interface and collaboration tools, and the two work together to improve development efficiency.

Git is a version control system, and GitHub is a Git-based code hosting platform. Git is used to manage code versions and history, and GitHub provides code hosting and collaboration capabilities. Git is suitable for all projects that require version control, GitHub is suitable for team collaboration and open source projects.

Git is a distributed version control system, and GitHub is an online platform based on Git. Git provides version control features such as branch management and commit history; GitHub provides collaboration tools such as code review and project management.

Git and GitHub are the core tools of modern software development. Git is a distributed version control system, while GitHub is a collaboration platform. Using Git and GitHub can improve development efficiency and enhance team collaboration.


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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

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

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software
