في الإصدار 2 ، لم تعد المعلمة 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 /؟ أحاول إيجاد طريقة fabric2 لاستخدام upload_template
إلخ.
@ geoffrey-eisenbarth في الوقت الحالي ، لا توجد طريقة "مباركة" لهذا الغرض - انظر قليلاً حول sudo ضمن http://www.fabfile.org/upgrading.html#file -transfer
في الوقت الحالي ، تريد أن تفعل شيئًا أساسيًا مثل
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 في الوقت الحالي ، لا توجد طريقة "مباركة" لهذا الغرض - انظر قليلاً حول sudo ضمن http://www.fabfile.org/upgrading.html#file -transfer
في الوقت الحالي ، تريد أن تفعل شيئًا أساسيًا مثل