首页 > 开发工具 > git > 详解将Github项目部署到服务器上的步骤

详解将Github项目部署到服务器上的步骤

PHPz
发布: 2023-03-27 11:23:32
原创
5565 人浏览过

Github是目前全球最大的开源社区,很多程序员都会将自己的代码托管在Github上,借助其方便的版本控制和协作功能。然而,Github上的项目仅仅是代码,要把它部署到服务器上运行,需要一些额外的工作。本文将为大家介绍具体的操作步骤。

一、登录服务器

使用SSH远程连接,输入命令:

ssh root@your_server_ip
登录后复制

二、安装必要的软件

在服务器上安装Git和Node.js。以Ubuntu系统为例,执行以下命令:

sudo apt-get update
sudo apt-get install git
sudo apt-get install nodejs
登录后复制

三、在服务器上创建一个Git仓库

在服务器上创建一个空的目录,并在其中初始化一个Git仓库,执行以下命令:

mkdir myapp
cd myapp
git init --bare
登录后复制

四、设置Git Hooks

在Git仓库中添加一个post-receive钩子以便自动部署应用程序,执行以下命令:

cd hooks
touch post-receive
sudo chmod +x post-receive
nano post-receive
登录后复制

在打开的文本编辑器中输入以下内容:

#!/bin/bash
git --work-tree=/var/www/html/myapp --git-dir=/root/myapp.git checkout -f
cd /var/www/html/myapp
sudo npm install
登录后复制

该脚本会自动将代码检出到/var/www/html/myapp下,并且执行npm install命令以安装项目依赖。

五、在Github上配置Webhooks

登录Github,在项目的Settings页面中点击Webhooks选项,然后点击Add webhook按钮。在Payload URL中输入服务器的IP地址和post-receive钩子的路径,例如:http://your_server_ip:8000/hooks/post-receive。在Content type中选择application/json,然后点击Add webhook。

六、在本地的代码中添加服务器地址

在本地的代码中修改package.json文件,增加以下内容:

{
  "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"
      }
    }
  }
}
登录后复制

其中,deploy脚本会将代码推送到服务器上的myapp.git仓库中;config/deploy/production中定义了一些配置项,包括服务器的ip地址、项目的路径、钩子所在的路径等。

七、执行代码部署

在本地的代码目录中执行以下命令:

npm run deploy production
登录后复制

该命令将代码推送到服务器上,触发post-receive钩子,自动将代码部署到/var/www/html/myapp目录下。

八、启动应用程序

进入到/var/www/html/myapp目录中,执行以下命令来启动应用程序:

npm start
登录后复制

应用程序现在应该可以在服务器上运行了!如果应用程序启动失败,则需要检查依赖项是否已正确安装,以及应用程序的配置是否正确。

总结:

以上就是将Github上的项目部署到服务器上的步骤。虽然这个过程看起来有些繁琐,但是通过使用这种方法,可以实现高效的代码部署和协作。同时,也为我们提供了很好的学习机会,让我们更深入地了解Git、Node.js等技术。

以上是详解将Github项目部署到服务器上的步骤的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板