使用GitHub Actions和Nginx实现自动化部署

简介: 使用GitHub Actions和Nginx实现自动化部署

要使用GitHub Actions和Nginx实现自动化部署,可以按照以下步骤操作:

 

1. **准备Nginx服务器**:在服务器上安装和配置Nginx,确保Nginx能够正常运行。

 

2. **创建GitHub仓库**:在GitHub上创建一个新的仓库,用于存储你的项目代码。

 

3. **创建GitHub Actions工作流**:在项目中创建`.github/workflows`目录,并在该目录下创建一个YAML文件,用于定义GitHub Actions工作流。示例内容如下:

 

```yaml
   name: Deploy to Nginx
 
   on:
     push:
       branches:
         - main
 
   jobs:
     deploy:
       runs-on: ubuntu-latest
 
       steps:
         - name: Checkout code
           uses: actions/checkout@v2
 
         - name: Install dependencies
           run: |
             sudo apt-get update
             sudo apt-get install nginx -y
 
         - name: Copy files to Nginx directory
           run: |
             sudo cp -r * /var/www/html/
 
         - name: Restart Nginx
           run: sudo systemctl restart nginx
   ```

 

  这个示例工作流在`main`分支上的每次push事件时运行,它会安装Nginx,将项目文件复制到Nginx的HTML目录下,并重启Nginx。

 

4. **提交代码到GitHub仓库**:将你的项目代码提交到GitHub仓库,触发GitHub Actions工作流。

 

5. **验证部署**:访问Nginx服务器的IP地址或域名,验证部署是否成功。

 

这里是一个更完整的示例代码,演示了如何使用GitHub Actions和Nginx实现自动化部署一个简单的静态网站。

 

1. **创建GitHub仓库**:创建一个新的GitHub仓库并将以下文件添加到仓库中:

 

  - `index.html`:一个简单的HTML文件,作为你的静态网站首页。

  - `.github/workflows/deploy.yml`:用于定义GitHub Actions工作流的YAML文件。

 

2. **index.html**:

 

```html
   <!DOCTYPE html>
   <html>
   <head>
       <title>Auto Deploy Example</title>
   </head>
   <body>
       <h1>Hello, Auto Deploy!</h1>
   </body>
   </html>
   ```

 

3. **.github/workflows/deploy.yml**:

 

```yaml
   name: Deploy to Nginx
 
   on:
     push:
       branches:
         - main
 
   jobs:
     deploy:
       runs-on: ubuntu-latest
 
       steps:
         - name: Checkout code
           uses: actions/checkout@v2
 
         - name: Install Nginx
           run: sudo apt-get update && sudo apt-get install nginx -y
 
         - name: Copy files to Nginx directory
           run: sudo cp -r * /var/www/html/
 
         - name: Restart Nginx
           run: sudo systemctl restart nginx
   ```

 

4. **提交代码**:将以上文件添加到GitHub仓库并提交。

 

这个示例假设我们已经有一个运行Nginx的服务器,并且具有sudo权限。工作流将在每次将代码推送到GitHub仓库的`main`分支时运行,它会安装Nginx,将`index.html`文件复制到Nginx的HTML目录下,并重启Nginx。

 

这里是一个带有环境变量配置的示例,可以根据需要修改Nginx的配置文件。

 

```yaml
name: Deploy to Nginx
 
on:
  push:
    branches:
      - main
 
jobs:
  deploy:
    runs-on: ubuntu-latest
 
    steps:
      - name: Checkout code
        uses: actions/checkout@v2
 
      - name: Install Nginx
        run: sudo apt-get update && sudo apt-get install nginx -y
 
      - name: Copy files to Nginx directory
        run: sudo cp -r * /var/www/html/
 
      - name: Set up Nginx configuration
        run: |
          sudo bash -c 'cat > /etc/nginx/sites-available/default <<EOF
          server {
            listen 80;
            server_name _;
            root /var/www/html;
            index index.html;
 
            location / {
              try_files \$uri \$uri/ =404;
            }
          }
          EOF'
 
      - name: Enable Nginx site
        run: sudo ln -s /etc/nginx/sites-available/default /etc/nginx/sites-enabled/
 
      - name: Restart Nginx
        run: sudo systemctl restart nginx
```

 

这个示例假设我们的Nginx配置文件是默认的`/etc/nginx/sites-available/default`,并且我们希望使用默认的Nginx配置来服务你的静态网站。如果我们有自定义的Nginx配置,请相应地修改`/etc/nginx/sites-available/default`的内容。

目录
相关文章
|
4月前
|
JavaScript API 开发工具
使用GitHub Actions自动发布electron多端安装程序
使用GitHub Actions自动发布electron多端安装程序
82 8
利用 GitHub Actions 自动化你的软件开发流程
在现代软件开发中,自动化是提升效率与质量的关键。GitHub Actions 作为 GitHub 的强大自动化工具,允许你在仓库中自动执行多种任务,如测试、打包、部署代码及自动合并 Pull Requests。本文介绍了 GitHub Actions 的核心概念、设置方法及其实用示例,帮助你快速上手并优化开发流程。通过 YAML 文件定义的工作流程可显著提高工作效率和代码质量。
利用 GitHub Actions 自动化你的软件开发流程
GitHub Actions 是由 GitHub 提供的自动化工具,可让你在仓库中触发和执行自动化工作流程,如自动运行测试和部署应用。其核心概念包括工作流程(定义在 YAML 文件中的一系列自动化步骤)、作业和步骤。本文将指导你如何设置和使用 GitHub Actions,并提供实用的自动化示例,帮助你提高开发效率和代码质量。通过简单的配置文件,你可以实现自动运行测试、部署应用甚至自动合并 Pull Requests。
|
5月前
|
开发者
利用 GitHub Actions 自动化你的软件开发流程
在快速发展的软件开发环境中,自动化对于提升效率与质量至关重要。GitHub Actions 作为一款强大的工具,能帮助开发者实现从自动运行测试到部署应用等工作的自动化。本文详细介绍了 GitHub Actions 的核心概念、设置方法及实际应用示例,如自动测试、部署和合并 Pull Requests,助力提升开发流程的自动化水平。
利用 GitHub Actions 自动化你的软件开发流程
GitHub Actions 是 GitHub 提供的自动化工具,可在仓库中触发和执行工作流程,包括自动运行测试、部署应用等。其核心概念包括工作流程(Workflow)、作业(Job)和步骤(Step),均定义在 YAML 文件中。本文将指导你如何设置和使用 GitHub Actions,并提供自动运行测试、部署应用及合并 Pull Requests 的示例,帮助提高开发效率和代码质量。
|
数据可视化 Shell 持续交付
|
1月前
|
开发工具 git
如何操作github,gitee,gitcode三个git平台建立镜像仓库机制,这样便于维护项目只需要维护一个平台仓库地址的即可-优雅草央千澈
如何操作github,gitee,gitcode三个git平台建立镜像仓库机制,这样便于维护项目只需要维护一个平台仓库地址的即可-优雅草央千澈
184 69
如何操作github,gitee,gitcode三个git平台建立镜像仓库机制,这样便于维护项目只需要维护一个平台仓库地址的即可-优雅草央千澈
|
4月前
|
编解码 Oracle Java
java9到java17的新特性学习--github新项目
本文宣布了一个名为"JavaLearnNote"的新GitHub项目,该项目旨在帮助Java开发者深入理解和掌握从Java 9到Java 17的每个版本的关键新特性,并通过实战演示、社区支持和持续更新来促进学习。
130 3
|
6月前
|
存储 安全 Java
【事故】记一次意外把公司项目放到GitHub并被fork,如何使用DMCA下架政策保障隐私
在一次意外中,作者因三年前将测试代码遗忘在GitHub上而遭遇了代码被他人fork的问题。为解决这一危机,作者详细介绍了如何通过GitHub的DMCA下架通知流程安全删除敏感代码,包括处理私人信息和商标侵权的具体步骤。本文不仅提供了实用的操作指南,还强调了及时响应的重要性,帮助读者避免类似风险
152 1
【事故】记一次意外把公司项目放到GitHub并被fork,如何使用DMCA下架政策保障隐私
|
6月前
|
SQL JavaScript 前端开发
Github 2024-08-05 开源项目周报 Top15
根据 Github Trendings 的统计,本周(2024年8月5日统计)共有15个项目上榜。以下是根据开发语言汇总的项目数量: - Go 项目:4个 - JavaScript 项目:3个 - Python 项目:3个 - Java 项目:2个 - TypeScript 项目:2个 - C 项目:1个 - Shell 项目:1个 - Dockerfile 项目:1个 - 非开发语言项目:1个
209 2

热门文章

最新文章