Menu Docs

Página inicial do DocsDesenvolver aplicaçõesManual do MongoDB

cursor.readPref()

Nesta página

  • Definição
  • Exemplos
cursor.readPref(mode, tagSet, hedgeOptions)

Importante

Método mongosh

Esta página documenta um método mongosh . Esta não é a documentação para um driver específico de idioma, como Node.js.

Para drivers de API do MongoDB, consulte a documentação do driver MongoDB específica do idioma.

Anexar readPref() a um cursor para controlar como o cliente roteia a query para membros do conjunto de réplicas.

Observação

Você deve aplicar readPref() ao cursor antes de recuperar quaisquer documentos do banco de dados.

Parâmetro
Tipo
Descrição
Modo
string
matriz de documentos

Opcional. Um conjunto de tags usado para direcionar leituras para membros com as tags especificadas. tagSet is not available if using primary.

Para obter detalhes, consulte Listas de conjuntos de tags de read preference.

documento

Opcional. Um documento que especifica se deve permitir o uso de leituras com hedge.

{ enabled: <boolean> }

O campo enabled é padronizado como verdadeiro; ou seja, especificar um documento vazio { } é equivalente a especificar { enabled: true }.

Leituras distribuídas estão disponíveis para clusters fragmentados. Para usar leituras com hedge, o mongos deve ter enabled support para leituras com hedge (o padrão) e as preferências de leitura nãoprimary devem permitir o uso de leituras com hedge.

A preferência de leitura nearest permite o uso de leituras protegidas em clusters fragmentados por padrão; ou seja, por padrão, tem { enabled: true }.

readPref() não é compatível com a opção read preference maxStalenessSeconds para read preference.

A seguinte operação utiliza o modo de read preference para direcionar a leitura para um nó secundário.

db.collection.find({ }).readPref( "secondary")

Para segmentar secundários com tags específicas, inclua o modo e a array tagSet :

db.collection.find({ }).readPref(
"secondary",
[
{ "datacenter": "B" }, // First, try matching by the datacenter tag
{ "region": "West"}, // If not found, then try matching by the region tag
{ } // If not found, then use the empty document to match all eligible members
]
)

Durante o processo de seleção secundário, o MongoDB tenta encontrar membros secundários com a tag datacenter: "B" primeiro.

  • Se encontrado, o MongoDB limita os secundários elegíveis àqueles com a marcação datacenter: "B" e ignora as marcações restantes.

  • Se nenhum for encontrado, o MongoDB tentará encontrar membros secundários com a tag "region": "West" .

    • Se encontrado, o MongoDB limita os secundários elegíveis àqueles com a marcação "region": "West" .

    • Se nenhum for encontrado, o MongoDB usará todos os secundários elegíveis.

Consulte Ordem da correspondência de tags para obter detalhes.

Dica

Para clusters fragmentados, você pode habilitar leituras protegidas para preferências de leitura não primárias. Para usar leituras com hedge, o mongos deve ter enabled support para leituras com hedge (o padrão) e as preferências de leitura nãoprimary devem permitir o uso de leituras com hedge.

Para direcionar secundários em clusters fragmentados usando leituras com hedge, inclua o modo e as opções de hedge, como nos exemplos a seguir:

  • Sem um conjunto de tags

    db.collection.find({ }).readPref(
    "secondary", // mode
    null, // tag set
    { enabled: true } // hedge options
    )
  • Com um conjunto de tags

    db.collection.find({ }).readPref(
    "secondary", // mode
    [ { "datacenter": "B" }, { } ], // tag set
    { enabled: true } // hedge options
    )
← cursor.readConcern()

Nesta página