当前位置: 首页 > news >正文

本地部署开源持续集成和持续部署系统 Woodpecker CI 并实现外部访问

Woodpecker CI 是一款轻量级、快速、开源的持续集成和持续部署( CI / CD )系统,它以简单、高效和易于集成而著称,特别适合希望快速搭建 CI / CD 流水线的开发者和团队。本文将详细介绍如何利用 Docker 在局域网内部署 Woodpecker CI 并结合路由侠实现外网访问局域网内部署的 Woodpecker CI 。

第一步,本地部署安装 Woodpecker CI

1,本教程操作环境为 Linux Ubuntu 系统,Woodpecker CI 依赖 Docker 运行,我们需要先确保你的系统上已经安装了 Docker 。如果尚未安装,可以参考文档进行安装,点此查看。

2,安装 Docker Compose 。

sudo curl -L "https://github.com/docker/compose/releases/download/$(curl -s https://api.github.com/repos/docker/compose/releases/latest | grep -Po '"tag_name": "\K.*\d')" /usr/local/bin/docker-compose

3,登录 GitHub ,进入【 Settings 】→【 Developer settings 】→【 OAuth Apps 】→【 New OAuth App 】。

填写信息,点击【 Register application 】。

记下生成的 Client ID 和 Client Secret 。

4,打开终端输入以下命令创建并进入项目目录。

mkdir ~/woodpecker && cd ~/woodpecker

5,创建 docker-compose.yml 文件。

sudo vim docker-compose.yml

写入以下内容:

version: '3'services:woodpecker-server:image: woodpeckerci/woodpecker-server:latestports:- "8000:8000"- "9000:9000"environment:- WOODPECKER_OPEN=true- WOODPECKER_HOST=http://你的服务器 IP:8000- WOODPECKER_GITHUB=true- WOODPECKER_GITHUB_CLIENT=你的 github-client-id- WOODPECKER_GITHUB_SECRET=你的 github-client-secret- WOODPECKER_AGENT_SECRET=your-super-secret-agent-tokenvolumes:- ./woodpecker-data:/var/lib/woodpecker/restart: alwayswoodpecker-agent:image: woodpeckerci/woodpecker-agent:latestcommand: agentdepends_on:- woodpecker-serverenvironment:- WOODPECKER_SERVER=woodpecker-server:9000- WOODPECKER_AGENT_SECRET=your-super-secret-agent-token- WOODPECKER_NAMESPACE_DOCKER=woodpeckervolumes:- /var/run/docker.sock:/var/run/docker.sockrestart: always

6,启动 Woodpecker CI 服务。

docker-compose up -d

7,打开浏览器访问地址 http://你的服务器 IP:8000 ,就能看到你部署的 Woodpecker CI 界面了。

第二步,外网访问本地 Woodpecker CI

安装路由侠内网穿透。

1,当前未提供网页管理,需要先在任意一台 Windows 机器安装路由侠 Windows 版本,用作跨机器管理。点此下载

2,在路由侠客户端主界面,进入“ 设备管理 ”,点击右下角的“ 添加设备 ”,此时可查看到对应的安装码,此安装码用于将设备添加到对应账号下,可选中后复制。

3,直接下载后导入:

wget https://dl.luyouxia.com:8443/v2/lyx-docker-x86_64.tar
docker load -i lyx-docker-x86_64.tar

4,然后使用该镜像启动容器。

docker run --name lyx -it --restart=always --net=host -e code=这里填写安装码 luyouxia/lyx

5,此时,需要等待下载和安装的过程,如果一切正常,最终可以看到一些输出,并且可以看到如下提示:

[Device] Logged in. Token: ....

这就表示安装成功了。

当前 Linux 终端这边,如果是使用的上面的命令,Docker 是运行在前台,此时可以按住 Ctrl + C ,退出路由侠,容器也将退出。现在可以使用以下命令将其放入后台持续运行:

docker start lyx

注意如果容器删除,重新 docker run , 将创建为新的设备。

需要注意的是,因为容器参数已经添加了 --restart=always ,这样开机就会自动启动,不需要再手动启动路由侠了。

6,现在回到 Windows 这边设备列表,点击右上角的 × 返回主界面,再次进入,就可以找到这个设备,可以修改名称。

7,回到主界面,点击【内网映射】。

8,注意右上角的设备名称下拉框,这里选中刚刚添加的设备名称,此时在这个界面上添加的映射,就属于刚刚这个设备。添加或修改一般需要等待 30 秒,容器中的路由侠进程就会更新并加载。切换好设备后,点击【添加映射】。

9,选择【原生端口】。

10,在内网地址填写你的服务器 IP 和 Woodpecker CI 端口 8000 后点击【创建】按钮,如下图。

11,创建好后,就可以看到一条映射的公网地址,鼠标右键点击【复制地址】。

12,在外网电脑上,打开浏览器,在地址栏输入从路由侠生成的外网地址,就可以看到内网部署的 Woodpecker CI 界面了。

http://www.dtcms.com/a/477785.html

相关文章:

  • 从 FinalShell 迁移到 WindTerm:一次安全、高效、开源的终端升级之旅
  • 从 0 到 1 构建一个完整的 AGUI 前端项目的流程在 ESP32 上运行
  • 【具身智能】RoboTwin 2.0:一个可扩展的、强领域随机化的数据生成器,用于双臂机器人操作
  • 【STM32项目开源】基于STM32的智能家庭安防系统
  • Avalonia+ReactiveUI+Sourcegenerators实现异步命令
  • 个人网站建设心得网站开发的数据库设计实体是什么
  • Java的动态绑定机制(重要)
  • 2Docker自定义网络,compose多容器部署
  • Linux内存管理-malloc虚拟内存到物理映射详细分析
  • 桂林网站建设内容大专自考报名入口官网
  • AMS支持的融资业务如何优化风控流程?
  • 小杰深度学习(thirteen)——视觉-经典神经网络——GoogLeNet
  • jtag转swd
  • 多语言支持应用场景实战解析
  • 手机微网站怎么设计方案陕西建省级执法人才库
  • c# 中文数字转阿拉伯数字
  • 如何自定义 Qt 日志处理并记录日志到文件
  • Spring Boot 3零基础教程,类属性绑定配置文件中的值,笔记10
  • TypeScript 基础类型
  • 鸿蒙NEXT Function Flow Runtime Kit:解锁高效并发编程的利器
  • 一个小项目的记录:PHP 分账组件
  • excel-mcp-server rocky linux简单部署
  • 网站前台模块包括什么软件wordpress js放到oss
  • ENET_INIT卡死在DMA_MODE判断
  • 蓝光3D扫描:汽车模具高精度尺寸检测与数字化质量控制实践
  • 一文对最新版本 Flink 反压机制全景深度解析(附源码)
  • 从硅谷到全球:新思科技(Synopsys)的发展史与产业深耕之路
  • 网站建设wang1314公司图案设计
  • 【AES加密专题】7.AES全局函数的编写
  • EPSON TG2016SMN:低功耗温补晶振延长电池设备续航