AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1080369
Accepted
Codejoy
Codejoy
Asked: 2021-10-13 15:21:13 +0800 CST2021-10-13 15:21:13 +0800 CST 2021-10-13 15:21:13 +0800 CST

脚本备份 sqlite 数据库,当作为 cron 运行时,数据库和名称被破坏

  • 772

我有一个 crontab:

 * * * * * /home/ipa/web/backup.sh > /dev/null 2>&1

(不,它不会每分钟都运行,只是在这里测试)

backup.sh 有这个:

#!/usr/bin/env sh



sqlite3 /home/ipa/web/ipa_django/mysite/db.sqlite3 ".backup 'backup_file.sqlite3'"
src="/home/ipa/web/backup_file.sqlite3"
let seconds=$(date +%H)*3600+$(date +%M)*60+$(date +%S)
echo $seconds
filename="db.sqlite3"
echo $filename.$seconds
dest="/home/ipa/web/db_backups/"$filename.$seconds
cp  $src $dest
cd /home/ipa/web/db_backups
tar -cvzf ipadbbackup.tar.gz $filename.$seconds
cd /home/ipa/web/
cp /home/ipa/web/db_backups/ipadbbackup.tar.gz ipadbbackup.tar.gz
rm /home/ipa/web/db_backups/$filename.$seconds
rm /home/ipa/web/db_backups/ipadbbackup.tar.gz
#rm "$srcfile"
/usr/bin/bash start-app.sh;
echo "Running email backup"
python2.7 backup_via_email.py
rm ipadbbackup.tar.gz

我的想法是我将数据库复制到暂存区域,将其压缩并复制到另一个 .py 文件可以找到它的位置,然后通过电子邮件将其作为备份发送出去。

问题是:

如果我从它所在的位置运行此脚本:/home/ipa/web/

带有 ./backup.sh

效果很好,我的电子邮件中的文件效果很好:db.sqlite3.77627

或者什么不是......问题是当它作为cron运行时文件不完整并且文件名是:

db.sqlite3.

我无法弄清楚它作为 cron 运行会导致它基本上失败吗?tar 中的文件也小了 2.1k?所以不知道发生了什么......甚至不知道在哪里看。

ubuntu cron python sqlite
  • 1 1 个回答
  • 353 Views

1 个回答

  • Voted
  1. Best Answer
    Ginnungagap
    2021-10-19T11:15:22+08:002021-10-19T11:15:22+08:00

    最有可能的是,您在./backup.sh手动运行时实际上并没有在运行,而是在bash ./backup.sh.

    通过 shell 计算值的唯一符合 POSIX 标准的方法是使用$(( expr )).

    一般来说,除非你有充分的理由,否则脚本应该使用 bash,因为大多数人不知道 sh 和 bash 之间的区别,只会编写损坏的脚本。

    #!/usr/bin/env bash
    
    set -e
    set -u
    
    declare -r db_src="/home/ipa/web/ipa_django/mysite/db.sqlite3"
    declare -r db_bak="/home/ipa/web/backup_file.sqlite3"
    declare -r db_dst="/home/ipa/web/db_backups/db.sqlite3.$[ EPOCHSECONDS % 86400 ]"
     
    sqlite3 "${db_src}" ".backup 'backup_file.sqlite3'"
    cp "${db_bak}" "${db_dst}"
    cd "$( dirname "${db_dst}" )"
    tar -czf "/home/ipa/web/ipadbbackup.tar.gz" "$( basename "${db_dst}" )"
    rm "${db_dst}"
    
    echo "Running email backup"
    cd "/home/ipa/web" 
    python2.7 backup_via_email.py
    rm ipadbbackup.tar.gz
    

    尝试调试时,请务必记录您的 cron 输出,我猜您会在command not found: let某个地方看到过。

    • 4

相关问题

  • 无法通过 Ubuntu VPN 访问外部网络

  • ubuntu apt-get upgrade - 如何在 shell 中单击确定?

  • VirtualBox 上 Ubuntu 的访客优化技巧 [关闭]

  • 外部硬盘上的 virtualbox 虚拟硬盘驱动器(Vista 主机上的 ubuntu 客户机)

  • 如何在 Ubuntu 上挂载 LVM 分区?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve