Linux定時任務配置以及解決python下mysqldump: command not found問題

      網友投稿 1537 2022-05-29

      前言

      每日定時任務,執行Python腳本,備份數據庫。

      步驟

      1:查詢該用戶的定時器設置

      crontab -l 出錯:no crontab for root root用戶下 輸入 crontab -l 顯示 no crontab for root 例如: [root@localhost ~]# crontab -l no crontab for root 同樣在 root 用戶下輸入 crontab -e 按 Esc 按: wq 回車 重新輸入: crontab -l 原因:是由于這個liunx服務器, 第一次使用 crontab ,還沒有生成對應的文件導致的,執行了 編輯(crontab -e)后 就生成了這個文件

      2:設置定時任務

      1:添加定時任務

      crontab -e 添加代碼:下面這個意思是每一分鐘執行一次用于測試 * * * * * /data/backup.py >> ~/cron.log 2>&1

      2:重啟服務

      /sbin/service crond restart # 重啟服務 一分鐘后就會執行備份

      3:問題

      手動運行python腳本,可以正確執行。 通過crontab啟動python腳本,備份的文件xxx.sql大小為0 通過查看cron的log,發現mysqldump命令找不到。 sh: mysqldump: command not found

      mysqldump: command not found 處理

      方法一:建立軟連接:ln -fs /data/mysql/mysql5.7/bin/mysqldump /usr/bin 方法二:使用mysqldump時,使用完整路徑。(第二種方法在我的腳本中沒有成功, 但是網上有多人推薦) 方法三:直接將 mysql 的執行文件路徑 /usr/local/mysql/bin 添加到定時任務內 (我嘗試了沒有成功)

      方法三設置,

      在/etc目錄下有一個crontab文件,這個就是系統任務調度的配置文件。 /etc/crontab文件包括下面幾行: SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=""HOME=/ 我將 PATH=/sbin:/bin:/usr/sbin:/usr/bin 改成 PATH=/sbin:/bin:/usr/sbin:/usr/bin:/data/mysql/mysql5.7/bin 重啟后,沒有生效

      mysqldump: command not found 原因

      mysql安裝的目錄和crontab掃描的目錄不一致。 如果我們使用 crontab 來定時執行腳本,無法執行,但是如果直接通過命令(如:./test.sh)又可以正常執行,這主要是因為無法讀取環境變量的原因。 mysqldump實際的位置在/data/lmysql/mysql5.7/bin,而crontab只會去/usr/bin尋找。

      ---------------------------------------------------------擴展------------------------------------------

      crontab

      提交和管理用戶的需要周期性執行的任務

      補充說明

      crontab命令?被用來提交和管理用戶的需要周期性執行的任務,與windows下的計劃任務類似,當安裝完成操作系統后,默認會安裝此服務工具,并且會自動啟動crond進程,crond進程每分鐘會定期檢查是否有要執行的任務,如果有要執行的任務,則自動執行該任務。

      語法

      crontab(選項)(參數)

      選項

      -e:編輯該用戶的計時器設置; -l:列出該用戶的計時器設置; -r:刪除該用戶的計時器設置; -u<用戶名稱>:指定要設定計時器的用戶名稱。

      參數

      crontab文件:指定包含待執行任務的crontab文件。

      知識擴展

      linux下的任務調度分為兩類:?系統任務調度?和?用戶任務調度?。

      系統任務調度:?系統周期性所要執行的工作,比如寫緩存數據到硬盤、日志清理等。在/etc目錄下有一個crontab文件,這個就是系統任務調度的配置文件。

      /etc/crontab文件包括下面幾行:

      SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=""HOME=/ # run-parts 51 * * * * root run-parts /etc/cron.hourly 24 7 * * * root run-parts /etc/cron.daily 22 4 * * 0 root run-parts /etc/cron.weekly 42 4 1 * * root run-parts /etc/cron.monthly

      前四行是用來配置crond任務運行的環境變量,第一行SHELL變量指定了系統要使用哪個shell,這里是bash,第二行PATH變量指定了系統執行命令的路徑,第三行MAILTO變量指定了crond的任務執行信息將通過電子郵件發送給root用戶,如果MAILTO變量的值為空,則表示不發送任務執行信息給用戶,第四行的HOME變量指定了在執行命令或者腳本時使用的主目錄。

      用戶任務調度:?用戶定期要執行的工作,比如用戶數據備份、定時郵件提醒等。用戶可以使用?crontab?工具來定制自己的計劃任務。所有用戶定義的crontab文件都被保存在/var/spool/cron目錄中。其文件名與用戶名一致,使用者權限文件如下:

      /etc/cron.deny 該文件中所列用戶不允許使用crontab命令 /etc/cron.allow 該文件中所列用戶允許使用crontab命令 /var/spool/cron/ 所有用戶crontab文件存放的目錄,以用戶名命名

      crontab文件的含義:用戶所建立的crontab文件中,每一行都代表一項任務,每行的每個字段代表一項設置,它的格式共分為六個字段,前五段是時間設定段,第六段是要執行的命令段,格式如下:

      minute hour day month week command 順序:分 時 日 月 周

      其中:

      minute:?表示分鐘,可以是從0到59之間的任何整數。

      hour:表示小時,可以是從0到23之間的任何整數。

      day:表示日期,可以是從1到31之間的任何整數。

      month:表示月份,可以是從1到12之間的任何整數。

      week:表示星期幾,可以是從0到7之間的任何整數,這里的0或7代表星期日。

      command:要執行的命令,可以是系統命令,也可以是自己編寫的腳本文件。

      在以上各個字段中,還可以使用以下特殊字符:

      星號(*):代表所有可能的值,例如month字段如果是星號,則表示在滿足其它字段的制約條件后每月都執行該命令操作。

      逗號(,):可以用逗號隔開的值指定一個列表范圍,例如,“1,2,5,7,8,9”

      中杠(-):可以用整數之間的中杠表示一個整數范圍,例如“2-6”表示“2,3,4,5,6”

      正斜線(/):可以用正斜線指定時間的間隔頻率,例如“0-23/2”表示每兩小時執行一次。同時正斜線可以和星號一起使用,例如*/10,如果用在minute字段,表示每十分鐘執行一次。

      crond服務

      /sbin/service crond start # 啟動服務 /sbin/service crond stop # 關閉服務 /sbin/service crond restart # 重啟服務 /sbin/service crond reload # 重新載入配置

      查看crontab服務狀態:

      service crond status

      手動啟動crontab服務:

      service crond start

      查看crontab服務是否已設置為開機啟動,執行命令:

      ntsysv

      加入開機自動啟動:

      chkconfig –level 35 crond on

      實例

      每1分鐘執行一次command

      * * * * * command

      每小時的第3和第15分鐘執行

      3,15 * * * * command

      在上午8點到11點的第3和第15分鐘執行

      3,15 8-11 * * * command

      每隔兩天的上午8點到11點的第3和第15分鐘執行

      3,15 8-11 */2 * * command

      每個星期一的上午8點到11點的第3和第15分鐘執行

      3,15 8-11 * * 1 command

      每晚的21:30重啟smb

      30 21 * * * /etc/init.d/smb restart

      每月1、10、22日的4?:?45重啟smb

      45 4 1,10,22 * * /etc/init.d/smb restart

      每周六、周日的1:10重啟smb

      10 1 * * 6,0 /etc/init.d/smb restart

      每天18?:?00至23?:?00之間每隔30分鐘重啟smb

      0,30 18-23 * * * /etc/init.d/smb restart

      每星期六的晚上11:00?pm重啟smb

      Linux定時任務配置以及解決python下mysqldump: command not found問題

      0 23 * * 6 /etc/init.d/smb restart

      每一小時重啟smb

      * */1 * * * /etc/init.d/smb restart

      晚上11點到早上7點之間,每隔一小時重啟smb

      * 23-7/1 * * * /etc/init.d/smb restart

      每月的4號與每周一到周三的11點重啟smb

      0 11 4 * mon-wed /etc/init.d/smb restart

      一月一號的4點重啟smb

      0 4 1 jan * /etc/init.d/smb restart

      每小時執行/etc/cron.hourly目錄內的腳本

      01 * * * * root run-parts /etc/cron.hourly

      版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。

      上一篇:架構師之路 — 分布式系統 — 分布式事務難題
      下一篇:[跟著官方文檔學Selenium][學習筆記][七][WebDriver的等待]
      相關文章
      久久精品国产亚洲AV未满十八| 国产亚洲精品精品国产亚洲综合| 国产亚洲精品资在线| 朝桐光亚洲专区在线中文字幕| va天堂va亚洲va影视中文字幕| 亚洲精品无码久久久久久久| 亚洲另类激情综合偷自拍 | 亚洲日日做天天做日日谢| 亚洲成aⅴ人片在线影院八| 亚洲日本在线免费观看| 亚洲成人免费电影| 亚洲国产精品免费在线观看| 亚洲六月丁香六月婷婷色伊人| 亚洲一区无码中文字幕乱码| 色偷偷亚洲女人天堂观看欧| 麻豆狠色伊人亚洲综合网站| 亚洲色成人WWW永久在线观看| 亚洲AV无码成人网站在线观看| 亚洲av无码片vr一区二区三区| 国产亚洲精品91| 亚洲人成网站在线观看青青| 国产亚洲精品a在线观看 | 丝袜熟女国偷自产中文字幕亚洲| 国产精品亚洲美女久久久| 在线亚洲精品自拍| 亚洲成A人片在线观看无码不卡| 亚洲AV成人精品网站在线播放 | 免费观看亚洲人成网站| 亚洲精品视频免费观看| 亚洲最大福利视频| 亚洲日韩精品国产一区二区三区 | 亚洲国产精品美女久久久久| 亚洲国产高清在线一区二区三区 | 在线A亚洲老鸭窝天堂| 亚洲AV无码专区在线播放中文| 精品亚洲国产成AV人片传媒| 国产精品亚洲片夜色在线| 亚洲经典千人经典日产| 亚洲精品国自产拍在线观看| 精品亚洲综合久久中文字幕| 亚洲网站免费观看|