1. 程式人生 > >Linux環境下Shell調用MySQL並實現定時任務

Linux環境下Shell調用MySQL並實現定時任務

usr .sql 操作 default char star ted 空格 rontab

對於一些周期性事務,我們可以在Linux下,使用shell腳本調用mysql數據庫存儲過程,並設置定時任務。

本來是要mysql數據庫中創建事件任務來,定時執行存儲過程,做數據傳輸的。。。使用crontab來定時執行,調用存儲過程。

實現這個數據傳輸分為兩步:

第一步:編寫shell腳本調用mysql數據庫存儲過程,如下:

#!/bin/bash
# 50 8 * * * sh /home/bgop/hao/detector_task.sh > /dev/null 2>&1 &

host1=127.0.0.1
user=root
passwd=HaoChuangMysql\@2018
port=23306 mysql -h${host1} -u${user} -p${passwd} -P${port} -e "call bg-biz.test_insert" ;

這樣就可以,調用執行庫data的過程pro了。

註意,不同主機有可能需要寫出mysql的絕對路徑,如/usr/bin/mysql,否則不執行庫過程。。。

這裏有幾個要點,我加上詳細的備註說明:

!/bin/bash  

#數據庫信息,也可以寫 HOSTNAME="localhost",端口號 PORT可以不設定 
HOSTNAME="192.168.0.100"                                           

# 端口
PORT
="3306" # 用戶名 USERNAME="root" # 密碼,註意如果有特殊字符的話,記得使用\轉義 PASSWORD="haochuangMySQL\@2018" #數據庫名稱 DBNAME="test_db_test" #數據庫中表的名稱 TABLENAME="test_table_test" # 帶上上面參數,調用存儲過程 mysql -h${host1} -
u${user} -p${passwd} -P${port} -e "call 庫名data.過程名pro" ;

第二步:創建crontab定時任務,設置在淩晨1點執行腳本/home/bgop/hao/detector_task.sh

#vi /var/spool/cron/root

添加語句 0 1 * * * sh /home/bgop/hao/detector_task.sh

0 1 * * * sh /home/bgop/hao/detector_task.sh > /dev/null 2>&1 &

設置完成之後保存,重啟一下crontab,並查看crontab的狀態是否正常

[root@VM_0_16_centos hao]# service crond restart
Redirecting to /bin/systemctl restart  crond.service
[root@VM_0_16_centos hao]# service crond status 
Redirecting to /bin/systemctl status  crond.service
● crond.service - Command Scheduler
   Loaded: loaded (/usr/lib/systemd/system/crond.service; enabled; vendor preset: enabled)
   Active: active (running) since Wed 2018-12-05 09:39:25 CST; 2s ago
 Main PID: 25636 (crond)
   CGroup: /system.slice/crond.service
           └─25636 /usr/sbin/crond -n

Dec 05 09:39:25 VM_0_16_centos systemd[1]: Started Command Scheduler.
Dec 05 09:39:25 VM_0_16_centos crond[25636]: (CRON) INFO (RANDOM_DELAY will be scaled with factor 20% if used.)
Dec 05 09:39:25 VM_0_16_centos systemd[1]: Starting Command Scheduler...
Dec 05 09:39:25 VM_0_16_centos crond[25636]: (CRON) bad minute (/etc/cron.d/cron.allow)
Dec 05 09:39:25 VM_0_16_centos crond[25636]: (CRON) bad minute (/etc/cron.d/cron.allow)
Dec 05 09:39:25 VM_0_16_centos crond[25636]: (CRON) INFO (running with inotify support)
Dec 05 09:39:25 VM_0_16_centos crond[25636]: (CRON) INFO (@reboot jobs will be run at computers startup.)

經過這兩個步驟,就可以實現使用shell腳本調用mysql數據庫存儲過程,並設置定時任務。

附錄

-----另外,補充幾條常用的Linux與MySQL等操作命令,如下:

# 定時導入
mysql -uroot  -h192.168.0.100  -P23306 -pHaoMySQL\@2018 < /hao/software/localCon.sql

#創建數據庫
create_db_sql="create database IF NOT EXISTS ${DBNAME}"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} -e "${create_db_sql}"

註意:-p${PASSWORD}中間不能有空格

#創建表
create_table_sql="create table IF NOT EXISTS ${TABLENAME} ( name varchar(20), id int(11) default 0 )"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} -D ${DBNAME} -e "${create_db_sql}"

#插入數據
insert_sql="insert into ${TABLENAME} values(‘billchen‘,2)"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${insert_sql}"

#查詢
select_sql="select * from ${TABLENAME}"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"

#更新數據
update_sql="update ${TABLENAME} set id=3"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${update_sql}"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"

#刪除數據
delete_sql="delete from ${TABLENAME}"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${delete_sql}"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"

----補充一些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服務

安裝crontab:

yum install crontabs

服務操作說明:

/sbin/service crond start //啟動服務

/sbin/service crond stop //關閉服務

/sbin/service crond restart //重啟服務

/sbin/service crond reload //重新載入配置

查看crontab服務狀態:

service crond status

手動啟動crontab服務:

service crond start

加入開機自動啟動:

chkconfig –level 35 crond on

使用實例

實例1:每1分鐘執行一次command

命令:

* * * * * command

實例2:每小時的第3和第15分鐘執行

命令:

3,15 * * * * command

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

命令:

3,15 8-11 * * * command

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

命令:

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

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

命令:

3,15 8-11 * * 1 command

實例6:每晚的21:30重啟smb

命令:

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

實例7:每月1、10、22日的4 : 45重啟smb

命令:

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

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

命令:

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

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

命令:

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

實例10:每星期六的晚上11 : 00 pm重啟smb

命令:

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

實例11:每一小時重啟smb

命令:

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

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

命令:

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

實例13:每月的4號與每周一到周三的11點重啟smb

命令:

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

實例14:一月一號的4點重啟smb

命令:

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

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

命令:

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

待完善。

Linux環境下Shell調用MySQL並實現定時任務