您的位置:首页 > 运维架构 > Linux

linux SHELL 基础 附:shell安装MYSQL

2010-06-09 15:33 399 查看
SHELL[/b]

一、什么是shell[/b]

1、shell是用户与操作系统内核之间的界面,是一个命令解释器。[/b]

其功能表现为:指令解析[/b] 交互执行[/b] 程序设计[/b]
2、shell的种类:Linux支持的shell,列表文

件为/etc/shells
/bin/bsh:最早的shell,Bourne shell。
/bin/bash:Bourne Again shell。应用最为广泛。
/bin/csh:最新版本为tcsh
/bin/ksh:
/bin/zsh:最大的shell
3、查看当前shell:#echo $SHELL
4、使用不同shell:#shell名 (exit退出当前shell)
5、修改登录shell:#chsh [用户名]

二、shell的功能[/b]
1、输入输出处理功能
指令解析
多指令
指令组
子shell
特殊字符

2、指令功能
别名
历史命令
自动补齐
3、管道和重定向
输入输出重定向
管道

三、输入输出处理功能[/b]
1、指令解析:shell是一种命令解释器。shell区分大小写,其语法结构为:
#指令 [-选项] [--选项] 参数1 ...... 参数n
2、多指令:一次性执行多条指令。
#指令1;......;指令n
3、指令替代:
echo 回显命令。“echo 字符串”将字符串回显至屏幕
#指令1`指令2`,将指令2的执行结果作为指令1的参数使用。
#echo “今天是`date`”
今天是:2009-11-26
当前的系统时间是:15:20
4、指令组:将多个指令的执行结果作为一个结果输出。
#{指令1alias leo='echo "今天是:`date +%Y-%m-%d`";echo "当前 的系统时间是:`date +%H:%M:%S`" '
;......;指令n}
5、子shell:
6、特殊字符:
#注释

“”、‘’,转义字符,将特定意义的字符转换为普通字符。
\ , 转义字符。
“abc“
‘“abc“'
‘“\a"\b c"\'

通配符:* ? [ ] [^ ]

四、指令功能[/b]
1、别名功能:
查看别名:#alias
定义别名: #alias 别名=‘指令叙述’
alias leo='echo "今天是:`date +%Y-%m-% 108 cleard`";echo "当前 的系统时间是:`date +%H:%M:%S`" '
固化别名配置:/etc/bashrc 添加别名设置
2、历史命令
调用历史命令:使用上下方向键
历史命令列表:#history
调用特定的历史命令:#!历史命令编号
3、自动补齐:Tab

五、输入输出重定向[/b]
1、输入输出重定向:将进程的stdin、stdout、stderr由默认设备修改为特
定设备。
2、输入重定向:<,语法。 进程 < 输入设备

3、输出重定向:>,语法 进程 > 输出设备 (覆盖式添加)
输出追加重定向:>>,语法 进程 >> 输出设备 (追加式添加)
4、错误输出重定向:2>,语法 进程 2> 输出设备
错误输出追加重定向: 2>>,语法 进程 2>> 输出设备
5、&> 将标准输出和标准错误输出重定向到同一设备
6、/dev/zero 永远为0的文件
/dev/null 永远为空的文件
7、将局部变量转换为环境变量:#export 变量名
8、删除变量:#unset 变量名

六、变量的键盘读取[/b]
1、read 变量名 由标准输入设备读取数值,并将数值赋予变量。
read A
2、echo "输入被加数";read A;echo "输入加数";read B;echo $[$A+$B]

3、echo "输入值1";read A;echo "输入运算符";read S;echo "输入值
2";read B;echo $[$A $S $B]

4、echo Hello,$USER;echo "What is your name?";read
NAME;echo "Hello,$NAME,The current time is `date +%H:%M:
%S`"
5、read语法:
read 变量名 将由键盘输入的内容赋值给变量
read -p “提示信息” 变量名 -p在键盘输入前显示提示信息。
read -t 秒数 变量名 -t定义等待输入时间

对于同一变量而言,其新值会覆盖旧值。

七、控制命令[/b]
1、&&:语法: 命令1 && 命令2
如果命令1成功执行,则执行命令2。
在目录中如果有file1 文件则删除。
ls file1 &>/dev/null && rm -f file1

命令在执行完成后会出现一个退出码。0成功执行,非0不成功执行。
查看命令的退出码:#echo $?
2、||:语法: 命令1 || 命令2
如果命令1不成功执行则执行命令2。
在目录中如果没有file1文件则创建该文件。

3、文件创建程序:
要求用户输入待创建的文件的绝对路径(输入时间为10秒)

如果待创建文件已存在,则提示用户“文件已存在”
如果待创建文件不存在,则创建文件,并提示用户"文件已创建成功"
read - p "输入绝对路径" -t 10 123;ls $123 && echo "文件已存 在" || echo "文件`touch $123`已创建"
[align=center] [/align]

[align=center]shell命令行基本格式[/b] [/align]
$|#命令名 -选项 --选项 参数1 ...... 参数n
1、命令名:可执行文件,存放于系统的特定位置。
2、选项:-字符选项,--单字选项,选项决定了命令的执行方式。
3、参数:定义了命令的执行对象。
4、shell命令行对大小写敏感(区分大小写)
5、支持自动补齐功能。利用tab键实现。
shell script 001[/b]

一、正则表达式[/b]
1、正则表达式:是一个字符串,用于在搜索中匹配相同的字符串,即明确搜索内
容。
2、正则表达式的格式:元字符字符串
元字符用于搜索控制。
存在三套源字符:基本源字符(应用于所有应用程序)
扩展源字符
POSIX源字符
3、基本源字符
^字符串 锚定行的开始字符串 ^Document
字符串$ 锚定行的结尾字符串 Off$
. 匹配任意一个字符 k..p
[ ] 匹配中括号中的任意字符 ^[Tt]he
[^] 不匹配中括号中的任意字符 /^[^T]he
\ 转义字符

二、正则表达式的工具[/b]
1、vi中的正则表达式的工具
/ 查找工具:/正则表达式
:s 查找替换::起始行号,结束行号s/正则表达式/替换值/g
2、grep
grep用于在一个或多个文件中搜索包含特定字符串的行。
语法:grep [选项] 正则表达式 文件名
-n 显示被检索行的行号
-c 显示检索到的行数
-x 显示检索到的行的上下x行
-v 反向显示A;
-i 忽略正则表达式中字符的大小写
grep的返回值:grep成功检索到内容,返回 0
grep未成功检索到内容,返回1
grep检A=`head -n 29 /etc/passwd |tail -n 1|wc -m`;B=`echo $[$A/2]`; head -n 29 /etc/passwd |tail -n 1|cut -c 1-$B索的文件不存在,返回2
查看应用程序的返值:echo $?

三、变量[/b]
1、查看变量:
#set 查看所有变量
#env 查看环境变量
2、变量的转换(将本地变量转换为环境变量)
#export 变量名
3、变量的表示方法:$变量名
4、引用变量:#echo $变量名
#echo $?
#echo $$ 显示当前shell的进程编号
5、定义变量:变量名=变量值 A=10
6、删除变量:unset 变量名
7、修改变量的属性:#declare [选项] 变量名
-i 将变量定义为整形数据?
-x 将变量定义为环境变量
-r 将变量定义为只读变量,不能删除
和修改

四、变量的键盘读取--read[/b]
语法:#read 变量名 将由键盘输入的内容赋值给变量。
#read -p “提示信息:” 变量名
-p 显示提示信息的内容
#read -t 秒数 变量名
-t 设置等待输入时间

五、控制命令[/b]
&& 语#(命令)法:命令1 && 命令2

当命令1成功执行时,echo $?=0,执行命令2
当命令1不成功执行时,echo $?=1,不执行命令2,而
执行下一条命令。
|| 语法:命令1 || 命令2
当命令1不成功执行时,echo $? = 1,执行命令2
当命令1成功执行时,echo $? = 0,不执行命令2,而
执行下一条命令。
read A;grep^$A /etc/passwd >/dev/null && echo "存在该用
户" | | echo "用户不存在"

六、子shell[/b]
1、shell中对环境变量的修改会影响到Shell本身。子shell的环境变量不影响父shell。
2、定义子shell:#(命令)

附:

shell 安装MYSQL[/b]

一、安装脚本

#!/bin/bash

MYSQL_HOME=/usr/local/mysql
# 将你的mysql安装程序解压后的文件名设置为MYSQL_DIR,将安装程序(mysql-xxx.tar.gz)放到当前目录
MYSQL_DIR=mysql-standard-5.0.20-linux-i686-glibc23
MYSQL_DIR_OLD=$PWD/${MYSQL_DIR}
MYSQL_DIR_NEW=/usr/local/${MYSQL_DIR}
MYSQL_SOURCE=$MYSQL_DIR_OLD.tar.gz

if [ ! -f ${MYSQL_SOURCE} ]
then
echo "MySQL package not found!"
exit 1
fi

id mysql > /dev/null 2>&1
if [ $? -eq 1 ]
then
# If user mysql does not exist,
# delete group mysql fisrt if exists
sed -i '/^mysql/d' /etc/group
echo "Add group mysql"
groupadd mysql
echo "Add user mysql"
useradd -g mysql mysql
fi

echo "Unzip MySQL-5.0.20"
tar zxvf ${MYSQL_SOURCE} > /dev/null 2>&1

echo "Move MySQL to the right place"
mv ${MYSQL_DIR_OLD} ${MYSQL_DIR_NEW}

echo "Create mysql linkage"
ln -s ${MYSQL_DIR_NEW} ${MYSQL_HOME}

echo "Change mysql directory to the right user and group"
cd $MYSQL_HOME
chown -R root  .
cd $MYSQL_HOME
chown -R mysql data
cd $MYSQL_HOME
chgrp -R mysql .

echo "Create mysql system database"
$MYSQL_HOME/scripts/mysql_install_db --user=mysql > /dev/null

echo "Set environment PATH"
sed -i '/export PATH=\/usr\/local\/mysql\/bin:$PATH/d' /etc/profile
echo 'export PATH=/usr/local/mysql/bin:$PATH' >> /etc/profile
. /etc/profile

echo "Set mysql as system service"
cp $MYSQL_HOME/support-files/mysql.server /etc/init.d/mysql
chkconfig mysql on
/etc/init.d/mysql start

echo -n "Please input password of mysql user root: "
stty -echo
read ROOT_PASSWORD
stty echo
echo

if [ -z $ROOT_PASSWORD ]
then
echo "ERROR: The password is null!"
exit 1
fi

mysqladmin -uroot password "$ROOT_PASSWORD"
mysql -uroot -p$ROOT_PASSWORD -e"grant all on *.* to root@localhost identified by '$ROOT_PASSWORD'"
if [ $? -eq 0 ]
then
echo "Set mysql user root password successfully!"
fi


二、卸载脚本

#!/bin/bash

MYSQL_HOME=/usr/local/mysql
# 将你的mysql安装程序解压后的文件名设置为MYSQL_DIR
MYSQL_DIR=mysql-standard-5.0.20-linux-i686-glibc23
MYSQL_DIR_NEW=/usr/local/${MYSQL_DIR}

echo "Kill mysql demon"
pkill mysql > /dev/null 2>&1
echo "Clean mysql from PATH"
sed -i '/export PATH=\/usr\/local\/mysql\/bin:$PATH/d' /etc/profile

chkconfig mysql off
rm -f /etc/init.d/mysql
rm -f /etc/rc2.d/*mysql
rm -f /etc/rc3.d/*mysql
rm -f /etc/rc4.d/*mysql
rm -f /etc/rc5.d/*mysql
rm -f /etc/rc6.d/*mysql

echo "Remove mysql source file"
rm -rf ${MYSQL_HOME}
rm -rf ${MYSQL_DIR_NEW}

echo "Remove user mysql"
sed -i '/^mysql/d' /etc/group
sed -i '/^mysql/d' /etc/passwd


三、安装成功后,运行. /etc/profile将mysql路径添加进去
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  linux MYSQL 脚本