# Java

The [`fluent-logger-java`](http://github.com/fluent/fluent-logger-java) library is used to post records from Java applications to Fluentd.

This article explains how to use it.

## Prerequisites

* Basic knowledge of Java
* Basic knowledge of Fluentd
* Java 7 or higher

## Installing Fluentd

Please refer to the following document to install Fluentd:

* [Installation](https://docs.fluentd.org/installation)

## Modifying the Config File

Configure Fluentd to use the [`forward`](https://docs.fluentd.org/input/forward) input plugin as its data source:

```
<source>
  @type forward
  port 24224
</source>
<match fluentd.test.**>
  @type stdout
</match>
```

Restart agent after configuring.

```
# for rpm/deb only
$ sudo /etc/init.d/td-agent restart

# or systemd
$ sudo systemctl restart td-agent.service
```

## Using `fluent-logger-java`

Add the following dependency configuration to `pom.xml`. The logger's revision information can be found in [CHANGES.txt](https://github.com/fluent/fluent-logger-java/blob/master/CHANGES.txt):

```
<dependencies>
  ...
  <dependency>
    <groupId>org.fluentd</groupId>
    <artifactId>fluent-logger</artifactId>
    <version>${logger.version}</version>
  </dependency>
  ...
</dependencies>
```

Here's a sample Java test application:

```
import java.util.HashMap;
import java.util.Map;
import org.fluentd.logger.FluentLogger;

public class Main {
    private static FluentLogger LOG = FluentLogger.getLogger("fluentd.test");

    public void doApplicationLogic() {
        // ...
        Map<String, Object> data = new HashMap<String, Object>();
        data.put("from", "userA");
        data.put("to", "userB");
        LOG.log("follow", data);
        // ...
    }
}
```

More information on the Java API can be found [here](https://github.com/fluent/fluent-logger-java).

Executing the above program will send the logs to Fluentd:

```
$ java -jar test.jar
```

The logs should be output to `/var/log/td-agent/td-agent.log` or the standard output of the Fluentd process via [`stdout`](https://docs.fluentd.org/output/stdout) output plugin.

## Production Deployments

### Output Plugins

Various [output plugins](https://docs.fluentd.org/output) are available for writing records to other destinations:

* Examples
  * [Store Apache Logs into Amazon S3](https://docs.fluentd.org/how-to-guides/apache-to-s3)
  * [Store Apache Logs into MongoDB](https://docs.fluentd.org/how-to-guides/apache-to-mongodb)
  * [Data Collection into HDFS](https://docs.fluentd.org/how-to-guides/http-to-hdfs)
* List of Plugin References
  * [Output to Another Fluentd](https://docs.fluentd.org/output/forward)
  * [Output to MongoDB](https://docs.fluentd.org/output/mongo) or [MongoDB ReplicaSet](https://docs.fluentd.org/output/mongo_replset)
  * [Output to Hadoop](https://docs.fluentd.org/output/webhdfs)
  * [Output to File](https://docs.fluentd.org/output/file)
  * [etc...](http://fluentd.org/plugin/)

### High-Availability Configurations of Fluentd

For high-traffic websites (more than 5 application nodes), we recommend using the high-availability configuration for `td-agent`. This will improve the reliability of data transfer and query performance.

* [High-Availability Configurations of Fluentd](https://docs.fluentd.org/deployment/high-availability)

### Monitoring

Monitoring Fluentd itself is also important. The article below describes the general monitoring methods for `td-agent`:

* [Monitoring Fluentd](https://docs.fluentd.org/monitoring-fluentd/overview)

If this article is incorrect or outdated, or omits critical information, please [let us know](https://github.com/fluent/fluentd-docs-gitbook/issues?state=open). [Fluentd](http://www.fluentd.org/) is an open-source project under [Cloud Native Computing Foundation (CNCF)](https://cncf.io/). All components are available under the Apache 2 License.
