{"id":18864112,"url":"https://github.com/jzillmann/tweaky","last_synced_at":"2025-07-21T18:35:46.125Z","repository":{"id":139585812,"uuid":"135615489","full_name":"jzillmann/tweaky","owner":"jzillmann","description":"Pieces of a traditional master-node cluster setup with modern technology","archived":false,"fork":false,"pushed_at":"2018-06-18T21:10:14.000Z","size":284,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-05-23T12:40:03.913Z","etag":null,"topics":["cluster-computing","dagger","grpc-java"],"latest_commit_sha":null,"homepage":null,"language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/jzillmann.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2018-05-31T17:30:33.000Z","updated_at":"2018-06-18T21:11:18.000Z","dependencies_parsed_at":null,"dependency_job_id":"4b6eb2f4-cf06-4d10-bae4-2d4b93744220","html_url":"https://github.com/jzillmann/tweaky","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/jzillmann/tweaky","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jzillmann%2Ftweaky","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jzillmann%2Ftweaky/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jzillmann%2Ftweaky/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jzillmann%2Ftweaky/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/jzillmann","download_url":"https://codeload.github.com/jzillmann/tweaky/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jzillmann%2Ftweaky/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":266352840,"owners_count":23915826,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-07-21T11:47:31.412Z","response_time":64,"last_error":null,"robots_txt_status":null,"robots_txt_updated_at":null,"robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["cluster-computing","dagger","grpc-java"],"created_at":"2024-11-08T04:39:41.317Z","updated_at":"2025-07-21T18:35:46.109Z","avatar_url":"https://github.com/jzillmann.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Tweaky\n\nPieces of a traditional master-node cluster setup with modern technology.\n\n## Build\n\n- `./gradlew generateProto` - Generate protbuf sources\n- `./gradlew cleanEclipse eclipse` - Create Eclipse files\n\n\n## TODO\n\n- √GRPC sample\n- √Logging\n- √NodeRegistrationValidator\n- √Junit5 ExternalResource\n- √Implement Node registration\n- √Dagger example\n- Remove log4j impl from pom.xml\n- NodeAcceptor\n- Dagger for nodes\n- Push node-name to node\n- Convert Node/Conductor into pure GRPC services (with proto files, Component \u0026 Component.Builder interfaces ?)\n    - stuff like serverServices() would come out of the GRPC module\n    - Think about how that influence advanced stuff like node communication (strategies), listener, event-bus, etc...\n\n## Thoughts\n\n- Example projects:\n   - Distributed Map\n   - Task Queue\n- Node Role Support\n   - Conductor assigns role(s) to node on registration\n   - Node starts services based on roles\n- Services\n    - Monitoring\n    - Monitoring-UI\n- Utils\n    - CallTracing (from client, to conductor including all node calls. Use metadata. Check https://github.com/grpc-ecosystem/grpc-opentracing)\n    - Profiling (custom for apps. just have generic proto files available. Nodes can track their individual work steps)","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjzillmann%2Ftweaky","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fjzillmann%2Ftweaky","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjzillmann%2Ftweaky/lists"}