-
Notifications
You must be signed in to change notification settings - Fork 14
Home
Starting with version 2.2.2, you can replace log4j with any logger that has an slf4j binding. For example, to use slf4j-simple, declare your dependencies as shown below.
compile ("com.emc.ecs:object-client:3.1.3") {
exclude group: 'org.slf4j', module: 'slf4j-log4j12'
}
runtime "org.slf4j:slf4j-simple:1.7.5"
<dependency>
<groupId>com.emc.ecs</groupId>
<artifactId>object-client</artifactId>
<version>3.1.3</version>
<scope>compile</scope>
<exclusions>
<exclusion>
<artifactId>slf4j-log4j12</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-simple</artifactId>
<version>1.7.5</version>
<scope>runtime</scope>
</dependency>
Group | Artifact | Version |
---|---|---|
com.emc.ecs |
object-client |
3.1.3 |
There are two ways to use the client: with or without the "Smart Client". If your system has a traditional load balancer set up behind a VIP, then use the URI constructor of S3Config. Note that virtual-host-style requests (where bucket.namespace is prepended to the host) are not enabled by default. To enable this, call setUseVHost(true).
If you want to use the software load balancer built-in to the client and have direct access to all the ECS nodes by IP, then use the alternate constructors of S3Config and the smart client will use the hosts you provide to discover all the ECS node IPs and load balance across them automatically.
S3Config config;
// with load balancer (and corresponding baseUrl/DNS setup)
config = new S3Config(new URI("https://s3.mycompany.com"));
// if you use virtual-host-style requests:
config.setUseVHost(true);
// client-side load balancing (direct to individual nodes)
// single VDC
config = new S3Config(Protocol.HTTP, NODE_IP1, NODE_IP2);
// multiple VDCs
config = new S3Config(Protocol.HTTP, new Vdc("Boston", VDC1_NODE1, VDC1_NODE2),
new Vdc("Seattle", VDC2_NODE1, VDC2_NODE2));
// to enable geo-pinning (hashes the object key and pins it to a specific VDC)
config.setGeoPinningEnabled(true);
config.withIdentity(S3_ACCESS_KEY_ID).withSecretKey(S3_SECRET_KEY);
S3Client s3Client = new S3JerseyClient(config);
Be sure to close each client instance when you are done using it. There is a background thread associated with the smart-client, and potentially other resources that need to be cleaned up when the client shuts down. You can do this by using the client in a try-with-resources block:
try (S3Client s3 = new S3JerseyClient(s3Config)) {
// execute S3 operations...
}
... or by explicitly calling destroy()
:
// close() method on some arbitrary component that owns an S3 client
public void close() {
try {
if (s3Client != null) s3Client.destroy();
} catch (Exception e) {
log.warn("could not destroy S3 client", e);
}
super.close();
}
In high throughput environments (10GbE+), the apache client can be a bottleneck. To maximize performance in these situations, you can configure the client to use HttpURLConnection instead by using the optional constructor
// you need to increase Java's connection pool limits if you have more than 5 threads
System.setProperty("http.maxConnections", "100");
S3Client s3Client = new S3JerseyClient(config, new URLConnectionClientHandler());
Note that this handler does not support Expect: 100-Continue behavior if that is important to you. However, we have witnessed a 5x throughput increase with a simultaneous .5x CPU load using this handler.