Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/greenpau/gosplunk
Splunk's HTTP Event Collector client library.
https://github.com/greenpau/gosplunk
Last synced: 1 day ago
JSON representation
Splunk's HTTP Event Collector client library.
- Host: GitHub
- URL: https://github.com/greenpau/gosplunk
- Owner: greenpau
- License: apache-2.0
- Created: 2018-08-07T16:00:43.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-12-02T03:08:24.000Z (about 6 years ago)
- Last Synced: 2024-05-23T00:01:13.431Z (9 months ago)
- Language: Go
- Size: 292 KB
- Stars: 7
- Watchers: 3
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[data:image/s3,"s3://crabby-images/348dd/348dd2289a7834a920c2996d280547c14a44b96d" alt="Go Report Card"](https://goreportcard.com/report/github.com/greenpau/gosplunk) [data:image/s3,"s3://crabby-images/1488d/1488d0a5db36ee06c71c894e3470edd66197de49" alt="Build Status"](https://travis-ci.org/greenpau/gosplunk) [data:image/s3,"s3://crabby-images/c4b1b/c4b1b7ee81036f6328a9117028923a067fb79ad1" alt="Hex.pm"](https://github.com/greenpau/gosplunk)
# Golang Client Libraries for Splunk
## HTTP Event Collector Client Library
Splunk's HTTP Event Collector (HEC) is an endpoint allowing sending messages
to Splunk via RESTful API using HTTP/S transport. The endpoint identifies
its clients based on a token the clients' provide. A Splunk administrator
configures tokens under "Add Data", "HTTP Event Collector". Once configured,
the administrator provides the token to a client application.By default, the HTTP Event Collector receives data over HTTPS on TCP port 8088.
If necessary, enable HEC tokens by running the following command on the server:
```bash
curl -k -X "POST" -u admin:password https://localhost:8089/servicesNS/admin/splunk_httpinput/data/inputs/http/http/enable
```### Getting Started
If necessary, create HEC token:
data:image/s3,"s3://crabby-images/ac0cb/ac0cb890371316754b72d46a30362f50a94fc590" alt="HTTP Event Collector Tokens"
The "Input Settings" for the HEC are:
* Source Type: Automatic
* App context: Search & Reporting
* Index: `main`data:image/s3,"s3://crabby-images/5ffc3/5ffc329421fc5afccce344685010ad9c97125bad" alt="HTTP Event Collector Token Configuration"
Prior to connecting to HEC, check its availability:
```bash
echo -n | openssl s_client -showcerts -connect splunk:8088
```The expected result would look like this:
```
CONNECTED(00000003)
depth=1 C = US, ST = CA, L = San Francisco, O = Splunk, CN = SplunkCommonCA, emailAddress = [email protected]
verify error:num=19:self signed certificate in certificate chain
---
Certificate chain
0 s:/CN=SplunkServerDefaultCert/O=SplunkUser
i:/C=US/ST=CA/L=San Francisco/O=Splunk/CN=SplunkCommonCA/[email protected]
```Next, create a configuration file at `~/.splunk.hec.yaml` with the following contents:
```yaml
---
collector:
host: 'splunk'
port: 8088
token: '61876693-4758-4f45-bca7-c910ccc746eb'
```Then, compile and run this data:image/s3,"s3://crabby-images/6f56d/6f56d7f85d8d13564ce785d696392e5f3df46c92" alt="example":
```bash
make
bin/http-event-collector-client
```The expected output follows. Here, the client sends a message, plus two
event fields: `foo` and `bar`:```bash
$ bin/http-event-collector-client
DEBU[0000] splunk-http-collector-client: proto=https
DEBU[0000] splunk-http-collector-client: host=splunk
DEBU[0000] splunk-http-collector-client: port=8088
DEBU[0000] splunk-http-collector-client: token=61876693-4758-4f45-bca7-c910ccc746eb
DEBU[0000] splunk-http-collector-client: timeout=5
DEBU[0000] splunk-http-collector-client: endpoint.health=https://splunk:8088/services/collector/health
DEBU[0000] splunk-http-collector-client: endpoint.event=https://splunk:8088/services/collector/event
DEBU[0000] splunk-http-collector-client: endpoint.raw=https://splunk:8088/services/collector/raw
DEBU[0000] splunk-http-collector-client: url=https://splunk:8088/services/collector/health
DEBU[0000] splunk-http-collector-client: status=200 OK
DEBU[0000] splunk-http-collector-client: HEC is available and accepting input
DEBU[0000] splunk-http-collector-client: code=17, text=HEC is healthy
DEBU[0000] message="{ test message on 2018-08-07 09:42:03.651128622 -0400 EDT m=+0.067162200" map[foo:bar bar:foo] 0}"
DEBU[0000] splunk-http-collector-client: url=https://splunk:8088/services/collector/event
DEBU[0000] splunk-http-collector-client: status=200 OK
DEBU[0000] splunk-http-collector-client: code=0, text=Success
```Once successful, the Splunk would have the following indexed event:
data:image/s3,"s3://crabby-images/06291/06291cb38a81da65c9adc3d4f83c4aa158d41d50" alt="HTTP Event Collector Indexed Event"
### References
* [HTTP Event Collector REST API endpoints](http://docs.splunk.com/Documentation/Splunk/7.1.2/Data/HECRESTendpoints)
* [HTTP Event Collector Examples](http://docs.splunk.com/Documentation/Splunk/7.1.2/Data/HECExamples)
* [HTTP Event Collector REST API Endpoints](http://docs.splunk.com/Documentation/Splunk/7.1.2/RESTREF/RESTinput#services.2Fcollector):
* [services/collector/health](http://docs.splunk.com/Documentation/Splunk/7.1.2/RESTREF/RESTinput#services.2Fcollector.2Fhealth)
* [services/collector/event](http://docs.splunk.com/Documentation/Splunk/7.1.2/RESTREF/RESTinput#services.2Fcollector.2Fevent)