Comments (4)
Hi (and thanks)
in nameko, each service "owns" its own events, so in that sense it doesn't quite make sense to talk about "the same" event from different services. However, if the apis (event data) are compatible, you can stack the entrypoint (any method can be exposed as multiple entyrpoints), e.g.
@event_handler("service_a", "event")
@event_handler("service_b", "event")
def bla(self, payload):
pass
would that do?
from nameko.
hi,
yes that's also a solution. I will use my own EventHandler to avoid code duplications.
thx,
chris
from nameko.
sure. one of our design goals is to keep things composable enough that you can replace parts to suit your exact use-case
note that the decorator
implementation you are overriding is designed to work for any entrypoint. since you have a concrete use-case, you can simplify it (e.g. cutting out the second half since an event-handler decorator always takes arguments)
from nameko.
@chassing feel free to tell me to mind my own business but I would recommend against having a custom subclass like this, for a number of reasons:
- Entrypoints were designed to stack for exactly this use-case.
- By overloading
Entrypoint.decorator
you've made your application brittle to changes in this "internal" nameko code. - (Subjective but) I don't consider multiple
@event_handler
decorators to be duplications. Each one is an explicit declaration, and having them separate will make for easier refactoring in the future. If you're listening to the same event from more than a couple of services you should consider whether your service architecture is correct. - Adding ~25 lines of complex decorator code is a lot less maintainable than "duplicating" these simple event handler declarations.
Just my 2ยข. Can you write about what your specific use-case is?
from nameko.
Related Issues (20)
- Use another augmented assignment statement HOT 1
- Check for existing key HOT 1
- Should ipython and bpython be listed in some configuration files? HOT 1
- Why using dnspython 1.x instead of 2.x ? HOT 8
- need upgrade to support python 3.10 HOT 2
- Publisher crashing when exchange is provided and RabbitMQ is down
- Nameko crashes when consuming illegal messages HOT 6
- [ DOUBT ] Events Pub / Sub - How can I make a consumer only run one event at a time
- from nameko.rpc import rpc class GreetingService: name = "greeting_service" def hello(self, name): return "Hello, {}!".format(name)
- Timer work on master process or every process? HOT 2
- dnspython dependency version overly restrictive HOT 3
- "verify_amqp_uri" in the module "nameko.amqp.utils" had been removed? HOT 2
- Should HttpRequestHandler print out the exception to the browser? HOT 2
- nameko multiprocess problem HOT 1
- Do you die? we need you to improve Nameko Library HOT 5
- DB Migrations not working with Flask-Migrate HOT 2
- Linking nameko and golang by RPC HOT 1
- dnspython version HOT 1
- nameko run faild when httpx installed
- event_handler should be agnostic to dispatching service
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
๐ Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. ๐๐๐
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google โค๏ธ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from nameko.