Skip to content

Commit

Permalink
Update README.md (cadence-workflow#200)
Browse files Browse the repository at this point in the history
* Update README.md
* Add separate file, CONTRIBUTING.md, with instructions on how to contribute
  • Loading branch information
molteanu authored May 31, 2017
1 parent 685b66d commit 27c531e
Show file tree
Hide file tree
Showing 2 changed files with 104 additions and 19 deletions.
66 changes: 66 additions & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
# Developing Cadence

This doc is intended for contributors to `cadence` server (hopefully that's you!)

**Note:** All contributors also need to fill out the [Uber Contributor License Agreement](http://t.uber.com/cla) before we can merge in any of your changes

## Development Environment

* Go. Install on OS X with `brew install go`.
* `thrift`. Install on OS X with `brew install thrift`)
* `thrift-gen`. Install with `go get github.com/uber/tchannel-go/thrift/thrift-gen`

## Checking out the code

Make sure the repository is cloned to the correct location:

```bash
go get github.com/uber/cadence/...
cd $GOPATH/src/github.com/uber/cadence
```

## Dependency management

Dependencies are tracked via `glide.yaml`. If you're not familiar with `glide`,
read the [docs](https://github.com/Masterminds/glide#usage).

## Licence headers

This project is Open Source Software, and requires a header at the beginning of
all source files. To verify that all files contain the header execute:

```bash
make copyright
```

## Commit Messages

Overcommit adds some requirements to your commit messages. At Uber, we follow the
[Chris Beams](http://chris.beams.io/posts/git-commit/) guide to writing git
commit messages. Read it, follow it, learn it, love it.

## Building

You can compile the `cadence` service and helper tools without running test:

```bash
make bins
```

## Testing

Before running the tests you must have `cassandra` running locally:

```bash
# for OS X
brew install cassandra

# start cassandra
/usr/local/bin/cassandra
```

Run all the tests:

```bash
make test
```
57 changes: 38 additions & 19 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,27 +1,46 @@
cadence
==============
[Cadence](https://eng.uber.com/) is awesome!
# Cadence

Developing
----------
Cadence is a distributed, scalable, durable, and highly available orchestration engine we developed at Uber Engineering to execute asynchronous long-running business logic in a scalable and resilient way.

Prerequisite:
* Make certain that `thrift` is in your path. (OSX: `brew install thrift`)
* `thrift-gen` is needed (`go get github.com/uber/tchannel-go/thrift/thrift-gen`)
* `cassandra` 3.9 is needed to run tests (OSX: `brew install cassandra`)
Business logic is modeled as workflows and activities. Workflows are the implementation of coordination logic. Its sole purpose is to orchestrate activity executions. Activities are the implementation of a particular task in the business logic. The workflow and activity implementation are hosted and executed in worker processes. These workers long-poll the Cadence server for tasks, execute the tasks by invoking either a workflow or activity implementation, and return the results of the task back to the Cadence server. Furthermore, the workers can be implemented as completely stateless services which in turn allows for unlimited horizontal scaling.

After starting cassandra, run `make` to build
The Cadence server brokers and persists tasks and events generated during workflow execution, which provides certain scalability and realiability guarantees for workflow executions. An individual activity execution is not fault tolerant as it can fail for various reasons. But the workflow that defines in which order and how (location, input parameters, timeouts, etc.) activities are executed is guaranteed to continue execution under various failure conditions.

Contributing
------------
We'd love your help in making Cadence great. If you need new API(s) to be added to our thrift files, open an issue and we will respond as fast as we can. If you want to propose new feature(s) along with the appropriate APIs yourself, open a pull request to start a discussion and we will merge it after review.
This repo contains the source code of the Cadence server. The client lib you can use to implement workflows, activities and worker can be found [here](https://github.com/uber-go/cadence-client).

**Note:** All contributors also need to fill out the [Uber Contributor License Agreement](http://t.uber.com/cla) before we can merge in any of your changes
## Running

Documentation
--------------
Interested in learning more about Cadence? TODO:
### Locally

* Build the required binaries following the instructions [here](CONTRIBUTING.md).

* Install and run `cassandra` locally:
```bash
# for OS X
brew install cassandra

# start cassandra
/usr/local/bin/cassandra
```

* Setup the cassandra schema:
```bash
./cadence-cassandra-tool --ep 127.0.0.1 create -k "cadence" --rf 1
./cadence-cassandra-tool --ep 127.0.0.1 -k "cadence" setup-schema -d -f ./schema/cadence/schema.cql
```

* Start the service:
```bash
./cadence
```

### Using Docker

You can also [build and run](docker/README.md) the service using Docker.

## Contributing
We'd love your help in making Cadence great. Please review our [instructions](CONTRIBUTING.md).

## License

License
-------
MIT License, please see [LICENSE](https://github.com/uber/cadence/blob/master/LICENSE) for details.

0 comments on commit 27c531e

Please sign in to comment.