mongoengine上的多连接..给我一些例子~

发布于 2024-12-26 12:49:08 字数 381 浏览 2 评论 0原文

我将 mongoengine 与 django 一起使用。

在我的项目Web应用程序中,我需要连接至少两台服务器:一台用于会话本地服务器,另一台连接到mongolab(mongodb托管服务公司)。

所以..我需要连接本地主机进行会话..同时连接到远处的另一台服务器。

如何在 mongoengine 上实现多个连接?

请给我一些例子。


a Web application   --- connecting ---> localhost for session
                    --- connecting ---> mongolab for application database

I'm using mongoengine with django.

in my project web application, I need to connect at least two servers: one that is local for session, another connecting to mongolab (mongodb hosting service company).

So.. I need to connect localhost for session.. while connecting to another server in distance.

How can I implement multiple connections on mongoengine?

give me some examples please.


a Web application   --- connecting ---> localhost for session
                    --- connecting ---> mongolab for application database

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

终难遇 2025-01-02 12:49:08

根据 mongoengine 文档,要使用多个数据库,您可以使用 connect() 并为连接提供一个别名。在后台,它使用 register_connection() 来存储数据,如果需要,您可以预先注册所有别名。

connect(alias='user-db-alias', db='user-db')
connect(alias='book-db-alias', db='book-db')
connect(alias='users-books-db-alias', db='users-books-db')

class User(Document):
    name = StringField()

    meta = {'db_alias': 'user-db-alias'}

class Book(Document):
    name = StringField()

    meta = {'db_alias': 'book-db-alias'}

class AuthorBooks(Document):
    author = ReferenceField(User)
    book = ReferenceField(Book)

    meta = {'db_alias': 'users-books-db-alias'}

您还可以使用 switch_db() 方法。

函数disconnect()可用于断开特定连接。这可用于全局更改连接:

from mongoengine import connect, disconnect
connect('a_db', alias='db1')

class User(Document):
    name = StringField()
    meta = {'db_alias': 'db1'}

disconnect(alias='db1')

connect('another_db', alias='db1')

Depending on mongoengine documentation, to use multiple databases you can use connect() and provide an alias name for the connection. In the background this uses register_connection() to store the data and you can register all aliases up front if required.

connect(alias='user-db-alias', db='user-db')
connect(alias='book-db-alias', db='book-db')
connect(alias='users-books-db-alias', db='users-books-db')

class User(Document):
    name = StringField()

    meta = {'db_alias': 'user-db-alias'}

class Book(Document):
    name = StringField()

    meta = {'db_alias': 'book-db-alias'}

class AuthorBooks(Document):
    author = ReferenceField(User)
    book = ReferenceField(Book)

    meta = {'db_alias': 'users-books-db-alias'}

You can also use switch_db() method.

The function disconnect() can be used to disconnect a particular connection. This can be used to change a connection globally:

from mongoengine import connect, disconnect
connect('a_db', alias='db1')

class User(Document):
    name = StringField()
    meta = {'db_alias': 'db1'}

disconnect(alias='db1')

connect('another_db', alias='db1')
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文