Every time fabric runs, it asks for root password, can it be sent along same for automated proposes.
fab staging test
Every time fabric runs, it asks for root password, can it be sent along same for automated proposes.
fab staging test
fab -h
will show you all the options, you can also read them here.
In particular, and I quote,
-p PASSWORD, --password=PASSWORD
Sets env.password to the given string; it will then be used as the default password when making SSH connections or calling the sudo program.
I know you've asked about password but wouldn't it better to configure the system so that you can doing fabric (i.e. SSH) without password?
For this, on local machine do:
ssh-keygen
and agree with all defaults (if you have no reasons do otherwise)cat ~/.ssh/id_rsa.pub
and copy that keyOn remote machine:
mkdir ~/.ssh && chmod 700 ~/.ssh
touch ~/.ssh/authorized_keys2 && chmod 600 ~/.ssh/authorized_keys2
authorized_keys2
From now your remote machine “trusts” your local machine and allows logging it in without password. Handy.
ssh-copy-id
Usage: /usr/bin/ssh-copy-id [-i [identity_file]] [user@]machine –
Deutschland fab -h
will show you all the options, you can also read them here.
In particular, and I quote,
-p PASSWORD, --password=PASSWORD
Sets env.password to the given string; it will then be used as the default password when making SSH connections or calling the sudo program.
You can also set passwords on a per host basis. It wasn't obvious to me, so here it goes for anyone looking for this:
from fabric import env
env.hosts = ['user1@host1:port1', '[email protected]']
env.passwords = {'user1@host1:port1': 'password1', '[email protected]': 'password2'}
Fabric caches used passwords in the env.passwords dictionary. It sets this cache using the full hosts string as key of that dictionary and the password as the value. If you set this dictionary yourself before executing any task, Fabric won't ask for them at all.
env.hosts
. Got me –
Othilie It's also possible to set ssh password in connect_args
conn = Connection(
"{username}@{ip}:{port}".format(
username=username,
ip=ip,
port=port,
),
connect_kwargs={"password": password},
)
connect_kwargs.password
notation in the docs was confusing me. –
Carbaugh Just to add for anyone who winds up here from a search, you can specify the -I
option when running fab for it to prompt you for a default password to use. This way it won't be visible in your command history
example:
$ fab -I my_task
Initial value for env.password:
One way to do this without putting the password in the process list (commands show up in ps aux) is to put it in the fabfile.py like so:
from fabric.context_managers import env
env.password = 'PASSWORD'
Put that before anything that goes to the remote system and it won't ask for a password anymore.
from fabric import env
–
Clarinda from fabric.context_managers import env
–
Mcalpine It is possible to store the password securely in the operating system keyring service with the keyring module, the password can then be automatically retrieved and used in fabfile.py
.
You first need to store the password in the keyring, for example using the Python shell:
>>> import keyring
>>> keyring.set_password('some-host', 'some-user', 'passwd')
Then you can use it in fabfile.py
, for example with Fabric 2:
from fabric import task
import keyring
@task
def restart_apache(connection):
connection.config.sudo.password = keyring.get_password(connection.host, 'some-user')
connection.sudo('service apache2 restart')
You can also pass a default password into a Connection
or Group
using connect_kwargs
. For example:
group = ThreadingGroup(*servers, connect_kwargs={
'password': getpass('SSH password: '),
})
group.run(command)
© 2022 - 2024 — McMap. All rights reserved.