【原】Linux环境下Shell调用MySQL并实现定时任务(转) | 您所在的位置:网站首页 › js调用存储过程mysqL › 【原】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@2018 port=23306 mysql -h h o s t 1 − u {host1} -u host1−u{user} -p p a s s w d − P {passwd} -P passwd−P{port} -e “use bg-biz;call 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 h o s t 1 − u {host1} -u host1−u{user} -p p a s s w d − P {passwd} -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 D B N A M E " m y s q l − h {DBNAME}" mysql -h DBNAME"mysql−h{HOSTNAME} -P P O R T − u {PORT} -u PORT−u{USERNAME} -p P A S S W O R D − e " {PASSWORD} -e " PASSWORD−e"{create_db_sql}” 注意:-p${PASSWORD}中间不能有空格 #创建表 create_table_sql=“create table IF NOT EXISTS T A B L E N A M E ( n a m e v a r c h a r ( 20 ) , i d i n t ( 11 ) d e f a u l t 0 ) " m y s q l − h {TABLENAME} ( name varchar(20), id int(11) default 0 )" mysql -h TABLENAME(namevarchar(20),idint(11)default0)"mysql−h{HOSTNAME} -P P O R T − u {PORT} -u PORT−u{USERNAME} -p${PASSWORD} -D D B N A M E − e " {DBNAME} -e " DBNAME−e"{create_db_sql}” #插入数据 insert_sql=“insert into T A B L E N A M E v a l u e s ( ′ b i l l c h e n ′ , 2 ) " m y s q l − h {TABLENAME} values('billchen',2)" mysql -h TABLENAMEvalues(′billchen′,2)"mysql−h{HOSTNAME} -P P O R T − u {PORT} -u PORT−u{USERNAME} -p${PASSWORD} D B N A M E − e " {DBNAME} -e " DBNAME−e"{insert_sql}” #查询 select_sql=“select * from T A B L E N A M E " m y s q l − h {TABLENAME}" mysql -h TABLENAME"mysql−h{HOSTNAME} -P P O R T − u {PORT} -u PORT−u{USERNAME} -p${PASSWORD} D B N A M E − e " {DBNAME} -e " DBNAME−e"{select_sql}” #更新数据 update_sql=“update T A B L E N A M E s e t i d = 3 " m y s q l − h {TABLENAME} set id=3" mysql -h TABLENAMEsetid=3"mysql−h{HOSTNAME} -P P O R T − u {PORT} -u PORT−u{USERNAME} -p${PASSWORD} D B N A M E − e " {DBNAME} -e " DBNAME−e"{update_sql}” mysql -h H O S T N A M E − P {HOSTNAME} -P HOSTNAME−P{PORT} -u U S E R N A M E − p {USERNAME} -p USERNAME−p{PASSWORD} D B N A M E − e " {DBNAME} -e " DBNAME−e"{select_sql}" #删除数据 delete_sql=“delete from T A B L E N A M E " m y s q l − h {TABLENAME}" mysql -h TABLENAME"mysql−h{HOSTNAME} -P P O R T − u {PORT} -u PORT−u{USERNAME} -p${PASSWORD} D B N A M E − e " {DBNAME} -e " DBNAME−e"{delete_sql}” mysql -h H O S T N A M E − P {HOSTNAME} -P HOSTNAME−P{PORT} -u U S E R N A M E − p {USERNAME} -p USERNAME−p{PASSWORD} D B N A M E − e " {DBNAME} -e " 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字段,表示每十分钟执行一次。 二、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 原文:https://www.cnblogs.com/haochuang/p/10070752.html |
CopyRight 2018-2019 实验室设备网 版权所有 |