三 脚本编写与运行

Posted 钟桂耀

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了三 脚本编写与运行相关的知识,希望对你有一定的参考价值。

 

 

编写脚本的思路:

 

明确脚本实现的功能
哪些数据是变化的,把变化的数据用变量来表示
使用哪种流程控制
使用哪些系统命令

 

 

 

创建第一个脚本

1、编写脚本代码

使用vim文本编辑器
每行一条Linux命令,按执行顺序依次编写

 

 



2、赋予可执行权限

若直接执行脚本文件,必须具有可执行属性

 

 



3、执行脚本文件

脚本文件路径/脚本名或./脚本名 (当前路径下执行脚本)
sh 脚本名或bash 脚本名 不需x权限(推荐使用)
source 脚本名或. 脚本名   不需x权限 #注意”.”点号

 

 

 

说明:

 

1.第三种方法是使用source或者”.”点号读入或加载指定的shell脚本文件(如san.sh),然后依次执行指定shell脚本文件san.sh中的所有语句。
这些语句将作为当前父shell脚本father.sh进程的一部分运行。因此,使用source或者”.”点号可以将san.sh自身脚本中的变量的值或函数等的返回值传递到
当前的父shell脚本father.sh中使用。这是第三种方法和前两种的最大区别。也是值得读者注意的地方。

2 Source或者”.”点号命令的功能是在当前shell中执行source或者”.”点号加载并执行的相关脚本文件中的命令及语句,

而不是产生一个子shell来执行命令文件中的命令。

 

 

 

 

 

正常的Shell脚本

 

脚本声明(需要的解释器、作者信息等)
注释信息(步骤、思路、用途、变量含义等)
可执行语句(操作代码)

 

 

 

 

 

 

脚本应用实例

 

 

1.3天备份一次mysql数据库

 

2.编写一个脚本,实现以下目标:

 

每次root用户登录后,自动报告当前登录的用户数、打开的进程数、剩余可用内存、剩余交换空间

 

3.list_sys_status.sh显示系统使用的以下信息:主机名、ip地址、子网掩码、网关、DNS服务IP地址

 

ifconfig | head -2 | tail -1 | awk {print $2} | awk -F ":" {print $2}

 

 

 

 

mysqlbak.sh备份数据库目录脚本

 

#!/bin/bash
DAY=`date +%Y%m%d`
SIZE=`du -sh /var/lib/mysql`
echo "Data: $DAY" >> /tmp/dbinfo.txt
echo "Data Size: $SIZE" >> /tmp/dbinfo.txt
cd /opt/dbbak &> /dev/null || mkdir /opt/dbbak;cd /opt/dbbak
tar zcf /opt/dbbak/mysqlbak-${DAY}.tar.gz /var/lib/mysql /tmp/dbinfo.txt &> /dev/null
rm -f /tmp/dbinfo.txt

 

 

 

5.每周日半夜23点半,对数据库服务器上的webdb库做完整备份。把备份文件保存在系统的/mysqlbak目录里,用系统日期做备份文件名 webdb-YYYY-mm-dd.sql

每次完整备份后都生成新的binlog日志把当前所有的binlog日志备份到/mysqlbinlog目录下。

 

以上是关于三 脚本编写与运行的主要内容,如果未能解决你的问题,请参考以下文章

编写java 程序与Linux进行远程连接并运行linux下的脚本

动态内存分配php

JSP 语法

Shell脚本------编程规范与变量

分享前端开发常用代码片段

jsp