• 三 脚本编写与运行


    编写脚本的思路:

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

    创建第一个脚本

    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目录下。

  • 相关阅读:
    宏任务与微任务
    reactnative 自定义项目的图标库
    react-native中textInput在androidTV上的焦点处理(坑篇)
    js中!!的运用
    ES6里class杂乱随笔
    浅析链式调用
    link和@import的区别
    ES2020链判断运算符?.和Null判断运算符??
    vue组件使用name属性来生成递归组件
    k8s学习——相关概念
  • 原文地址:https://www.cnblogs.com/zhongguiyao/p/8934346.html
Copyright © 2020-2023  润新知