:toc:
= JGroups AWS – S3_PING
Projects JGroups AWS provides an implementation of S3_PING
discovery protocol using AWS S3 buckets as cluster information store.
It is based on the original code written by Tobias Sarnowski at Zalando.
footnote:[https://libraries.io/github/zalando/jgroups-native-s3-ping]
footnote:[https://github.com/jwegne/jgroups-native-s3-ping]
It uses the official AWS SDK footnote:[http://docs.aws.amazon.com/AmazonS3/latest/dev/UsingTheMPDotJavaAPI.html] and does not implement the HTTP protocol on its own. The benefit is a more stable connection as well as usage of IAM server profiles and AWS standardized credential distribution.
== Maven Coordinates
== Protocol Configuration
This library implements a JGroups discovery protocol which replaces protocols like MPING
or TCPPING
.
// TODO: move this to configuration with other props
The aws.S3_PING
automatically registers itself to JGroups with the magic number 789
.
You can overwrite this by setting the system property s3ping.magic_number
to different number, e.g. -Ds3ping.magic_number=123
.
=== Possible Configurations
// TODO change this to table format
=== Example Stack
// TODO update the sample protocol stack with jgroups 5.3.x default
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="urn:org:jgroups" xsi:schemaLocation="urn:org:jgroups http://www.jgroups.org/schema/jgroups.xsd"> <TCP bind_port="7800" recv_buf_size="${tcp.recv_buf_size:5M}" send_buf_size="${tcp.send_buf_size:5M}" max_bundle_size="64K" thread_pool.enabled="true" thread_pool.min_threads="2" thread_pool.max_threads="8" thread_pool.keep_alive_time="5000"/>
<aws.S3_PING region_name="eu-west-1"
bucket_name="jgroups-s3-test"
bucket_prefix="jgroups"/>
<MERGE3 min_interval="10000"
max_interval="30000"/>
<FD_SOCK/>
<FD_ALL timeout="30000" interval="5000"/>
<VERIFY_SUSPECT timeout="1500"/>
<pbcast.NAKACK2 use_mcast_xmit="false"
discard_delivered_msgs="true"/>
<UNICAST3/>
<pbcast.STABLE stability_delay="1000" desired_avg_gossip="50000"
max_bytes="4M"/>
<pbcast.GMS print_local_addr="true" join_timeout="2000"
view_bundling="true"/>
<MFC max_credits="2M"
min_threshold="0.4"/>
<FRAG2 frag_size="60K"/>
== Testing
Running the automated tests requires having AWS credentials setup with appropriate permissions along with setting the region name and a bucket name.
If any of the required properties are not specified tests will be skipped (uses org.junit.Assume
).
In case credentials are not provided and running on Linux, tests will be run against mock containerized S3 instance. These require a functioning podman or Docker environment.
== Reporting Issues
Project JGroups AWS uses GitHub Issues for tracking:
https://github.com/jgroups-extras/jgroups-aws/issues
== Support Matrix
|=== |Version (branch) |JGroups version |AWS SDK
|main
|5.2.x - 5.3.x |2.x
|2.x
|5.2.x |1.x
|1.x
|4.2.x |1.x
|===