shell编程

十六 mysql安装

以源码安装的方式编译和安装Mysql 5.6

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 上传本地mysql5.6源码包至/opt

xftp连接上传

2.3 编译

tar -zxvf mysql-5.6.14.tar.gz		解压
cd mysql-5.6.14						切换目录

编译准备:
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_c

编译并安装:
make && make install

2.4 配置mysql

权限管理:

1.创建mysql组,及用户
	groupadd mysql
	useradd -g mysql mysql
	
2.修改/usr/local/mysql权限
	chown -R mysql:mysql /usr/local/mysql
	
	
初始化配置:
1.cd /usr/local/mysql
2.scripts/mysql_install_db

在启动MySQL服务时,会先在/etc目录下找my.cnf,找不到则会搜索"$basedir/my.cnf",在本例中就是 /usr/local/mysql/my.cnf

查看/etc下是否有my.cnf,有就换个名字,防止干扰
1.mv /etc/my.cnf /etc/my.cnf.bak

添加服务(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

配置环境变量:
1.vi /etc/profile
2.在文件中加入:
	export PATH=$PATH:/usr/local/mysql/bin
3.source /etc/profile

十七 shell编程

17.1 shell编程是个啥

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

画图说明

17.2 shell编程打印hello world

17.2.1 代码部分

#!/bin/bash
echo 'hello world'

代码解释:

1.#!/bin/bash:

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

2.echo:

​ 控制台输出

17.2.2 执行代码

方式一:

给脚本可执行权限

chmod 744 myshell.sh

然后直接运行脚本

方式二:(不推荐)

直接调用shell解释器执行

sh myshell.sh

17.3 注释

单行注释

#内容

多行注释

:<<!
内容
!

17.4 变量

17.4.1 变量的介绍

1.Linux中变量的分类:系统变量	自定义变量
2.系统变量:
	$PATH
	$HOME
	$PWD
	$SHELL
	$USER
3.显示当前shell中所有的变量:set (直接用就好,不用加什么后缀)

17.4.2 变量的定义

基本语法

1.定义变量:变量名=变量值   (不能加空格)
2.撤销变量:unset 变量名
3.声明静态变量:readonly 变量名.	(相当于常量)	静态变量不能unset

快速入门

1.定义变量a
2.撤销变量a
3.声明静态变量b=2,尝试unset撤销

定义规则

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

将命令的返回值赋给变量

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

17.5 设置环境变量

基本语法

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

快速入门

1.在/etc/profile文件中定义MY_NAME环境变量
2.查看环境变量MY_NAME的值

强调:在使用MY_NAME前,需要让其生效
3.source /etc/profile

4,在另外一个shell程序中使用MY_NAME


17.6 位置参数变量

介绍

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

基本语法

1.
$n (功能描述:n 为数字,$0 代表命令本身,$1-$9 代表第一到第九个参数,十以上的参数,十以上的参数需要用大括号包含,如${10})

2.
$* (功能描述:这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体)

3.
$@  (功能描述:这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待)

4.
$#(功能描述:这个变量代表命令行中所有参数的个数)


快速入门

编写一个shell脚本,pasition.sh,在脚本中获取到命令行的各个参数信息

17.7 预定义变量

介绍

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

基本语法

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

快速入门

在一个shell脚本pre.sh中简单实用一下预定义变量(提示, ./myshell.sh &  后台运行myshell.sh)

17.8 运算符

基本语法

1.$((运算式))   (这种方式里面加不加空格都可以)
2.$[运算式]		(这种也是)
3.`expr m + n`		(这种方式一定要加空格)
	例子: res=`expr \( 2 + 3 \) \* 4`  (\必须要加)

	特点:运算符之间要有空格
	+
	-
	/
	%
	\*
	\(	\)
	

快速入门

写一个demo.sh完成:
1.3种方式计算(2+3)*4的值
2.方式2求出命令行两个参数的和

17.9 判断

基本语法

[ 条件 ]			注意:条件前后要有空格

特别的:
[ 非空 ]	  为true
[ ]		   为false
[ haha ] && echo true || echo false   (用这种方式,前面haha如果为true,就打印第一个,反之打印第二个)

例子:
[ "a" = "ok" ] && echo true || echo false
这里的判断条件的 = 前后一定要加空格,不然就会变成一个字符串了。

判断语句

字符串比较

=	判等
!=  判不相等

整数比较

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

不支持 > < 这种符号

文件权限判断

-r	有读的权限	[ -r 文件 ]
-w	有写的权限
-x	有执行权限

文件类型判断

-f 存在并且是一般文件	[-f 文件]
-e 文件存在
-d 存在并且是一个目录

快速入门

1.'ok'是否等于'ok'
2.'ok100' 是否等于 'ok'

3.23 是否大于 23
4.23 是否大于等于 23

5./root是否存在
 [ -e /root ] && echo true || echo false
6./root是否是一般文件

17.10 流程控制

17.10.1 if判断

基本语法

if [ 条件 ]
then
	代码
fi        (倒过来写,表示if结束了,恶心)

if [ 条件 ]
then
	代码
else
	代码
fi

if [ 条件 ]
then
	代码
elif [ 条件 ]
then
	代码
else
	代码
fi

快速入门

编写shell脚本,if.sh:
如果输入参数,大于等于60,则输出'及格了',如果小于60,则输出'不及格'

17.10.2 case 选择分支

基本语法(相当诡异,令人发指,what a fuck)

case $变量名 in
'值1')
代码
;;
'值2')
代码
;;
*)
代码					都没命中执行
;;
esac   (同理,case翻过来表示结束了。这个case类似于switch)



快速入门

编写shell脚本,case.sh:
当命令行参数是1时,输出'周一';是2时,输出'周二',是3时,输出'周三',其它情况,输出'其它'

答案:
case $1 in  #这里的$1代表传进来的第一个参数,可以一直到$9,第十个开始就要${10}
'1')
        echo "星期一"
;;
'2')
        echo "星期二"
;;
*)
        echo "其他"
esac

在命令行这样输入 sh hello.sh 参数   即可

17.10.3 for循环

遍历

基本语法
for 变量 in 值1 值2 值3
do
	代码
done

例子:
#$@表示把传过来的参数分成一个一个,而不是一个整体,输出的时候是一行一行的,一行一个数字
for i in "$@"    

do
        echo $i
done
-----------------------
#$*表示把传过来的参数看成一个整体,而不是一个一个,输出的时候是一行的,包含全部数字
for i in "$*"    

do
        echo $i
done

快速入门
编写foreach.sh:
打印命令行输入的参数[这里可以看出$*和$@的区别]

循环

基本语法
#和js的循环一样
for ((初始值;循环条件;变量变化))
do
	代码
done

快速入门
编写for.sh:
从1加到100,并输出结果

17.10.4 while循环

基本语法

while [ 条件 ]
do
	代码
done

快速入门

编写while.sh:
从命令行中输出一个数n,统计1+...+n的值是多少

17.11 与用户交互

基本语法

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

例子

read -p "输入名字:" -t 3 name  #3秒之后关闭输入框,无论你输入了什么,都作废
echo "$name"

快速入门

编写input.sh:
1.读取控制带输入的值
2.读取控制台输入的值,等待6秒

17.12 函数

17.12.1 系统函数

basename

基本语法
basename [pathname] [suffix]
获得路径最后一部分

如果指定的suffix,那么会去掉结果中suffix的部分

快速入门
1.返回/home/aaa/test.txt中'test.txt'的部分
2.返回/home/aaa/test.txt中'test'的部分

dirname

基本语法
dirname [pathname]
获得基础路径

快速入门
1.返回/home/aaa/test.txt中'/home/aaa'的部分

17.12.2 自定义函数

基本语法

function 函数名(){
	代码;
	#参数使用:$1,$2,...,${10}...
	return xxx;
}

调用:
函数名 值1 值2

快速入门

编写func.sh:
用函数的形式,计算两个参数的和
函数里面的return是用来返回状态的,只能返回0到255,返回其他的,或者字符串都会错。

例子
function test(){
        res=$[$1+$2]
        echo "$res"
}

res=`test 130 120`
echo $res


17.13 shell综合案例

在/root下编写mysql_db_backuo.sh

需求:
1.每天凌晨2点10分,备份数据库mydb  到/data/backup/db
2.备份开始和备份结束时能够给出提示信息
3.备份后的文件要求以备份时间为文件名,并打包成.tar.gz的形式,如2019-09-28-044403.tar.gz
4.在备份的同时,检查是否有10天前的备份文件,如果有就删除

#!/bin/bash

#备份的路径
BACKUP=/data/backup/db
#当前的时间作为文件名
DATETIME=$(date +%Y_%m_%d_%H%M%S)

echo "=======开始备份======"
echo "=====备份的路径是 $BACKUP/$DATETIME.tar.gz"

#主机
HOST=localhost
#用户名
DB_USER=root
#密码
DB_PWD=997997
#备份的数据库
DATABASE=mydb



如果备份路径不存在,就创建
[ ! -d "$BACKUP/DATETIME" ] && mkdir -p "$BACKUP/$DATETIME"
#执行mysql的备份指令
mysqldump -u$DB_USER -p$DB_PWD --host=$HOST $DATABASE | gzip > $BACKUO/$DATETIME/$DATETIME.sql.gz
#打包备份文件
cd $BACKUP
tar -zcvf $DATETIME.tar.gz $DATETIME
#删除临时目录
rm -rf $BACKUP/$DATETIME


#删除10天前的文件
find $BACKUP -mtime +10 --name "*.tar.gz" -exec rm -rf {} \;

echo "=====备份成功+++++"

十八 程序员装逼之----Ubuntu

18.1 Ubuntu介绍

1.Ubuntu是一个以桌面应用为主的开源操作系统,它的界面做的非常好看

2.专业的程序员一般会选择Ubuntu

原因:
1.为了装逼
2.开发环境更加接近真实服务器环境,因为都是基于GNU/Linux内核开发的
3.穷

3.下载地址:http://cn.ubuntu.com/download

18.2 安装

略,比centos更加简单

18.3 设置Ubuntu支持中文

默认安装的
ubuntu 中只有英文语言,因此是不能显示汉字的。要正确显示汉字,需要安装中文语言包。

步骤:

1.单击左侧图标栏打开 System Settings(系统设置)菜单,点击打开 Language Support(语言支持)选项卡。
2.点击 Install / Remove Languages,在弹出的选项卡中下拉找到 Chinese(Simplified),即中文简体, 在后面的选项框中打勾。然后点击 Apply Changes 提交,系统会自动联网下载中文语言包。(保证
ubuntu 是联网的)。
3.这时“汉语(中国)”在最后一位因为当前第一位是”English”,所以默认显示都是英文。我们如果希望默认显示用中文,则应该将“汉语(中国)”设置为第一位。设置方法是拖动,鼠标单击
“汉语(中国)”,当底色变化(表示选中了)后,按住鼠标左键不松手,向上拖动放置到第一位。
4.设置后不会即刻生效,需要下一次登录时才会生效。

18.4 root用户

ubuntu安装后,默认是普通用户,这时候要获得权限就得:

1.sudo

2.su root

设置root用户的密码并使

1.sudo passwd

18.5 Ubuntu使用python

ubuntu安装成功后,默认会带上python2 和 python3,无需另外安装

ubuntu下可以安装各种python的ide环境,包括pycharm

https://baijiahao.baidu.com/s?id=1622347860160507809&wfr=spider&for=pc

18.6 apt软件管理工具

apt 是 Advanced Packaging Tool 的简称,是一款安装包管理工具。在 Ubuntu 下,我们可以使用 apt

命令可用于软件包的安装、删除、清理等,

apt软件相关命令

sudo apt-get update	更新源
sudo apt-get install package 安装包
sudo apt-get remove package 删除包
sudo apt-cache show package	获取包的相关信息,如说明、大小、版本等
sudo apt-get source package	下载该包的源代码


----------------------以上命令最为常用---------------------------


sudo apt-cache search package 搜索软件包
sudo apt-get install package --reinstall	重新安装包
sudo apt-get -f install	修复安装
sudo apt-get remove package --purge 删除包,包括配置文件等
sudo apt-get build-dep package 安装相关的编译环境
sudo apt-get upgrade 更新已安装的包
sudo apt-get dist-upgrade 升级系统
sudo apt-cache depends package 了解使用该包依赖那些包sudo apt-cache rdepends package 查看该包被哪些包依赖


更换镜像源

清华开源软件镜像站:https://mirrors.tuna.tsinghua.edu.cn/

ubuntu的软件源配置文件是/ect/apt/source.list

1.备份/ect/apt/source.list

mv /ect/apt/source.list /ect/apt/source.list.backup

若权限不够,切换root用户,或使用sudo

2.替换/ect/apt/source.list内容

1.vim /ect/apt/source.list
2.写入清华镜像源文件内容

小案例

1.apt-get remove vim
2.apt-get install vim
3.apt-cache show vim

18.7 ssh远程登录

和 CentOS 不一样,Ubuntu 默认没有安装
SSHD 服务,因此需要安装

18.7.1 安装

apt-get install openssh-server
service sshd restart

查看监听状态:
netstat -nap | more

此时xshell就可以连接了

18.7.2 其它

openssh-sever会安装客户端和服务端,
所以ubuntu在此时也可以连接其它有sshd服务的机器


基本语法:
ssh 用户名@IP
例如:ssh mac@192.168.188.131
使用 ssh 访问,如访问出现错误。可查看是否有该文件 ~/.ssh/known_ssh  尝试删除该文件解决。
登出命令:exit 或者 logout

posted @ 2020-01-14 14:48  chanyuli  阅读(186)  评论(0编辑  收藏  举报