厨师服务器ctl备份不尊重 - 超时
问题描述:
试图设置我们的厨师服务器的自动备份,但它在焦油阶段超时。我手动运行了tar,它似乎花了20分钟,但默认的超时时间是10分钟。我尝试过使用--timeout并将其设置为高达6000的值,但在600秒后仍然超时。厨师服务器ctl备份不尊重 - 超时
输出:
[email protected]:/opt/opscode/embedded/lib/ruby/gems/2.1.0/gems/chef_backup-0.0.1# /usr/bin/chef-server-ctl backup --yes --timeout 60000
Locating rsync..
/usr/bin/rsync
Starting Chef Server backup
Bringing down the Chef Server
ok: down: bookshelf: 1s, normally up
ok: down: nginx: 1s, normally up
ok: down: oc_bifrost: 0s, normally up
ok: down: oc_id: 0s, normally up
ok: down: opscode-chef-mover: 1s, normally up
ok: down: opscode-erchef: 0s, normally up
ok: down: opscode-expander: 0s, normally up
ok: down: opscode-solr4: 0s, normally up
ok: down: rabbitmq: 0s, normally up
ok: down: redis_lb: 0s, normally up
Dumping Postgresql database to /tmp/chef_backup20170613-7603-1hsvyr5/chef_backup-2017-06-13-16-55-10.sql
could not change directory to "/tmp/d20170613-7603-xpkmet"
ok: down: postgresql: 0s, normally up
Writing backup manifest
Creating backup tarball
/opt/opscode/embedded/lib/ruby/gems/2.1.0/gems/mixlib-shellout-2.2.6/lib/mixlib/shellout/unix.rb:183: warning: conflicting chdir during another chdir block
tar: Removing leading `/' from member names
ERROR: Something wen't terribly wrong, aborting backup
ERROR: Command timed out after 600s:
Command exceeded allowed execution time, process terminated
---- Begin output of tar -czf /tmp/chef_backup20170613-7603-1hsvyr5/chef-backup-2017-06-13-16-55-10.tgz /var/opt/opscode/rabbitmq/db /var/opt/opscode/opscode-solr4/data /var/opt/opscode/redis_lb/data /var/opt/opscode/postgresql/9.2/data /var/opt/opscode/bookshelf/data /v
ar/opt/opscode/upgrades /etc/opscode /etc/opscode-manage /etc/opscode-reporting /etc/opscode-push-jobs-server /etc/opscode-analytics manifest.json chef_backup-2017-06-13-16-55-10.sql ----
STDOUT:
STDERR: /opt/opscode/embedded/lib/ruby/gems/2.1.0/gems/mixlib-shellout-2.2.6/lib/mixlib/shellout/unix.rb:183: warning: conflicting chdir during another chdir block
tar: Removing leading `/' from member names
---- End output of tar -czf /tmp/chef_backup20170613-7603-1hsvyr5/chef-backup-2017-06-13-16-55-10.tgz /var/opt/opscode/rabbitmq/db /var/opt/opscode/opscode-solr4/data /var/opt/opscode/redis_lb/data /var/opt/opscode/postgresql/9.2/data /var/opt/opscode/bookshelf/data /var
/opt/opscode/upgrades /etc/opscode /etc/opscode-manage /etc/opscode-reporting /etc/opscode-push-jobs-server /etc/opscode-analytics manifest.json chef_backup-2017-06-13-16-55-10.sql ----
Ran tar -czf /tmp/chef_backup20170613-7603-1hsvyr5/chef-backup-2017-06-13-16-55-10.tgz /var/opt/opscode/rabbitmq/db /var/opt/opscode/opscode-solr4/data /var/opt/opscode/redis_lb/data /var/opt/opscode/postgresql/9.2/data /var/opt/opscode/bookshelf/data /var/opt/opscode/up
grades /etc/opscode /etc/opscode-manage /etc/opscode-reporting /etc/opscode-push-jobs-server /etc/opscode-analytics manifest.json chef_backup-2017-06-13-16-55-10.sql returned
有什么想法?
编辑:
这里要说的是,我相信创造焦油代码:
def create_tarball
log 'Creating backup tarball'
cmd = [
"tar -czf #{tmp_dir}/#{export_filename}",
data_map.services.map { |_, v| v['data_dir'] }.compact.join(' '),
data_map.configs.map { |_, v| v['data_dir'] }.compact.join(' '),
Dir["#{tmp_dir}/*"].map { |f| File.basename(f) }.join(' ')
].join(' ').strip
res = shell_out(cmd, cwd: tmp_dir)
res
end
从/opt/opscode/embedded/lib/ruby/gems/2.1.0/gems/ chef_backup /0.0.1/lib/Chef_backup/warm/backup/tar.rb文件
答
看起来像chef_backup/master/lib/chef_backup/helpers.rb文件中的shell_out函数在12.6.0中已过时,并且didn'在超时设置中合并。我用这个文件替换了这个文件:https://raw.githubusercontent.com/chef/chef_backup/master/lib/chef_backup/helpers.rb,并且能够覆盖默认的超时时间并允许备份完成。
感谢厨师松懈的渠道,帮助我与那!
你可以包含执行'tar'动作的相关执行语句/代码吗? – JohnLBevan
我不得不通过厨师代码来找到它。忍耐与我,我会看看我是否可以找到它.. 已更新的原贴 – user3062065