我在连接到公共数据库服务器的几个 Web 主机上运行 Django。该数据库包含一个简单的待处理作业表。例如
class Job(models.Model):
name = models.CharField(max_length=255, null=False, help_text='task to do')
worker = models.CharField(max_length=255, null=True, help_text='globally unique host name')
我将如何使用 Django 的 ORM 来查询待处理的作业(其中 worker 为空)并自动设置工作者名称,因此没有两个 Django 进程会意外地获取同一个作业(即避免竞争条件)?
理想情况下,我只想通过查询/更新在表锁中进行包装,但 Django 的 ORM 似乎没有内置此功能。