v2では、 use_sudo=True
パラメーターはもう存在しません。
リモートホスト上のファイルをコピーしようとすると、次のようになります。
Traceback (most recent call last):
File "env/bin/fab", line 9, in <module>
load_entry_point('fabric==2.0.0', 'console_scripts', 'fab')()
File "/home/tim/Workspace/wintest/env/lib/python3.5/site-packages/invoke/program.py", line 332, in run
self.execute()
File "/home/tim/Workspace/wintest/env/lib/python3.5/site-packages/invoke/program.py", line 480, in execute
executor.execute(*self.tasks)
File "/home/tim/Workspace/wintest/env/lib/python3.5/site-packages/invoke/executor.py", line 133, in execute
result = call.task(*args, **call.kwargs)
File "/home/tim/Workspace/wintest/env/lib/python3.5/site-packages/invoke/tasks.py", line 127, in __call__
result = self.body(*args, **kwargs)
File "/home/tim/Workspace/wintest/fabfile.py", line 131, in nginx
context.put(StringIO(nginx_conf), remote='/etc/nginx/sites-enabled/website')
File "/home/tim/Workspace/wintest/env/lib/python3.5/site-packages/fabric/connection.py", line 639, in put
return Transfer(self).put(*args, **kwargs)
File "/home/tim/Workspace/wintest/env/lib/python3.5/site-packages/fabric/transfer.py", line 213, in put
sftp.putfo(fl=local, remotepath=remote)
File "/home/tim/Workspace/wintest/env/lib/python3.5/site-packages/paramiko/sftp_client.py", line 683, in putfo
with self.file(remotepath, 'wb') as fr:
File "/home/tim/Workspace/wintest/env/lib/python3.5/site-packages/paramiko/sftp_client.py", line 341, in open
t, msg = self._request(CMD_OPEN, filename, imode, attrblock)
File "/home/tim/Workspace/wintest/env/lib/python3.5/site-packages/paramiko/sftp_client.py", line 780, in _request
return self._read_response(num)
File "/home/tim/Workspace/wintest/env/lib/python3.5/site-packages/paramiko/sftp_client.py", line 832, in _read_response
self._convert_status(msg)
File "/home/tim/Workspace/wintest/env/lib/python3.5/site-packages/paramiko/sftp_client.py", line 863, in _convert_status
raise IOError(errno.EACCES, text)
PermissionError: [Errno 13] Permission denied
これはhttp://docs.fabfile.org/en/latest/upgrading.html#id15に記載されています。 これに代わる適切な単一コマンドはないようです(たとえば、 c.sudo("install … /dev/stdin /path/to/remote")
は使用できません)。また、 sudo()
にバグがあり、 tee
の使用が妨げられているようです。
これが私が一時ファイルのダンスを行うために使用していることです。これは、意図しないアクセス許可を持つファイルを残さないようにするために、とにかく常に実行する必要があることです。
def sudo_install(connection, source, dest, *, owner='root', group='root', mode='0600'):
"""
Helper which installs a file with arbitrary permissions and ownership
This is a replacement for Fabric 1's `put(…, use_sudo=True)` and adds the
ability to set the expected ownership and permissions in one operation.
"""
mktemp_result = connection.run('mktemp', hide='out')
assert mktemp_result.ok
temp_file = mktemp_result.stdout.strip()
try:
connection.put(source, temp_file)
connection.sudo(f'install -o {owner} -g {group} -m {mode} {temp_file} {dest}')
finally:
connection.run(f'rm {temp_file}')
例として呼び出されます
<strong i="14">@task</strong>
def install_mount_status_monitor(conn):
sudo_install(conn, override_file, "/etc/systemd/system/mount_status_monitor.service.d/override.conf")
これは、ローカルファイルをユーザーのホームディレクトリ外のリモートサーバーにコピーしようとするときに使用すると予想されるルートですか?
Fabricを使用してファイルを/ etc / nginx /などにコピーするための意図された方法は何ですか? upload_template
などを使用するfabric2の方法を見つけようとしています。
@ geoffrey-eisenbarth現時点では、これに対する「祝福された」アプローチはありません。http: //www.fabfile.org/upgrading.html#file-transferの下にあるsudoについてのビットを参照してください。
今のところ、あなたは次のような基本的なことをしたいと思うでしょう
c.put("path/to/local/nginx.conf") # implicit to remote $HOME
c.sudo("mv nginx.conf /etc/nginx/") # again implicitly with a CWD of $HOME
最も参考になるコメント
@ geoffrey-eisenbarth現時点では、これに対する「祝福された」アプローチはありません。http: //www.fabfile.org/upgrading.html#file-transferの下にあるsudoについてのビットを参照してください。
今のところ、あなたは次のような基本的なことをしたいと思うでしょう