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

Ability to grab all PIDs in the registry #149

Open
stevohuncho opened this issue Jan 14, 2024 · 4 comments
Open

Ability to grab all PIDs in the registry #149

stevohuncho opened this issue Jan 14, 2024 · 4 comments
Labels

Comments

@stevohuncho
Copy link

It would make things less complicated in my repos if I was able to have a couple more public functions for reading the registry. Right now only being able to get active PID info only by inputing the specific ID I'm looking for isn't too helpful for my case. I require the ability to check what the active PIDs are upon request. Using the event stream to monitor this just bloats my code by needing to create my own mapping to just replicate the privated one. I understand it is privated for mutex reasons, but if these functions could be added it would be very helpful. I have used these functions in my own code before using my fork with no issues, but I think this could be useful to others as well.

registry.go

...

func (r *Registry) GetIDs() []string {
	r.mu.RLock()
	defer r.mu.RUnlock()
	keys := make([]string, 0, len(r.lookup))
	for k := range r.lookup {
		keys = append(keys, k)
	}
	return keys
}

func (r *Registry) GetPIDs() []*PID {
	r.mu.RLock()
	defer r.mu.RUnlock()
	keys := make([]*PID, 0, len(r.lookup))
	for _, v := range r.lookup {
		keys = append(keys, v.PID())
	}
	return keys
}

...
@anthdm
Copy link
Owner

anthdm commented Jan 14, 2024

Makes sense. Let me think about this today and come up with some stuff for you.

@webfrank
Copy link

It would be a very useful addition, also a Lookup function to search for an ID

@chadleeshaw
Copy link

This would be awesome... I wanted to see how balanced the cluster had distributed the activations and could have used this implementation. In my case its probably possible to view this through Prometheus metrics or by writing a subscriber that would essentially mimic the registry. That said, this proposal is easier.

@stevohuncho
Copy link
Author

I stopped using this repo a while ago, but I recommend this Golang actor library it has had all the support I've needed.
https://github.com/asynkron/protoactor-go

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

No branches or pull requests

4 participants