class SRVConnector: (source)
Constructor: SRVConnector(reactor, service, domain, factory, ...)
Implements interfaces: twisted.internet.interfaces.IConnector
A connector that looks up DNS SRV records.
RFC 2782 details how SRV records should be interpreted and selected for subsequent connection attempts. The algorithm for using the records' priority and weight is implemented in pickServer
.
Method | __init__ |
No summary |
Method | connect |
Start connection to remote server. |
Method | connection |
Undocumented |
Method | connection |
Undocumented |
Method | disconnect |
Disconnect whatever our are state is. |
Method | get |
Return destination this will try to connect to. |
Method | pick |
Pick the next server. |
Method | stop |
Stop attempting to connect. |
Instance Variable | connect |
Undocumented |
Instance Variable | connect |
Undocumented |
Instance Variable | connect |
Undocumented |
Instance Variable | connector |
Undocumented |
Instance Variable | domain |
Undocumented |
Instance Variable | factory |
Undocumented |
Instance Variable | host |
Undocumented |
Instance Variable | ordered |
List of server records that have already been tried in this round of connection attempts. |
Instance Variable | port |
Undocumented |
Instance Variable | protocol |
Undocumented |
Instance Variable | reactor |
Undocumented |
Instance Variable | servers |
List of candidate server records for future connection attempts. |
Instance Variable | service |
Undocumented |
Instance Variable | stop |
Undocumented |
Method | _cb |
Undocumented |
Method | _eb |
Undocumented |
Method | _eb |
Connect to the default port when the service name is unknown. |
Method | _really |
Undocumented |
Instance Variable | _default |
Undocumented |
Parameters | |
reactor | Undocumented |
service | Undocumented |
domain:bytes or str | The domain to connect to. If passed as a text string, it will be encoded using idna encoding. |
factory | Undocumented |
protocol | Undocumented |
connect | Undocumented |
connect | Undocumented |
connect | Undocumented |
defaultint | Optional default port number to be used when SRV lookup fails and the service name is unknown. This should be the port number associated with the service name as defined by the IANA registry. |
Pick the next server.
This selects the next server from the list of SRV records according to their priority and weight values, as set out by the default algorithm specified in RFC 2782.
At the beginning of a round, servers
is populated with orderedServers
, and the latter is made empty. servers
is the list of candidates, and orderedServers
is the list of servers that have already been tried.
First, all records are ordered by priority and weight in ascending order. Then for each priority level, a running sum is calculated over the sorted list of records for that priority. Then a random value between 0 and the final sum is compared to each record in order. The first record that is greater than or equal to that random value is chosen and removed from the list of candidates for this round.
Returns | |
tuple of native str and int | A tuple of target hostname and port from the chosen DNS SRV record. |
Connect to the default port when the service name is unknown.
If no SRV records were found, the service name will be passed as the port. If resolving the name fails with error.ServiceNameUnknownError
, a final attempt is done using the default port.