|  | 2 weeks ago | |
|---|---|---|
| .devcontainer | 3 years ago | |
| .github | 3 months ago | |
| .licenses | 1 month ago | |
| .vscode | 6 years ago | |
| __tests__ | 4 months ago | |
| dist | 2 weeks ago | |
| restore | 1 year ago | |
| save | 10 months ago | |
| src | 3 weeks ago | |
| .eslintrc.json | 4 years ago | |
| .gitattributes | 4 years ago | |
| .gitignore | 6 years ago | |
| .licensed.yml | 3 months ago | |
| .prettierrc.json | 6 years ago | |
| CODE_OF_CONDUCT.md | 6 years ago | |
| CONTRIBUTING.md | 5 years ago | |
| LICENSE | 6 years ago | |
| README.md | 2 weeks ago | |
| RELEASES.md | 1 month ago | |
| action.yml | 5 months ago | |
| caching-strategies.md | 10 months ago | |
| examples.md | 1 year ago | |
| jest.config.js | 4 years ago | |
| package-lock.json | 2 weeks ago | |
| package.json | 2 weeks ago | |
| tips-and-workarounds.md | 9 months ago | |
| tsconfig.json | 6 years ago | |
		
			
				
				README.md
			
		
		
			
			
		
	
	Shockingly faster cache action
This action is a drop-in replacement for the official actions/cache@v4 action, for use with the RunsOn self-hosted GitHub Action runner provider, or with your own self-hosted runner solution.
It will automatically store your caches in a dedicated RunsOn S3 bucket that lives close to your self-hosted runners, ensuring you get at least 200MiB/s download and upload throughput when using caches in your workflows. The larger the cache, the faster the speed.
Also note that you no longer have any limit on the size of the cache. The bucket has a lifecycle rule to remove items older than 10 days.
If no S3 bucket is provided, it will also transparently switch to the default behaviour. This means you can use this action and switch between RunsOn runners and official GitHub runners with no change.
Usage with RunsOn
If using RunsOn, simply replace actions/cache@v4 with runs-on/cache@v4. All the official options are supported.
- - uses: actions/cache@v4
+ - uses: runs-on/cache@v4
    with:
      ...
Please refer to actions/cache for usage.
Usage outside RunsOn
If you want to use this in your own infrastructure, setup your AWS credentials with aws-actions/configure-aws-credentials, then:
  - uses: aws-actions/configure-aws-credentials@v4
    ...
  - uses: runs-on/cache@v4
    with:
      ...
    env:
      RUNS_ON_S3_BUCKET_CACHE: name-of-your-bucket
Be aware of S3 transfer costs if your runners are not in the same AWS region as your bucket.
Special environment variables
- RUNS_ON_S3_BUCKET_CACHE: if set, the action will use this bucket to store the cache.
- RUNS_ON_S3_BUCKET_ENDPOINT: if set, the action will use this endpoint to connect to the bucket. This is useful if you are using AWS's S3 transfer acceleration or a non-AWS S3-compatible service.
- RUNS_ON_RUNNER_NAME: when running on RunsOn, where this environment variable is non-empty, existing AWS credentials from the environment will be discarded. If you want to preserve existing environment variables, set this to the empty string- "".
- RUNS_ON_S3_FORCE_PATH_STYLEor- AWS_S3_FORCE_PATH_STYLE: if one of those environment variables equals the string- "true", then the S3 client will be configured to force the path style.
Action pinning
Contrary to the upstream action, v4 is a branch. As such, any tag pushed to this runs-on/cache repository comes from upstream and does NOT contain the changes for the S3 backend support. Please pin to a specific commmit from the v4 branch if needed.