linux编译安装mysql shell_linux源码安装mysql,shell编程学习,ubuntu

一。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

卸载c的编译工具

下载c的编译工具

yum-y install make gcc-c++ cmake bison-devel ncurses-devel

上传本地mysql5.6源码包志/opt

xftp连接上传

编译

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_ci

编译并安装:

make&& make install

配置mysl

权限管理:1.创建mysql组,及用户

groupadd mysql

useradd-g mysql mysql2.修改/usr/local/mysql权限

chown-R mysql:mysql /usr/local/mysql

初始化配置:1.cd /usr/local/mysql2.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.se

rver/etc/init.d/mysql2.chkconfig mysql on3.service mysql start

若失败重新修改权限

配置环境变量:1.vi /etc/profile2.在文件中加入:

export PATH=$PATH:/usr/local/mysql/bin3.source /etc/profile

二。shell编程

1.什么是shell编程

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

2.shell编程打印hello world

代码:

#!/bin/bash

echo 'hello world'

.#!/bin/bash:

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

echo:

控制台输出。

执行代码

给脚本可执行权限

chmod744myshell.sh

然后直接运行脚本

直接调用shell解释器执行

bash myshell.sh

3.注释

单行注释#内容

多行注释

:<

内容

!

4.变量

变量的介绍

1.Linux中变量的分类:系统变量 自定义变量2.系统变量:

$PATH

$HOME

$PWD

$SHELL

$USER3.显示当前shell中所有的变量:set

变量的定义

基本语法1.定义变量:变量名=变量值2.撤销变量:unset 变量名3.声明静态变量:readonly 变量名. 静态变量不能unset

快速入门1.定义变量a2.撤销变量a3.声明静态变量b=2,尝试unset撤销

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

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

5.设置环境变量

基本语法

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

快速入门

1.在/etc/profile文件中定义MY_NAME环境变量

vim/etc/profile

MY_NAME="mac"

2.查看环境变量MY_NAME的值

强调:在使用MY_NAME前,需要让其生效3.source /etc/profile4,在另外一个shell程序中使用MY_NAME

6.位置参数变量

介绍

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

基本语法

1.

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

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

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

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

快速入门

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

7.预定义变量

介绍

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

基本语法

$$ (功能描述:当前进程的进程号(PID))

$! (功能描述:后台运行的最后一个进程的进程号(PID))

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

快速入门

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

8.运算符

基本语法

1.$((运算式))2.$[运算式]3.`expr m +n`

特点:运算符之间要有空格+

-

/

%\*\( \)

快速入门

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

9.判断

基本语法

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

特别的:

[ 非空 ] 为true

[] 为false

[ haha ]&& 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是否存在6./root是否是一般文件

10.流程控制

1.if判断

if[ 条件 ]

then

代码

fi

if[ 条件 ]

then

代码else代码

fi

if[ 条件 ]

then

代码elif[ 条件 ]

then

代码else代码

fi

练习

编写shell脚本,if.sh:

如果输入参数,大于等于60,则输出'及格了',如果小于60,则输出'不及格'

2.case选择分支

case $变量名 in

'值1')

代码

;;'值2')

代码

;;*)

代码 都没命中执行

;;

esac

编写shell脚本,case.sh:

当命令行参数是1时,输出'周一';是2时,输出'周二',是3时,输出'周三',其它情况,输出'其它'

3.for循环

for 变量 in值1 值2 值3

do

代码

done

快速入门

编写foreach.sh:

打印命令行输入的参数[这里可以看出$*和$@的区别]

循环

for((初始值;循环条件;变量变化))

do

代码

done

入门

编写for.sh:

从1加到100,并输出结果

4.while循环

while[ 条件 ]

do

代码

done

快速入门

编写while.sh:

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

11.与用户交互

基本语法

read 选项 变量

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

入门

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

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'的部分

2。自定义函数

function 函数名(){

代码;#参数使用:$1,$2,...,${10}...

returnxxx;

}

调用:

函数名 值1 值2

快速入门

编写func.sh:

用函数的形式,计算两个参数的和

13.shell综合案例

在/root下编写mysql_db_backuo.sh

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

1.ubuntu介绍

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

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

2.安装

同centos

3.这只ubuntu支持中文

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

步骤

1.单击左侧图标栏打开 System Settings(系统设置)菜单,点击打开 Language Support(语言支持)选项卡。2.点击 Install /Remove Languages,在弹出的选项卡中下拉找到 Chinese(Simplified),即中文简体, 在后面的选项框中打勾。然后点击 Apply Changes 提交,系统会自动联网下载中文语言包。(保证

ubuntu 是联网的)。3.这时“汉语(中国)”在最后一位因为当前第一位是”English”,所以默认显示都是英文。我们如果希望默认显示用中文,则应该将“汉语(中国)”设置为第一位。设置方法是拖动,鼠标单击

“汉语(中国)”,当底色变化(表示选中了)后,按住鼠标左键不松手,向上拖动放置到第一位。4.设置后不会即刻生效,需要下一次登录时才会生效。

4.root用户

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

1.sudo

2.su root

设置root用户的密码并使用

1.sudo passwd

5.ubuntu使用python

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

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

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 查看该包被哪些包依赖

更换镜像源

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.list2.写入清华镜像源文件内容

小案例

1.apt-get remove vim2.apt-get install vim3.apt-cache show vim

7.ssh远程登录

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

1 安装

apt-get install openssh-server

service sshd restart

查看监听状态:

netstat-nap | more

此时xshell就可以连接了

2.其他

openssh-sever会安装客户端和服务端,

所以ubuntu在此时也可以连接其它有sshd服务的机器

基本语法:

ssh 用户名@IP

例如:ssh mac@192.168.188.131使用 ssh 访问,如访问出现错误。可查看是否有该文件 ~/.ssh/known_ssh 尝试删除该文件解决。

登出命令:exit 或者 logout

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值