在我们的项目设置中,我们使用的是带有RabbitMQ的烧瓶和nameko。我们将它用于多个项目(我们两个月前就开始了),并且在开发时我们对服务名称有问题。
我们有两个项目--A和B,它们都有UserService (具有不同的功能):
class UserService:
name = 'user_service'
...问题是当我们需要在同一台机器上运行两个项目时,一个用户服务无法工作。准确地说,两者都是工作的,但是所有的请求都是由其中一个处理的,并且由于它们的结构不同,我们得到了错误。
第一个想法是在服务名称中添加项目前缀,比如A_user_service,但这是非常难看的解决方案(在rpc部分中,我们需要调用类似rpc.A_user_service的东西,这很糟糕)。nameko项目有什么名称空间吗?我们尝试将配置中的rpc_excange参数设置为每个项目不同,但这并不能解决我们的问题。
发布于 2016-12-29 14:34:39
我想这在一定程度上取决于你如何定义“项目”。服务名称是主要名称空间,因此,如果这两个用户服务有可能共存,它们可能应该使用不同的(可能更具体的)服务名称。
如果它们是完全独立的(例如为两个独立的客户开发),那么使用单独的rabbitmq vhost可以解决您的问题吗?这样,您将运行两个独立的服务“集群”,在vhost a中,vhost a中的任何内容都看不到或无法与vhost b中的任何内容对话(当然,如果您愿意的话,可以运行服务x实例,例如,对于在两个客户端站点/网络上运行的服务)。
https://stackoverflow.com/questions/41331198
复制相似问题