radix-job-scheduler

command module
v1.8.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 27, 2023 License: MIT Imports: 21 Imported by: 0

README

The job scheduler server for application jobs

Usage

Request from application container URLs

  • POST http://<job-name>:8080/api/v1/jobs - start a new job
  • GET http://<job-name>:8080/api/v1/jobs - get a job list
  • GET http://<job-name>:8080/api/v1/jobs/<job-name> - get a job status
  • DELETE http://<job-name>:8080/api/v1/jobs/<job-name> - delete a job
  • POST http://<job-name>:8080/api/v1/jobs/<batch-name>/stop - stop a batch
  • POST http://<job-name>:8080/api/v1/batches - start a new batch
  • GET http://<job-name>:8080/api/v1/batches - get a batch list
  • GET http://<job-name>:8080/api/v1/batches/<batch-name> - get a batch status
  • DELETE http://<job-name>:8080/api/v1/batches/<batch-name> - delete a batch
  • POST http://<job-name>:8080/api/v1/batches/<batch-name>/stop - stop a batch
  • POST http://<job-name>:8080/api/v1/batches/<batch-name>/jobs/<job-name>/stop - stop a batch job

Developing

You need Go installed. Make sure GOPATH and GOROOT are properly set up.

Clone the repo into your GOPATH and run go mod download.

Also needed:

  • go-swagger (on a Mac, you can install it with Homebrew: brew install go-swagger)
  • statik (install with go get github.com/rakyll/statik)

Clone the repo into your GOPATH and run go mod download.

Update version

We follow the semantic version as recommended by go. radix-job-scheduler has three places to set version

  • apiVersionRoute in router/server.go and BasePathin docs/docs.go - API version, used in API's URL

  • Version in docs/docs.go - indicates changes in radix-job-scheduler logic - to see (e.g in swagger), that the version in the environment corresponds with what you wanted

    Run following command to update version in swagger.json

    make swagger
    
  • If generated file swagger.json is changed (methods or structures) - copy it to the public site

Custom configuration

By default Info and Error messages are logged. This can be configured via environment variable LOG_LEVEL (pods need to be restarted after changes)

  • LOG_LEVEL=ERROR - log only Error messages
  • LOG_LEVEL=INFO or not set - log Info and Error messages
  • LOG_LEVEL=WARNING or not set - log Info, Warning and Error messages
  • LOG_LEVEL=DEBUG - log Debug, Warning, Info and Error messages

By default swagger UI is not available. This can be configured via environment variable USE_SWAGGER

  • USE_SWAGGER=true - allows to use swagger UI with URL <api-endpoint>/swaggerui

Generating mocks

We use gomock to generate mocks used in unit test. https://github.com/golang/mock

You need to regenerate mocks if you make changes to any of the interfaces in the code, e.g. the job Handler interface

Run make mock to regenerate mocks

Update version

We follow the semantic version as recommended by go.

  • tag in git repository (in main branch)

    Run following command to set tag (with corresponding version)

    git tag v1.0.0 
    git push origin v1.0.0
    

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
api
v1
v1/batches/mock
Package mock is a generated GoMock package.
Package mock is a generated GoMock package.
v1/jobs/mock
Package mock is a generated GoMock package.
Package mock is a generated GoMock package.
v2
v2/mock
Package mock is a generated GoMock package.
Package mock is a generated GoMock package.
Package docs Radix job scheduler server.
Package docs Radix job scheduler server.
notifications
Package notifications is a generated GoMock package.
Package notifications is a generated GoMock package.
v1
v2
Package swaggerui Needed for dynamically generate swagger documentation from make file using swagger + statik
Package swaggerui Needed for dynamically generate swagger documentation from make file using swagger + statik

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL