forked from argoproj/argo-events
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
docs: mixed types of events in single EventSource (argoproj#815)
* docs: mixed types of events in single EventSource * log * fix test case * comments * minor * minor again * change * update
- Loading branch information
Showing
7 changed files
with
183 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
# EventSource Deployment Strategies | ||
|
||
EventSource controller creates a k8s deployment for each EventSource object to | ||
watch the events. Some of the event source types do not allow multiple live | ||
clients with same attributes (i.e. multiple clients with same `clientID` | ||
connecting to a NATS server), or multiple event source PODs will generate | ||
duplicated events to downstream, so the deployment strategy and replica numbers | ||
are different for different event sources. | ||
|
||
## Rolling Update Strategy | ||
|
||
`Rolling Update` strategy is applied to the following EventSource types: | ||
|
||
- AWS SNS | ||
- AWS SQS | ||
- Github | ||
- Gitlab | ||
- NetApp Storage GRID | ||
- Slack | ||
- Stripe | ||
- Webhook | ||
|
||
### Replicas Of Rolling Update Types | ||
|
||
Deployment replica of these event source types respects `spec.replica` in the | ||
EventSource object, defaults to 1. | ||
|
||
## Recreate Strategy | ||
|
||
`Recreate` strategy is applied to the following EventSource types: | ||
|
||
- AMQP | ||
- Azure Events Hub | ||
- Kafka | ||
- GCP PubSub | ||
- File | ||
- HDFS | ||
- NATS | ||
- Minio | ||
- MQTT | ||
- Emitter | ||
- NSQ | ||
- Pulsar | ||
- Redis | ||
- Resource | ||
- Calendar | ||
|
||
### Replicas Of Recreate Types | ||
|
||
`spec.replica` in the `Recreate` types EventSources is ignored, the deployment | ||
is always created with `replica=1`. | ||
|
||
**Please DO NOT manually scale up the replicas, that will lead to unexpected | ||
behaviors!** |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
# EventSource Names | ||
|
||
In a Sensor object, a `dependency` is defined as: | ||
|
||
```yaml | ||
dependencies: | ||
- name: test-dep | ||
eventSourceName: webhook-example | ||
eventName: example | ||
``` | ||
The `eventSourceName` ad `eventName` might be confusing. Take the following | ||
EventSource example, the `eventSourceName` and `eventName` are described as | ||
below. | ||
|
||
```yaml | ||
apiVersion: argoproj.io/v1alpha1 | ||
kind: EventSource | ||
metadata: | ||
name: webhook-example # eventSourceName | ||
spec: | ||
webhook: | ||
example: # eventName | ||
port: "12000" | ||
endpoint: /example | ||
method: POST | ||
example-foo: # eventName | ||
port: "13000" | ||
endpoint: /example2 | ||
method: POST | ||
``` | ||
|
||
## EventSourceName | ||
|
||
`eventSourceName` is the `name` of the dependent `EventSource` object, i.e. | ||
`webhook-example` in the example above. | ||
|
||
## EventName | ||
|
||
`eventName` is the map key of a configured event. In the example above, | ||
`eventName` could be `exmaple` or `example-foo`. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
# EventSource With Multiple Events | ||
|
||
![alpha](assets/alpha.svg) | ||
|
||
> v0.17.0 and after | ||
Multiple events can be configured in a single EventSource, they can be either | ||
one event source type, or mixed event source types with some limitations. | ||
|
||
## Single EventSource Type | ||
|
||
A single type EventSource configuration: | ||
|
||
```yaml | ||
apiVersion: argoproj.io/v1alpha1 | ||
kind: EventSource | ||
metadata: | ||
name: webhook | ||
spec: | ||
webhook: | ||
example: | ||
port: "12000" | ||
endpoint: /example | ||
method: POST | ||
example-foo: | ||
port: "13000" | ||
endpoint: /example2 | ||
method: POST | ||
``` | ||
For the example above, there are 2 events configured in the EventSource named | ||
`webhook`. Please use different `port` numbers for different events, this is the | ||
limitation for multiple events configured in a `webhook` EventSource, this | ||
limitation also applies to `webhook` extended event source types such as | ||
`github`, `sns`. | ||
|
||
## Mixed EventSource Types | ||
|
||
EventSource is allowed to have mixed types of events configured. | ||
|
||
```yaml | ||
apiVersion: argoproj.io/v1alpha1 | ||
kind: EventSource | ||
metadata: | ||
name: mixed-sources | ||
spec: | ||
webhook: | ||
webhook-example: # eventName | ||
port: "12000" | ||
endpoint: /example | ||
method: POST | ||
sns: | ||
sns-example: # eventName | ||
topicArn: arn:aws:sns:us-east-1:XXXXXXXX:test | ||
webhook: | ||
endpoint: "/" | ||
port: "15000" | ||
accessKey: | ||
key: my-key | ||
name: my-name | ||
secretKey: | ||
key: my-secret-key | ||
name: my-secret-name | ||
region: us-east-1 | ||
``` | ||
|
||
However, there are some rules need to follow to do it: | ||
|
||
- `Rolling Update` types and `Recreate` types can not be configured together, | ||
see [EventSource Deployment Strategies](eventsource-deployment-strategies.md). | ||
|
||
- Event Name (i.e. `webhook-example` and `sns-example` above, refer to | ||
[EventSource Names](eventsource-names.md)) needs to be unique in the | ||
EventSource, same `eventName` is not allowed even they are in different event | ||
source types. | ||
|
||
The reason for that is, we use `eventSourceName` and `eventName` as the | ||
dependency attributes in Sensor. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters