{"id":13622413,"url":"https://github.com/bookingcom/shipper","last_synced_at":"2026-01-15T01:49:01.053Z","repository":{"id":39544761,"uuid":"146317566","full_name":"bookingcom/shipper","owner":"bookingcom","description":"Kubernetes native multi-cluster canary or blue-green rollouts using Helm","archived":true,"fork":false,"pushed_at":"2022-05-03T15:39:14.000Z","size":68173,"stargazers_count":728,"open_issues_count":42,"forks_count":39,"subscribers_count":16,"default_branch":"master","last_synced_at":"2025-08-13T22:11:17.726Z","etag":null,"topics":["blue-green-deployment","deployment-automation","kubernetes"],"latest_commit_sha":null,"homepage":"","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/bookingcom.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG-0.10.md","contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2018-08-27T15:31:41.000Z","updated_at":"2025-07-30T20:45:56.000Z","dependencies_parsed_at":"2022-09-13T03:10:36.576Z","dependency_job_id":null,"html_url":"https://github.com/bookingcom/shipper","commit_stats":null,"previous_names":[],"tags_count":60,"template":false,"template_full_name":null,"purl":"pkg:github/bookingcom/shipper","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bookingcom%2Fshipper","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bookingcom%2Fshipper/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bookingcom%2Fshipper/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bookingcom%2Fshipper/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/bookingcom","download_url":"https://codeload.github.com/bookingcom/shipper/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bookingcom%2Fshipper/sbom","scorecard":{"id":247801,"data":{"date":"2025-08-11","repo":{"name":"github.com/bookingcom/shipper","commit":"6e3765a4d855aaaccdbebfdde298836e692cd2d4"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":3.5,"checks":[{"name":"Maintained","score":0,"reason":"project is archived","details":["Warn: Repository is archived."],"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Code-Review","score":10,"reason":"all changesets reviewed","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/main.yml:1","Info: no jobLevel write permissions found"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: Apache License 2.0: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"Signed-Releases","score":0,"reason":"Project has not signed or included provenance with any releases.","details":["Warn: release artifact v0.10.9 not signed: https://api.github.com/repos/bookingcom/shipper/releases/54795527","Warn: release artifact v0.10.8 not signed: https://api.github.com/repos/bookingcom/shipper/releases/54121611","Warn: release artifact v0.10.6 not signed: https://api.github.com/repos/bookingcom/shipper/releases/42832919","Warn: release artifact v0.10.5 not signed: https://api.github.com/repos/bookingcom/shipper/releases/41531571","Warn: release artifact v0.10.9 does not have provenance: https://api.github.com/repos/bookingcom/shipper/releases/54795527","Warn: release artifact v0.10.8 does not have provenance: https://api.github.com/repos/bookingcom/shipper/releases/54121611","Warn: release artifact v0.10.6 does not have provenance: https://api.github.com/repos/bookingcom/shipper/releases/42832919","Warn: release artifact v0.10.5 does not have provenance: https://api.github.com/repos/bookingcom/shipper/releases/41531571"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":-1,"reason":"internal error: error during branchesHandler.setup: internal error: githubv4.Query: Resource not accessible by integration","details":null,"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Pinned-Dependencies","score":1,"reason":"dependency not pinned by hash detected -- score normalized to 1","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:22: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:24: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:50: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:57: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/main.yml:59: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/main.yml:65: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/main.yml:71: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:81: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:83: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:97: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:99: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/main.yml:106: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:113: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:118: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:127: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:136: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:145: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:154: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/main.yml:163: update your workflow using https://app.stepsecurity.io/secureworkflow/bookingcom/shipper/main.yml/master?enable=pin","Warn: containerImage not pinned by hash: Dockerfile.shipper:1: pin your Docker image by updating alpine:3.12.3 to alpine:3.12.3@sha256:3c7497bf0c7af93428242d6176e8f7905f2201d8fc5861f45be7a346b5f23436","Warn: containerImage not pinned by hash: Dockerfile.shipper-state-metrics:1: pin your Docker image by updating alpine:3.12.3 to alpine:3.12.3@sha256:3c7497bf0c7af93428242d6176e8f7905f2201d8fc5861f45be7a346b5f23436","Warn: containerImage not pinned by hash: docs/Dockerfile:1: pin your Docker image by updating python:3 to python:3@sha256:b3e52dd22ff14e2e6dcbc0f028f743dc037c74258e9af3d0a2fd8e6617d94d72","Warn: pipCommand not pinned by hash: docs/Dockerfile:6","Warn: pipCommand not pinned by hash: docs/build.sh:3","Warn: goCommand not pinned by hash: hack/generate-groups.sh:49","Warn: goCommand not pinned by hash: vendor/github.com/googleapis/gnostic/extensions/COMPILE-EXTENSION.sh:1","Warn: goCommand not pinned by hash: vendor/github.com/json-iterator/go/build.sh:10","Warn: downloadThenRun not pinned by hash: .github/workflows/main.yml:38","Warn: downloadThenRun not pinned by hash: .github/workflows/main.yml:104","Info:   0 out of  15 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   4 third-party GitHubAction dependencies pinned","Info:   0 out of   3 containerImage dependencies pinned","Info:   0 out of   2 pipCommand dependencies pinned","Info:   3 out of   6 goCommand dependencies pinned","Info:   0 out of   2 downloadThenRun dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 30 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Vulnerabilities","score":0,"reason":"43 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GO-2023-2048 / GHSA-6xv5-86q9-7xr8","Warn: Project is vulnerable to: GO-2022-0322 / GHSA-cg3q-j54f-5p7p","Warn: Project is vulnerable to: GO-2021-0064 / GHSA-8cfg-vx93-jvxw","Warn: Project is vulnerable to: GO-2020-0017 / GHSA-w73w-5m7g-f7qc","Warn: Project is vulnerable to: GO-2022-0209 / GHSA-r5c5-pr8j-pfp7","Warn: Project is vulnerable to: GO-2023-1992 / GHSA-x3jr-pf6g-c48f","Warn: Project is vulnerable to: GO-2022-0229 / GHSA-cjjc-xp8v-855w","Warn: Project is vulnerable to: GO-2020-0012 / GHSA-ffhg-7mh4-33c4","Warn: Project is vulnerable to: GO-2021-0227 / GHSA-3vm4-22fp-5rfm","Warn: Project is vulnerable to: GO-2022-0968 / GHSA-gwc9-m7rh-j2ww","Warn: Project is vulnerable to: GO-2021-0356 / GHSA-8c26-wmh5-6g9v","Warn: Project is vulnerable to: GO-2024-2961","Warn: Project is vulnerable to: GO-2023-2402 / GHSA-45x7-px36-x8w8","Warn: Project is vulnerable to: GO-2024-3321 / GHSA-v778-237x-gjrc","Warn: Project is vulnerable to: GO-2025-3487 / GHSA-hcg3-q754-cr77","Warn: Project is vulnerable to: GO-2022-0236 / GHSA-h86h-8ppg-mxmh","Warn: Project is vulnerable to: GO-2021-0238 / GHSA-83g2-8m93-v3w7","Warn: Project is vulnerable to: GO-2022-0288","Warn: Project is vulnerable to: GO-2022-0969 / GHSA-69cg-p879-7622","Warn: Project is vulnerable to: GO-2022-1144 / GHSA-xrjj-mj9h-534m","Warn: Project is vulnerable to: GO-2023-1571 / GHSA-vvpx-j8f3-3w6h","Warn: Project is vulnerable to: GO-2023-1988 / GHSA-2wrh-6pvc-2jm9","Warn: Project is vulnerable to: GO-2023-2102 / GHSA-4374-p667-p6c8","Warn: Project is vulnerable to: GHSA-qppj-fm5r-hxr3","Warn: Project is vulnerable to: GO-2024-2687 / GHSA-4v7x-pqxf-cx7m","Warn: Project is vulnerable to: GO-2024-3333","Warn: Project is vulnerable to: GO-2025-3503 / GHSA-qxp5-gwg8-xv66","Warn: Project is vulnerable to: GO-2025-3595 / GHSA-vvgc-356p-c3xw","Warn: Project is vulnerable to: GO-2020-0015 / GHSA-5rcv-m4m3-hfh7","Warn: Project is vulnerable to: GO-2021-0113 / GHSA-ppp9-7jff-5vj2","Warn: Project is vulnerable to: GO-2022-1059 / GHSA-69ch-w2m2-3vjp","Warn: Project is vulnerable to: GO-2022-0493 / GHSA-p782-xgp4-8hr8","Warn: Project is vulnerable to: GO-2021-0061 / GHSA-r88r-gmrh-7j83","Warn: Project is vulnerable to: GO-2022-0956 / GHSA-6q6q-88xp-6f2r","Warn: Project is vulnerable to: GO-2020-0036 / GHSA-wxc4-f4m6-wwqv","Warn: Project is vulnerable to: GO-2022-0197 / GHSA-4r78-hx75-jjj2 / GHSA-mv93-wvcp-7m7r","Warn: Project is vulnerable to: GO-2020-0014 / GHSA-vfw5-hrgq-h5wf","Warn: Project is vulnerable to: GO-2022-0536 / GHSA-39qc-96h7-956f / GHSA-hgr8-6h9x-f7q9","Warn: Project is vulnerable to: GO-2021-0078 / GHSA-5p4h-3377-7w67","Warn: Project is vulnerable to: GO-2022-0193 / GHSA-fcf9-6fv2-fc5v","Warn: Project is vulnerable to: GO-2022-0192 / GHSA-2wp2-chmh-r934","Warn: Project is vulnerable to: GO-2022-0619 / GHSA-r48q-9g5r-8q2h","Warn: Project is vulnerable to: GO-2021-0053 / GHSA-c3h9-896r-86jm"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-17T07:55:28.195Z","repository_id":39544761,"created_at":"2025-08-17T07:55:28.195Z","updated_at":"2025-08-17T07:55:28.195Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28441031,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-15T00:55:22.719Z","status":"ssl_error","status_checked_at":"2026-01-15T00:55:20.945Z","response_time":107,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"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":["blue-green-deployment","deployment-automation","kubernetes"],"created_at":"2024-08-01T21:01:18.814Z","updated_at":"2026-01-15T01:49:01.014Z","avatar_url":"https://github.com/bookingcom.png","language":"Go","funding_links":[],"categories":["Continuous Delivery","Go","Configuration Management"],"sub_categories":["[Jenkins](#jenkins)"],"readme":"[![Build Status](https://travis-ci.com/bookingcom/shipper.svg?branch=master)](https://travis-ci.com/bookingcom/shipper)\n[![Documentation Status](https://readthedocs.org/projects/shipper-k8s/badge/?version=latest)](https://shipper-k8s.readthedocs.io/en/latest/)\n\n# Deprecation notice\n\n**⚠️ Shipper has reached end of life. We are no longer accepting pull requests or providing support for community users.\nThe project has been discontinued and the core team will not develop any feature or bug-fix.**\n\n---\n\n# Shipper\n\nVisit [Read the Docs](https://shipper-k8s.readthedocs.io/en/latest/) for the full documentation,\nexamples and guides.\n\nShipper is an extension for Kubernetes to add sophisticated rollout strategies\nand multi-cluster orchestration.\n\nIt lets you use `kubectl` to manipulate objects which represent any kind of\nrollout strategy, like blue/green or canary. These strategies can deploy to one\ncluster, or many clusters across the world.\n\n## Why does Shipper exist?\n\nKubernetes is a wonderful platform, but implementing mature rollout strategies\non top of it requires subtle multi-step orchestration: _Deployment_ objects are\na building block, not a solution.\n\nWhen implemented as a set of scripts in CI/CD systems like Jenkins, GitLab, or\nBrigade, these strategies can become hard to debug, or leave out important\nproperties like safe rollbacks.\n\nThese problems become more severe when the rollout targets multiple Kubernetes\nclusters in multiple regions: the complex, multi-step orchestration has\nmany opportunities to fail and leave clusters in inconsistent states.\n\nShipper helps by providing a higher level API for complex rollout strategies to\none or many clusters. It simplifies CI/CD pipeline scripts by letting them\nfocus on the parts that matter to that particular application.\n\n## Multi-cluster, multi-region, multi-cloud\n\nShipper can deploy your application to multiple clusters in different regions.\n\nIt expects a Kubernetes API and requires no agent in the application clusters,\nso it should work with any compliant Kubernetes implementation like GKE or AKS.\nIf you can use `kubectl` with it, chances are, you can use Shipper with it as\nwell.\n\n## Release Management\n\nShipper doesn't just copy-paste your code onto multiple clusters for you -- it\nallows you to customize the rollout strategy fully. This allows you to craft\na rollout strategy with the appropriate speed/risk balance for your particular\nsituation.\n\nAfter each step of the rollout strategy, Shipper pauses to wait for another\nupdate to the _Release_ object. This checkpointing approach means that rollouts\nare fully declarative, scriptable, and resumable. Shipper can keep a rollout on\na particular step in the strategy for ten seconds or ten hours. At any point\nthe rollout can be safely aborted, or moved backwards through the strategy to\nreturn to an earlier state.\n\n## Roll Backs\n\nSince Shipper keeps a record of all your successful releases, it allows you to\nroll back to an earlier release very easily.\n\n## Charts As Input\n\nShipper installs a complete set of Kubernetes objects for a given application.\n\nIt does this by relying on [Helm](https://helm.sh), and using Helm Charts as\nthe unit of configuration deployment. Shipper's Application object provides an\ninterface for specifying values to a Chart just like the `helm` command line\ntool.\n\n### Relationship to Tiller\n\n[Tiller](https://docs.helm.sh/architecture/#components) is the server-side\ncomponent of Helm 2 which installs Charts into the cluster, and keeps track of\nreleases. Shipper does not use Tiller: it replaces Tiller entirely.\n\nShipper consumes Charts directly from a Chart repository like ChartMuseum, and\ninstalls objects into clusters itself. This has the nice property that regular\nKubernetes authentication and RBAC controls can be used to manage access to\nShipper APIs.\n\n## Documentation and Support\n\nVisit [Read the Docs](https://shipper-k8s.readthedocs.io/en/latest/) for the full documentation,\nexamples and guides.\n\nYou can find us at [#shipper](https://kubernetes.slack.com/messages/shipper/)\nchannel of [Kubernetes slack](http://slack.k8s.io/).\n\n## Demo\n\n[Here's a video demo](http://www.youtube.com/watch?v=5BLD0d_VzNU\u0026start=95\u0026end=1160)\nof Shipper from the SIG Apps community call June 2018. Shipper object\ndefinitions have changed a little bit since then, but this is still a good way\nto get a general idea of what problem Shipper is solving and how it looks in\naction.\n\n## License\n\nApache License 2.0, see [LICENSE](https://github.com/bookingcom/shipper/blob/master/LICENSE).\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fbookingcom%2Fshipper","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fbookingcom%2Fshipper","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fbookingcom%2Fshipper/lists"}