{"id":22852137,"url":"https://github.com/alicfeng/gogs_drone_docker","last_synced_at":"2025-04-30T09:17:00.823Z","repository":{"id":41406116,"uuid":"162257842","full_name":"alicfeng/gogs_drone_docker","owner":"alicfeng","description":"For the better CI as well as CD using gogs and  drone base on Docker","archived":false,"fork":false,"pushed_at":"2022-12-24T12:17:28.000Z","size":791,"stargazers_count":76,"open_issues_count":2,"forks_count":18,"subscribers_count":1,"default_branch":"1.0","last_synced_at":"2025-04-30T09:16:49.696Z","etag":null,"topics":["docker","docker-compose","drone","gogs"],"latest_commit_sha":null,"homepage":"https://www.samego.com","language":"Dockerfile","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/alicfeng.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2018-12-18T08:46:54.000Z","updated_at":"2025-04-16T19:01:55.000Z","dependencies_parsed_at":"2023-01-30T20:35:12.014Z","dependency_job_id":null,"html_url":"https://github.com/alicfeng/gogs_drone_docker","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alicfeng%2Fgogs_drone_docker","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alicfeng%2Fgogs_drone_docker/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alicfeng%2Fgogs_drone_docker/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alicfeng%2Fgogs_drone_docker/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/alicfeng","download_url":"https://codeload.github.com/alicfeng/gogs_drone_docker/tar.gz/refs/heads/1.0","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":251674590,"owners_count":21625646,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["docker","docker-compose","drone","gogs"],"created_at":"2024-12-13T06:07:19.145Z","updated_at":"2025-04-30T09:17:00.803Z","avatar_url":"https://github.com/alicfeng.png","language":"Dockerfile","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003e 基于 `Kubernetes` 部署方案于 [alicfeng/kubernetes_cicd](https://github.com/alicfeng/kubernetes_cicd) 仓库\n\n## 前言\n\n`CI / CD`( 持续集成 / 持续部署  )方案是DevOps中不可或缺的流程之一，最近也了解了部分的相关的解决方案，最终选择了`Drone` + `Gogs`基于`docker`容器环境来构建`CI / CD`，本文将分享下如何构建此平台以及如何快速地使用到项目开发中。\n\n**应该会有一个疑问？我为什么不选择主流的`GitLab` + `Jenkins` 两个最佳搭档来构建呢？**\n\n- `GitLab`是使用`Ruby`编写的，`Jenkins`更是了不起，使用`Java`来编写的，项目整体比较膨大，同时它们对硬件、CPU等开销比较高\n- `Drone`、`Gogs`皆是使用`Go`语言来编写构建，在整体的语言性能与内存开销算是有一定的优势，同时`Drone`支持`Github`、`GitLab`、`Gogs`以及`Bitbucket`，这点很不错！反手就是一个赞?\n\u003e GitLab + Jenkins该组合还是一个不错的选择，我并没有反对，为何呢？GitLab是一个非常成熟的git工具之一，同时Jenkins也是非常成熟的CICD组件，功能非常强大。\n\u003e 但是我还是要站在正义的一边，选择`Drone` + `Gogs`。O(∩_∩)O哈哈~\n\n\n\n#### 说明\n\n`drone`升级使用`1.0.0-rc6`版本，此版本并非稳定版本，推荐使用`1`版本甚至是`0.8.6`更稳定的版本。`1.0`后的版本较之前而言，配置更加灵活、优化版本，同时界面也变化了。[drone](https://drone.io/)\n\n\n\n#### 环境\n\n使用的前提，必须符合以下条件\n- 系统安装了`Docker`，同时要安装了`Docker`编排工具`docker-compose`\n- 主流的`x64`位系统，`Linux`、`Mac`、`Window`等\n- 安装了`git`版本控制工具\n\n\n\n#### 安装\n安装非常简单，拉取`docker-compose.yml`编排文件，基于`Docker`环境自动构建即可！\n**同步至[github](https://github.com/alicfeng/gogs-drone-docker) | [戳戳戳](https://github.com/alicfeng/gogs-drone-docker)**\n```shell\ngit clone https://github.com/alicfeng/gogs-drone-docker.git\ncd gogs-drone-docker \u0026\u0026 docker-compose up -d\n```\n执行`docker ps`来看下容器的运行情况\n![alicfeng - docker ps](https://laravel-china.org/uploads/images/201812/23/29791/dpbpV6AFUM.png)\n\n\u003e 对应的配置文件可以根据项目的需求自由灵活改变，同时像我这样强迫症的人，我不喜欢使用`IP`来进行访问请求的以及`http`协议访问，我会使用`nginx`代理。[不详细说了](https://www.jianshu.com/p/5d36ccb5af88)\n\n至此，我们已经完成了平台的构建工作了。我们来欣赏下~干杯~\n![Gogs](https://laravel-china.org/uploads/images/201812/23/29791/5shaxU7QMn.png)\n![Drone](https://laravel-china.org/uploads/images/201812/23/29791/XufyITQfkI.png)\n\n有两个地方需要注意：\n- `Drone`登录的账号需要在`Gogs`设置为管理员，他俩兄弟的账密是互通的\n- `Gogs`的仓库会自动同步到`Drone`上，此时，需要在`Drone`开启钩子才能正常运行\n\n\n\n#### 使用\n好了，是时候来体验两把了，这里需要有一个前提了，O(∩_∩)O哈哈~，你需要了解它是如何运行的，根据什么来自动化构建的\n每当分支的代码更新的时候，Gogs会动过钩子同步通知Drone，而Drone收到通知之后会发生一系列动作\n - 通过git插件`clone`分支代码到容器里面\n - 测试\n - 编译代码，构建可执行文件\n - 将项目和运行环境打包成镜像，发布到`Registry`\n - 部署至生产环境\n - 发送邮件等通知信息，这里还有很多插件，比如微信、钉钉、电报等\n\n   构建的剧本是通过`.drone.yml`文件编排的，基于`Docker`镜像进行构建，很nice~下面简单体验下`Laravel`项目的即可！[github](https://github.com/alicfeng/gogs-drone-docker) 有`laravel`、`vue`等前后端编排的`yml`文件。\n\n```yml\npipeline:\n  build:\n    image: motecshine/laravelphp71\n    commands:\n    - mv $(pwd)/.env.dev $(pwd)/.env\n    - composer config repo.packagist composer https://packagist.phpcomposer.com\n    - composer install --no-scripts --no-dev\n    # others\n```\n![drone](https://raw.githubusercontent.com/alicfeng/gogs-drone-docker/1.0/file/image3.png)\n\n![drone](https://raw.githubusercontent.com/alicfeng/gogs-drone-docker/1.0/file/image2.png)\n\n\n**[价值源于技术，技术源于分享](https://github.com/alicfeng)**","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Falicfeng%2Fgogs_drone_docker","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Falicfeng%2Fgogs_drone_docker","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Falicfeng%2Fgogs_drone_docker/lists"}