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

對於一些週期性事務,咱們能夠在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:要執行的命令,能夠是系統命令,也能夠是本身編寫的腳本文件。

《crontab命令詳解 含啓動/重啓/中止》

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

星號(*):表明全部可能的值,例如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

 

  

待完善。

相關文章
相關標籤/搜索