Linux環境下Shell調用MySQL並實現定時任務
對於一些周期性事務,我們可以在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\@2018port=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 computer‘s 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並實現定時任務