{"id":30440176,"url":"https://github.com/yagotome/rpc-distributed-chat","last_synced_at":"2025-08-23T05:42:51.242Z","repository":{"id":217640935,"uuid":"147102271","full_name":"yagotome/rpc-distributed-chat","owner":"yagotome","description":"An RPC distributed chat","archived":false,"fork":false,"pushed_at":"2018-09-02T16:26:43.000Z","size":348,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"master","last_synced_at":"2024-01-17T17:21:46.444Z","etag":null,"topics":["chat","distributed-systems","java","rpc"],"latest_commit_sha":null,"homepage":"","language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/yagotome.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null}},"created_at":"2018-09-02T16:25:17.000Z","updated_at":"2024-01-17T17:21:48.458Z","dependencies_parsed_at":"2024-01-17T17:39:11.918Z","dependency_job_id":null,"html_url":"https://github.com/yagotome/rpc-distributed-chat","commit_stats":null,"previous_names":["yagotome/rpc-distributed-chat"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/yagotome/rpc-distributed-chat","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yagotome%2Frpc-distributed-chat","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yagotome%2Frpc-distributed-chat/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yagotome%2Frpc-distributed-chat/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yagotome%2Frpc-distributed-chat/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/yagotome","download_url":"https://codeload.github.com/yagotome/rpc-distributed-chat/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yagotome%2Frpc-distributed-chat/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":271745624,"owners_count":24813513,"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-08-23T02:00:09.327Z","response_time":69,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","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":["chat","distributed-systems","java","rpc"],"created_at":"2025-08-23T05:42:50.423Z","updated_at":"2025-08-23T05:42:51.194Z","avatar_url":"https://github.com/yagotome.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"# RMI Group Chat\n\nEste projeto implementa um sistema distribuído de chat de grupo com java RMI e sockets.\n\n![Running application](imgs/running.png)\n\n## Definição do sistema distribuído\n\nO sistema é escalável em uma rede com suporte a multicast. Ele é composto por uma quantidade variada de nós, que pode ser ajustada de acordo com a demanda.\n\nCada nó do sistema distribuído tem:\n* Um host rodando RMIREGISTRY\n* Um host (pode ser o mesmo do RMIREGISTRY ou não) rodando o servidor da aplicação (servidor socket multicast, servidor RMI para enviar mensagens e cliente RMI para enviar mensagens recebidas do socket para os seus clientes)\n* Vários hosts rodando cliente (sistema com UI interativa, que se comunica com o servidor)\n\nAbaixo uma imagem represntando a arquitetura de um nó:\n\n![Architecture](imgs/architecture.png)\n\n## Decisões do projeto\n\nTodo endereçamento IP e portas da aplicação foram deixados em um arquivo de configuração (config.json) que é lido em runtime para flexibilidade da aplicação de rodar em diferentes hosts. Isso inclui o IP e porta do RMIREGISTRY e o IP e porta do servidor socket multicast.\n\nComo terão múltiplos servidores RMI (servidor da aplicação e os clientes), foi adotado um padrão de nome de registro no RMIREGISTRY:\n* Servidor da aplicação tem o nome MessageServer\n* Cada cliente pede um _username_ ao usuário ao iniciar a aplicação e usa esse nome no seguinte padrão: MessageClient_\\\u003c_username_\\\u003e\n\nPara o servidor socket multicast enviar uma mensagem recebida para todos os seus clientes, ele lista todos os registros do RMIREGISTRY e manda para todos excluindo o seu próprio (_MessageServer_).\n\nDessa forma, vale lembrar que apenas um, e exatamente um, servidor da aplicação deve estar rodando em um nó do sistema distribuído.\n\n## Instruções para rodar\n\nO projeto foi feito em Java 8 com Maven.\n\nPara rodar o projeto, siga os seguintes passos:\n\n### Sem maven (em ambiente linux com [make](https://linux.die.net/man/1/make))\n\n1. Cheque se você tem uma pasta \"bin/dependencies\" com as dependências do projeto. Caso não, crie-a!\n\n2. (Opcional) Rebuildar a partir do código-fonte:\n```\n$ make clean-build\n```\n\n3. Startar rmiregistry (A porta 9925 será usada. Está definida no arquivo config.json e Makefile):\n```\n$ make run-rmiregistry\n```\n\n4. Rodar servidor (arquivo config.json deve estar definido na pasta corrente):\n```\n$ make run-server\n```\n\n5. Rodar o cliente (em outro terminal):\n```\n$ make run-client\n```\n\n### Usando Maven\n\n1. Buildar o projeto:\n```\n$ mvn clean install\n```\n\n2. Setar classpath para o JAR gerado pelo maven em target:\n```\n$ export CLASSPATH=target/rmi-group-chat-1.0-SNAPSHOT.jar\n```\n\n3. Startar rmiregistry (9925 é a porta que está no arquivo config.json):\n```\n$ rmiregistry 9925 \u0026\n```\n\n4. Rodar servidor:\n```\n$ java rmigroupchat.rmi.MessageServer\n```\n\n5. Rodar o cliente (em outro terminal, lembrar de setar o classpath):\n```\n$ java rmigroupchat.rmi.MessageClient\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fyagotome%2Frpc-distributed-chat","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fyagotome%2Frpc-distributed-chat","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fyagotome%2Frpc-distributed-chat/lists"}