Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature : Support Nomad Task API #3

Closed
henrikjohansen opened this issue Jun 4, 2024 · 9 comments
Closed

Feature : Support Nomad Task API #3

henrikjohansen opened this issue Jun 4, 2024 · 9 comments

Comments

@henrikjohansen
Copy link

henrikjohansen commented Jun 4, 2024

Nomad's Task API provides every task managed by Nomad with a Unix Domain Socket (UDS) to access the local agent's HTTP API. Regardless of agent configuration the Task API does not require mTLS, but always requires authentication.

This would make it much easier when working with an mTLS enabled cluster 😇 and IIRC only requires a newer version of the Nomad API client.

https://developer.hashicorp.com/nomad/api-docs/task-api
hashicorp/nomad#16872

@apollo13
Copy link
Contributor

@henrikjohansen My PR #4 should provide support for what you requested. I haven't tested it on a cluster yet, but maybe you can build the docker file and test it?

blinkinglight added a commit that referenced this issue Aug 15, 2024
Upgrade nomad api package to support unix domain sockets. Fixes #3
@blinkinglight
Copy link
Contributor

blinkinglight commented Aug 15, 2024

you could try this build from main branch ghcr.io/ituoga/coredns-nomad:main

@blinkinglight blinkinglight reopened this Aug 15, 2024
@henrikjohansen
Copy link
Author

@blinkinglight Something seems off, running the above image I get unsupported protocol scheme "unix" ...

service.nomad.:1053
CoreDNS-1.11.3
linux/amd64, go1.21.13, c742ec03f-dirty
[DEBUG] plugin/nomad: Looking up record for svc: dns namespace: default
[ERROR] plugin/nomad: getClientfailed querying self endpoint: Get "unix:///v1/agent/self?namespace=platform®ion=global": unsupported protocol scheme "unix"
[INFO] 172.19.92.116:64739 - 57057 "A IN dns.default.service.nomad. udp 54 false 4096" NOERROR qr,aa,rd 43 0.00034716s

The corresponding Corefile is :

service.nomad.:1053 {
    errors
    debug
    health
    log
    nomad {
      zone service.nomad
      address unix:///secrets/api.sock
      ttl 10
    }
}

@apollo13
Copy link
Contributor

@henrikjohansen Could you try without address, and set NOMAD_ADDR as env var instead (though I think nomad might do that by default?)

@apollo13
Copy link
Contributor

So I just tried this locally via a manually built coredns and it did work, I wonder if something is wonky with the build process so that it fetched the wrong nomad api client?

@apollo13
Copy link
Contributor

#5 has a working readme for the task api. I also fixed the Dockerfile so you can easily build this locally and test (till @blinkinglight merged it). I just verified it on a test machine.

@blinkinglight
Copy link
Contributor

blinkinglight commented Dec 1, 2024

api.sock requires token .
token [token]
address unix:///secrets/api.sock
and it works. ( just tested with 1.9.3 nomad )

@apollo13
Copy link
Contributor

apollo13 commented Dec 1, 2024 via email

@blinkinglight
Copy link
Contributor

that works too. thank you @apollo13

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants