對於一些週期性事務,咱們能夠在Linux下,使用shell腳本調用mysql數據庫存儲過程,並設置定時任務。mysql
原本是要mysql數據庫中建立事件任務來,定時執行存儲過程,作數據傳輸的。。。使用crontab來定時執行,調用存儲過程。sql
實現這個數據傳輸分爲兩步:shell
第一步:編寫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 "use bg-biz;call test_insert;" ;
這樣就能夠,調用執行庫data的過程pro了。centos
注意,不一樣主機有可能須要寫出mysql的絕對路徑,如/usr/bin/mysql,不然不執行庫過程。。。bash
這裏有幾個要點,我加上詳細的備註說明:url
!/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.shspa
#vi /var/spool/cron/rootrest
添加語句 0 1 * * * sh /home/bgop/hao/detector_task.shcode
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字段,表示每十分鐘執行一次。
2、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:每個月一、十、22日的4 : 45重啓smb
命令:
45 4 1,10,22 * * /etc/init.d/smb restart
實例8:每週6、週日的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
待完善。