Partage des verrous entre les processus Python
Lorsque vous tentez d'utiliser un verrou entre plusieurs processus, vous pouvez rencontrer l'erreur « Les objets de verrouillage ne doivent être partagé entre les processus via l'héritage. Objet Manager et passage d'un Manager.Lock():
à partir du gestionnaire d'importation multitraitement ... m = Gestionnaire() l = m.Lock()
L'utilisation d'un gestionnaire introduit cependant la nécessité d'un processus supplémentaire pour héberger le serveur du gestionnaire et communiquer via IPC.
Passer le verrou au pool Creationfrom multiprocessing import Manager ... m = Manager() l = m.Lock()
def init(l) : verrouillage global verrouiller = l l = multitraitement.Lock() pool = multiprocessing.Pool(initializer=init, initargs=(l,))
Cette méthode rend l'instance de verrouillage globale dans tous les travailleurs enfants. Notez que cette approche élimine le besoin de fonction partielle.En employant l'une de ces techniques, vous pouvez partager efficacement les verrous entre les processus Python, permettant ainsi un accès coordonné aux ressources partagées.
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3