LocalAI/.github/workflows
Ettore Di Giacinto fdb45153fe
feat(llama.cpp): Totally decentralized, private, distributed, p2p inference (#2343)
* feat(llama.cpp): Enable decentralized, distributed inference

As https://github.com/mudler/LocalAI/pull/2324 introduced distributed inferencing thanks to
@rgerganov implementation in https://github.com/ggerganov/llama.cpp/pull/6829 in upstream llama.cpp, now
it is possible to distribute the workload to remote llama.cpp gRPC server.

This changeset now uses mudler/edgevpn to establish a secure, distributed network between the nodes using a shared token.
The token is generated automatically when starting the server with the `--p2p` flag, and can be used by starting the workers
with `local-ai worker p2p-llama-cpp-rpc` by passing the token via environment variable (TOKEN) or with args (--token).

As per how mudler/edgevpn works, a network is established between the server and the workers with dht and mdns discovery protocols,
the llama.cpp rpc server is automatically started and exposed to the underlying p2p network so the API server can connect on.

When the HTTP server is started, it will discover the workers in the network and automatically create the port-forwards to the service locally.
Then llama.cpp is configured to use the services.

This feature is behind the "p2p" GO_FLAGS

Signed-off-by: Ettore Di Giacinto <mudler@localai.io>

* go mod tidy

Signed-off-by: Ettore Di Giacinto <mudler@localai.io>

* ci: add p2p tag

Signed-off-by: Ettore Di Giacinto <mudler@localai.io>

* better message

Signed-off-by: Ettore Di Giacinto <mudler@localai.io>

---------

Signed-off-by: Ettore Di Giacinto <mudler@localai.io>
2024-05-20 19:17:59 +02:00
..
disabled feat(conda): conda environments (#1144) 2023-11-04 15:30:32 +01:00
bump_deps.yaml build(deps): bump peter-evans/create-pull-request from 5 to 6 (#2005) 2024-04-11 13:58:04 +00:00
bump_docs.yaml build(deps): bump peter-evans/create-pull-request from 5 to 6 (#2005) 2024-04-11 13:58:04 +00:00
checksum_checker.yaml ci: get latest git version 2024-05-09 11:33:16 +02:00
dependabot_auto.yml build(deps): bump dependabot/fetch-metadata from 2.0.0 to 2.1.0 (#2186) 2024-04-29 21:12:37 +00:00
generate_grpc_cache.yaml fix: bring everything onto the same GRPC version to fix tests (#2199) 2024-04-30 19:12:15 +00:00
image_build.yml fix: bring everything onto the same GRPC version to fix tests (#2199) 2024-04-30 19:12:15 +00:00
image-pr.yml feat: update ROCM and use smaller image (#2196) 2024-05-03 18:46:49 +02:00
image.yml feat: update ROCM and use smaller image (#2196) 2024-05-03 18:46:49 +02:00
labeler.yml fix(seed): generate random seed per-request if -1 is set (#1952) 2024-04-03 22:25:47 +02:00
localaibot_automerge.yml fix - correct checkout versions (#2029) 2024-04-13 19:01:17 +02:00
release.yaml feat(llama.cpp): Totally decentralized, private, distributed, p2p inference (#2343) 2024-05-20 19:17:59 +02:00
secscan.yaml build(deps): bump github/codeql-action from 2 to 3 (#2041) 2024-04-15 22:02:44 +00:00
test-extra.yml add openvoice backend (#2334) 2024-05-19 16:27:08 +02:00
test.yml feat: auto select llama-cpp cuda runtime (#2306) 2024-05-14 19:40:18 +02:00
update_swagger.yaml ci: add swagger pipeline 2024-04-25 15:11:01 +02:00
yaml-check.yml Update yaml-check.yml 2024-04-25 16:05:02 +02:00