zoukankan      html  css  js  c++  java
  • Linux mysql shell脚本 变量和环境变量 位置参数 预定义变量 运算符 判断 流程控制 for循环 与用户交互 函数

    mysql

    1. 卸载旧版本

    rpm -qa | grep mysql        检查是否有旧版本
    
    查询结果:mysql-libs-5.1.73-7.el6.x86_64
    
    rpm -e mysql-libs            删除旧版本
    rpm -e --nodeps mysql-libs    强行删除

    2. 安装mysql

    2.1 安装源码需要编译

    下载c的编译工具
    yum -y install make gcc-c++ cmake bison-devel  ncurses-devel

    2.2 xftp连接上传

    xftp连接上传到opt文件夹

    2.3 编译

    1. tar -zxvf mysql-5.6.14.tar.gz        解压
    2. cd mysql-5.6.14                        切换目录
    
    3.编译准备:
    cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -
    DMYSQL_DATADIR=/usr/local/mysql/data -DSYSCONFDIR=/etc -
    DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -
    DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -
    DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.sock -DMYSQL_TCP_PORT=3306 -DENABLED_LOCAL_INFILE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -
    DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci 编译并安装: make && make install

    2.4配置mysql

    1.创建mysql组,及用户
        groupadd mysql
        useradd -g mysql mysql
        passwd mysql
    2.初始化配置:
    1.cd /usr/local/mysql
    2.scripts/mysql_install_db
    
    3.修改权限:
    修改/usr/local/mysql权限
    chown -R mysql:mysql /usr/local/mysql
    
    4.在启动MySQL服务时,会先在/etc目录下找my.cnf,找不到则会搜索"$basedir/my.cnf",在本例中就是 /usr/local/mysql/my.cnf
    查看/etc下是否有my.cnf,有就换个名字,防止干扰
    mv /usr/local/mysql/my.cnf /usr/local/mysql/my.cnf.bak
    
    5.添加服务(mysql服务放进/etc/init.d),并设置开机自启:
    1.cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
    2.chkconfig mysql on
    3.service mysql start
    
    6.配置环境变量:
    1.vi /etc/profile
    2.在文件中加入:
        export PATH=/usr/local/mysql/bin:$PATH
    3.source /etc/profile

    shell编程

    1.shell编程是个啥

    Shell 是一个命令行解释器,它为用户提供了一个向 Linux 内核发送请求以便运行程序的系统级程序

    2.shell编程打印hello world使用案例

    1.新建脚本文件(bash结尾)

    vim hello.sh

    2.脚本文件代码编写

    #!/bin/bash
    echo 'hello world'

    代码解释:

    1.#!/bin/bash:

    告诉计算机,使用bash解释器来执行代码

    2.echo:

    控制台输出

    3.运行脚本文件

    方式一:(不推荐)

    直接调用shell解释器执行

    1.hello.sh为文件路径
    bash hello.sh

    方式二:

    给脚本可执行权限

    1.hello.sh为文件路径
    chmod 744 hello.sh
    
    2.文件路径直接运行
    ./hello.sh

     3.注释

    1.单行注释
    #内容
    
    2.多行注释
    :<<!
    内容
    !

    变量

    1.变量的介绍

    1.Linux中变量的分类:系统变量(系统先前定义好的)    自定义变量
    2.引用变量:$变量名
    3.系统变量: $PATH $HOME $PWD $SHELL $USER 4.显示当前shell中所有的变量:set

    2.变量的定义

    1.定义变量:变量名=变量值
    2.撤销变量:unset 变量名
    3.声明静态变量:readonly 变量名=值        静态变量不能unset和改值

    定义规则

    1.变量名称可以由字母、数字和下划线组成,但是不能以数字开头
    2.等号两侧不能有空格
    3.变量名称一般习惯为大写

    3.将命令的返回值赋给变量(用的多)

    1.A=`ls -la` 反引号,运行里面的命令,并把结果返回给变量 A
    2.A=$(ls -la) 等价于反引号

    设置环境变量

    基本语法

    1.export 变量名=变量值        将shell变量输出给环境变量
    2.source 配置文件             让修改后的配置信息立即生效
    3.echo $变量值                  查看环境变量的值

    位置参数变量(给执行文件传参数)

    当我们执行一个 shell 脚本时,如果希望获取到命令行的参数信息,就可以使用到位置参数变量

    基本语法

    1.
    $n (功能描述:n 为数字,$0 代表命令本身,$1-$9 代表第一到第九个参数,十以上的参数,十以上的参数需要用大括号包含,如${10})
    
    2.
    $* (功能描述:这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体)
    
    3.
    $@  (功能描述:这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待)
    
    4.
    $#(功能描述:这个变量代表命令行中所有参数的个数)

    预定义变量

    就是 shell 设计者事先已经定义好的变量,可以直接在 shell 脚本中使用

    基本语法

    $$     (功能描述:当前进程的进程号(PID))
    $!    (功能描述:后台运行的最后一个进程的进程号(PID))
    $?(获取函数return的结果)    (功能描述:最后一次执行的命令的返回状态。如果这个变量的值为 0,证明上一个命令正确执行;如果这个变量的值为非 0(具体是哪个数,由命令自己来决定),则证明上一个命令执行失败)

    运算符

    基本语法

    1.$((运算式))
    2.$[运算式]   ------推荐使用
    3.`expr m + n`
        特点:运算符之间要有空格
        +
        -
        /
        %
        *
        (    )

    判断

    基本语法

    [ 条件 ]            注意:条件前后要有空格
    
    特别的:
    [ 非空 ]      为true
    []           为false
    [ haha ] && echo true || echo false

    1.字符串比较

    =    判等
    !=  判不相等

    2.整数比较

    -lt        小于
    -le        小于等于
    -gt        大于
    -ge        大于等于
    -eg        等于
    -ne        不等于

    3.文件权限判断

    -r    有读的权限    [ -r 文件 ]
    -w    有写的权限   [ -w 文件路径 ]
    -x    有执行权限
    -f 存在并且是一般文件    [-f 文件]
    -e 文件存在 (用的多)
    -d 存在并且是一个目录

    流程控制

    1.基本语法

    1.
    if [ 条件 ]
    then
        代码
    fi
    
    2.
    if [ 条件 ]
    then
        代码
    else
        代码
    fi
    
    3.
    if [ 条件 ]
    then
        代码
    elif [ 条件 ]
    then
        代码
    else
        代码
    fi

    2.case 选择分支

    case $变量名 in
    '值1')
    代码
    ;;
    '值2')
    代码
    ;;
    *)
    代码                    都没命中执行
    ;;
    esac

    for循环

    1.用法一

    for ((初始值;循环条件;追加条件))
    do
        代码
    done

    2.用法二

    for 变量 in 值1 值2 值3
    do
        代码
    done

    while循环

    while [ 条件 ]
    do
        代码
    done

    与用户交互

    基本语法

    read 选项 变量
    选项:
    -p:提示信息
    -t:等待输入的时间

    函数

    1.系统函数

    basename

    basename [pathname] [suffix]
    获得路径最后一部分
    
    如果指定的suffix,那么会去掉结果中suffix的部分

    dirname

    dirname [pathname]
    获得基础路径

    2.自定义函数

    没有形参

    function 函数名(){
        代码;
        #参数使用:$1,$2,...,${10}...
        return xxx;
    }
    
    return 的结果会被谁捕获: $?
    
    调用:
    函数名 值1 值2
  • 相关阅读:
    docker pull配置代理方法
    docker配合ssh管道跨主机传输镜像
    Java面向对象详解
    云服务器的公网IP和内网IP的区别
    开启 kubectl 命令的自动补全功能
    Vue+Openlayers实现绘制线段并测量距离显示
    Vue+Openlayers+elradio实现切换地图显示
    koa使用swagger自动生成接口文档
    什么是低代码
    前后端统一接口的响应参数数据结构
  • 原文地址:https://www.cnblogs.com/tfzz/p/12075235.html
Copyright © 2011-2022 走看看