发布于 2015-10-05 04:16:27 | 344 次阅读 | 评论: 0 | 来源: 网络整理
Classes and subroutines dealing with network connections and related topics.
fabric.network.
disconnect_all
()¶Disconnect from all currently connected servers.
Used at the end of fab
‘s main loop, and also intended for use by
library users.
fabric.network.
HostConnectionCache
¶Dict subclass allowing for caching of host connections/clients.
This subclass will intelligently create new client connections when keys are requested, or return previously created connections instead.
It also handles creating new socket-like objects when required to implement
gateway connections and ProxyCommand
, and handing them to the inner
connection methods.
Key values are the same as host specifiers throughout Fabric: optional
username + @
, mandatory hostname, optional :
+ port number.
Examples:
example.com
- typical Internet host address.firewall
- atypical, but still legal, local host address.user@example.com
- with specific username attached.bob@smith.org:222
- with specific nonstandard port attached.When the username is not given, env.user
is used. env.user
defaults to the currently running user at startup but may be overwritten by
user code or by specifying a command-line flag.
Note that differing explicit usernames for the same hostname will result in
multiple client connections being made. For example, specifying
user1@example.com
will create a connection to example.com
, logged
in as user1
; later specifying user2@example.com
will create a new,
2nd connection as user2
.
The same applies to ports: specifying two different ports will result in
two different connections to the same host being made. If no port is given,
22 is assumed, so example.com
is equivalent to example.com:22
.
__getitem__
(key)¶Autoconnect + return connection object
__weakref__
¶list of weak references to the object (if defined)
connect
(key)¶Force a new connection to key
host string.
fabric.network.
connect
(user, host, port, cache, seek_gateway=True)¶Create and return a new SSHClient instance connected to given host.
参数: |
|
---|
fabric.network.
denormalize
(host_string)¶Strips out default values for the given host string.
If the user part is the default user, it is removed; if the port is port 22, it also is removed.
fabric.network.
disconnect_all
()Disconnect from all currently connected servers.
Used at the end of fab
‘s main loop, and also intended for use by
library users.
fabric.network.
get_gateway
(host, port, cache, replace=False)¶Create and return a gateway socket, if one is needed.
This function checks env
for gateway or proxy-command settings and
returns the necessary socket-like object for use by a final host
connection.
参数: |
|
---|---|
返回: | A |
fabric.network.
join_host_strings
(user, host, port=None)¶Turns user/host/port strings into user@host:port
combined string.
This function is not responsible for handling missing user/port strings;
for that, see the normalize
function.
If host
looks like IPv6 address, it will be enclosed in square brackets
If port
is omitted, the returned string will be of the form
user@host
.
fabric.network.
key_filenames
()¶Returns list of SSH key filenames for the current env.host_string.
Takes into account ssh_config and env.key_filename, including normalization
to a list. Also performs os.path.expanduser
expansion on any key
filenames.
fabric.network.
key_from_env
(passphrase=None)¶Returns a paramiko-ready key from a text string of a private key
fabric.network.
needs_host
(func)¶Prompt user for value of env.host_string
when env.host_string
is
empty.
This decorator is basically a safety net for silly users who forgot to specify the host/host list in one way or another. It should be used to wrap operations which require a network connection.
Due to how we execute commands per-host in main()
, it’s not possible to
specify multiple hosts at this point in time, so only a single host will be
prompted for.
Because this decorator sets env.host_string
, it will prompt once (and
only once) per command. As main()
clears env.host_string
between
commands, this decorator will also end up prompting the user once per
command (in the case where multiple commands have no hosts set, of course.)
fabric.network.
normalize
(host_string, omit_port=False)¶Normalizes a given host string, returning explicit host, user, port.
If omit_port
is given and is True, only the host and user are returned.
This function will process SSH config files if Fabric is configured to do so, and will use them to fill in some default values or swap in hostname aliases.
fabric.network.
normalize_to_string
(host_string)¶normalize() returns a tuple; this returns another valid host string.
fabric.network.
prompt_for_password
(prompt=None, no_colon=False, stream=None)¶Prompts for and returns a new password if required; otherwise, returns None.
A trailing colon is appended unless no_colon
is True.
If the user supplies an empty password, the user will be re-prompted until they enter a non-empty password.
prompt_for_password
autogenerates the user prompt based on the current
host being connected to. To override this, specify a string value for
prompt
.
stream
is the stream the prompt will be printed to; if not given,
defaults to sys.stderr
.
fabric.network.
ssh_config
(host_string=None)¶Return ssh configuration dict for current env.host_string host value.
Memoizes the loaded SSH config file, but not the specific per-host results.
This function performs the necessary “is SSH config enabled?” checks and will simply return an empty dict if not. If SSH config is enabled and the value of env.ssh_config_path is not a valid file, it will abort.
May give an explicit host string as host_string
.