本文整理匯總了Python中fabric.state.env.user方法的典型用法代碼示例。如果您正苦於以下問題:Python env.user方法的具體用法?Python env.user怎麽用?Python env.user使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類fabric.state.env
的用法示例。
在下文中一共展示了env.user方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: run_bench
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def run_bench(stack):
'''
Log into the RabbitMQ machine
Execute python run.py with production settings
'''
env.user = 'ubuntu'
# check if rabbit and celery started correctly
instance_dict = get_ec2_instances(stack, logical_id='RabbitAutoScaling')
execute(_verify_rabbit, hosts=instance_dict['running'])
execute(_verify_cloud_init, hosts=instance_dict['running'])
celery_instance_dict = get_ec2_instances(stack, logical_id='CeleryAutoScaling')
execute(_verify_celery, hosts=celery_instance_dict['running'])
cassandra_instance_dict = get_ec2_instances(stack, logical_id='CassandraAutoScaling')
execute(_verify_cassandra, hosts=cassandra_instance_dict['running'])
# start the actual benchmark
execute(_run_bench, hosts=instance_dict['running'])
示例2: authorizeSshKey
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def authorizeSshKey(username, sshId):
"""Add specified SSH public key to the user's ~/.ssh/authorized_keys.
If there is no such file, one will be created for the user.
@param username: The name of the user whose authorized_keys is being
updated.
@param sshId: Path to SSH public key (usually ~/.ssh/id_rsa.pub)
"""
with settings(user='ubuntu',
key_filename=os.environ['EC2_KEYPAIR_PATH']):
sshPath = os.path.join('~%s' % username, '.ssh')
sudo('mkdir -p %s' % sshPath)
sudo('chmod 700 %s' % sshPath)
sudo('chown %s:%s %s' % (username, username, sshPath))
authorizedKeysPath = os.path.join(sshPath, 'authorized_keys')
pubKey = open(sshId, 'r').readline().strip()
sudo("echo '%s' >> %s" % (pubKey, authorizedKeysPath))
sudo('chmod 600 %s' % authorizedKeysPath)
sudo('chown %s:%s %s' % (username, username, authorizedKeysPath))
示例3: addAdmin
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def addAdmin(username, sshId, user, identity):
"""Add a user with admin privileges to an Ubuntu server.
@param username: The name of the new user.
@param sshId: Path to SSH public key (usually ~/.ssh/id_rsa.pub)
@param user: Optionally, the user to connect as.
@param identity: Optionally, the SSH identity to use when connecting.
"""
if identity:
env.key_filename = identity
if user:
env.user = user
sudo('adduser --disabled-password --gecos ",,," %s' % username)
sudo('usermod -p "" %s' % username)
sudo('chage -d 0 %s' % username)
sudo('gpasswd --add %s admin' % username)
authorizeSshKey(username, sshId)
示例4: prepareInstance
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def prepareInstance(username, sshId):
"""Prepare an instance updating the packages and creating a new user.
@param username: The name of the new user.
@param sshId: Path to SSH public key (usually ~/.ssh/id_rsa.pub)
"""
print os.environ['EC2_KEYPAIR_PATH']
with settings(user='ubuntu',
key_filename=os.environ['EC2_KEYPAIR_PATH']):
password = getpass('Enter a new password for user %s:' % username)
password2 = getpass('Enter the password a again:')
if password != password2:
raise RuntimeError("Passwords don't match")
sudo('adduser --disabled-password --gecos ",,," %s' % username)
cryptedPassword = _hashPassword(password)
sudo('usermod --password %s %s' % (cryptedPassword, username))
sudo('gpasswd --add %s admin' % username)
authorizeSshKey(username, sshId)
sudo('apt-get update')
sudo('DEBIAN_FRONTEND=noninteractive apt-get dist-upgrade -y')
if exists('/var/run/reboot-required'):
reboot()
示例5: applyDatabasePatches
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def applyDatabasePatches(deploymentPath, revision):
"""Apply database patches.
The PostgreSQL database will be backed up before patches are applied,
which means this could potentially take some time to run.
@param deploymentPath: The path to deploy Fluidinfo in.
@param revision: The C{str} revision of the branch being deployed.
"""
path = os.path.join(deploymentPath, revision, 'fluidinfo')
postgresBackupScript = os.path.join(deploymentPath, revision,
'scripts', 'backup-postgresql.sh')
with cd(path):
with settings(warn_only=True):
sudo('killall psql', user='postgres')
logging.info('Backing up the Postgres database.')
sudo(postgresBackupScript, user='postgres')
sudo('bin/python bin/fluidinfo '
'patch-database postgres:///fluidinfo', user='fluidinfo')
示例6: _set_stage
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def _set_stage(stage_name='test'):
env.environment = stage_name
for option, value in STAGES[env.environment].items():
setattr(env, option, value)
env.appname = os.path.basename(os.path.abspath(os.path.dirname(__file__)))
env.deploydir = os.path.abspath(os.path.join(env.root, env.appname))
env.virtualenv_dir = os.path.join(env.deploydir,'virtualenv')
groupname = getattr(env, "chown_group", None)
if groupname is None:
setattr(env, "chown_group", env.user)
username = getattr(env, "chown_user", None)
if username is None:
setattr(env, "chown_user", env.user)
示例7: deploy
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def deploy():
"""
Deploys the latest rev for use
"""
env.currentrev = _release_name()
env.app_shortname = env.appname[:3].upper()
env.releasepath = env.app_shortname + "-" + env.currentrev[:12]
print cyan("Release: %s" % env.releasepath)
print red("Deployment user: %s" % env.user)
pkg_health = _pkg_check()
if pkg_health:
abort("One or more required system packages are unavailable.\n\nTry 'fab bootstrap'ing this system or installing the required package(s) by hand.")
_prep_deploy_dest()
with lcd(env.deploydir):
_setup_local_virtualenv(env.virtualenv_dir)
_copy_release(env.releasepath)
_deploy_appconf()
_symlink_release(env.releasepath, env.app_shortname)
示例8: database_delete
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def database_delete():
"""
Deletes the database instance
"""
if(env.is_production_env is True):
abort(red("You are not allowed to delete the database of a production " +
"environment. If this is a server restore situation, you " +
"have to temporarily declare env.is_production_env = False " +
"in the environment"))
execute(check_and_create_database_user)
with settings(warn_only=True), hide('stdout'):
checkDatabase = venvcmd('assembl-pypsql -1 -u {user} -p {password} -n {host} "{command}"'.format(
command="SELECT 1 FROM pg_database WHERE datname='%s'" % (env.db_database),
password=env.db_password, host=env.db_host, user=env.db_user))
if not checkDatabase.failed:
print(yellow("Cannot connect to database, trying to create"))
deleteDatabase = run('PGPASSWORD=%s dropdb --host=%s --username=%s %s' % (
env.db_password, env.db_host, env.db_user, env.db_database))
if deleteDatabase.succeeded:
print(green("Database deleted successfully!"))
else:
print(green("Database does not exist"))
示例9: cleanup_stage1
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def cleanup_stage1():
# Remove all packages we installed
sudo('yum clean all')
# Do not ship NGAS with a working NGAS directory
if not docker_keep_ngas_root():
with settings(user=ngas_user()):
run("rm -rf %s" % (ngas_root_dir()))
示例10: create_aws_instances
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def create_aws_instances():
"""
Create AWS instances and let Fabric point to them
This method creates AWS instances and points the fabric environment to them with
the current public IP and username.
"""
default_if_empty(env, 'AWS_KEY_NAME', DEFAULT_AWS_KEY_NAME)
default_if_empty(env, 'AWS_INSTANCE_NAME', default_instance_name)
# Create the key pair and security group if necessary
conn = connect()
aws_create_key_pair(conn)
sgid = check_create_aws_sec_group(conn)
# Create the instance in AWS
host_names = create_instances(conn, sgid)
# Update our fabric environment so from now on we connect to the
# AWS machine using the correct user and SSH private key
env.hosts = host_names
env.key_filename = key_filename(env.AWS_KEY_NAME)
if env.AWS_AMI_NAME in ['CentOS', 'SLES']:
env.user = 'root'
else:
env.user = 'ec2-user'
# Instances have started, but are not usable yet, make sure SSH has started
puts('Started the instance(s) now waiting for the SSH daemon to start.')
execute(check_ssh, timeout=300)
示例11: list_instances
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def list_instances():
"""
Lists the EC2 instances associated to the user's amazon key
"""
conn = connect()
res = conn.get_all_instances()
for r in res:
for inst in r.instances:
print
print_instance(inst)
print
示例12: updateVersionTag
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def updateVersionTag(deploymentPath, revision):
"""Updates the fluiddb/version tag for changes in the API.
@param deploymentPath: The path to deploy Fluidinfo in.
@param revision: The C{str} revision of the branch being deployed.
"""
fluidinfoPath = os.path.join(deploymentPath, revision, 'fluidinfo')
with cd(fluidinfoPath):
with open('deployment/api-version.txt') as versionFile:
version = versionFile.read()
sudo('bin/python bin/fluidinfo update-version-tag '
'postgres:///fluidinfo '
'%s' % version,
user='fluidinfo')
示例13: hasUnappliedDatabasePatches
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def hasUnappliedDatabasePatches(deploymentPath, revision):
"""Determine if there are database patches to apply.
@param deploymentPath: The path to deploy Fluidinfo in.
@param revision: The C{str} revision of the branch being deployed.
@return: C{True} if there are outstanding patches, otherwise C{False}.
"""
path = os.path.join(deploymentPath, revision, 'fluidinfo')
with cd(path):
with settings(warn_only=True):
out = sudo('bin/python bin/fluidinfo '
'patch-status postgres:///fluidinfo', user='fluidinfo')
return out.return_code != 0
示例14: get_user_home
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def get_user_home(stage="develop"):
servers = get_server_config()
return "%(home_path)s/%(user)s" % {
"home_path": HOME_PATH,
"user": make_user(servers[stage]["project"]),
}
示例15: set_user
# 需要導入模塊: from fabric.state import env [as 別名]
# 或者: from fabric.state.env import user [as 別名]
def set_user(superuser=False):
servers = get_server_config()
if superuser:
env.user = username = get_value(env.stage, "superuser", default="root")
if has_key(env.stage, "key_filename") and os.path.isfile(get_value(env.stage, "key_filename", default=None)):
env.key_filename = servers[env.stage]["key_filename"]
else:
env.password = getpass("Put password for [%s]: " % username)
if len(env.password) == 0:
sys.exit("[superuser] password is needed to make server configurations")
else:
env.user = make_user(servers[env.stage]["project"])
env.password = servers[env.stage]["password"]