Linux 学习总结(三十)lamp之mysql安装
admin
2023-05-01 11:06:40
0

一 lamp架构介绍

lamp 是linux apache mysql php 的缩写,就是整个一套服务端环境,对于php开发的网站,我们访问到的页面或者数据很可能就是这套环境提供的。对于普通网民来说,我们没有注意我们访问到的网站内容,其实是分两大类的,一类是图片为代表的静态数据,一类是存储在数据库中的动态数据,比如我们登陆博客的用户名密码等。我们根据下图分解下各部分原理,linux当然是指我们的linux操作系统centos,ubuntu等。apache我们都知道他是一个基金会的名字,其实质是一个叫httpd的web server。mysql是数据库,用来存储动态数据,真正和他打交道的是一个叫php的应用。在lamp架构中,他作为httpd的一个模块存在。用户请求的静态文件直接存储在服务器上,动态数据存储在数据库中,通过php调用后传递给web,数据库可以单独装在其他服务器上,通过网络连接。
Linux 学习总结(三十)lamp之mysql安装

二 mysql安装

下面我们具体看下mysql的安装。
MySQL的几个常用安装包:rpm、源码、二进制免编译包安装
这里我们采用二进制免编译包安装,他相对于源码包来说不用去解决编译缺少库的错误,安装更简
单,因为他是在linux系统中编译好的, 相对与rpm来说他可以指定目录,方便包的管理。
cd /usr/local/src 到该目录下,以后统一将下载的应用包放在这里
wget http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz
下载一个mysql包,如果链接失效,可以再找其他镜像源
tar zxvf mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz
1 数据包重命名
mv mysql-5.6.35-linux-glibc2.5-x86_64 /usr/local/mysql
cd /usr/local/mysql
2 创建用户及数据存放目录

useradd mysql  
mkdir /data/   

3初始化
./scripts/mysql_install_db --user=mysql --datadir=/data/mysql
Linux 学习总结(三十)lamp之mysql安装
我们发现缺少perl 模块下的 Dumper包,我们尝试着找下
yum list |grep perl |grep -i dumper // -i 忽略大小写
Linux 学习总结(三十)lamp之mysql安装
我们可以尝试安装这两个包,看是否可以解决上面问题,也可以两个都装上,再初始化。
我们yum安装了上面第一个包后,再次初始化,发现又有一个问题,真是出师不利,不过不用怕,上网查了下解决办法:缺少libaio库文件,直接放了个大招,yum install -y libaio* 后来我发现可以直接
yum povides libaio.so.1 找这个库文件,毕竟这个模糊匹配安装让人不踏实。
Linux 学习总结(三十)lamp之mysql安装
安装完后,echo $? 结果为0 ,这下好了
cp support-files/my-default.cnf /etc/my.cnf
拷贝配置文件模板并编辑,我们发现/etc/下已经有一个my.cnf 那么就可以不用上面那个my-default.cnf文件了,直接编辑该文件即可
4 编辑配置文件
vim /etc/my.cnf
Linux 学习总结(三十)lamp之mysql安装
我们定义datadir 和 socket 然后注释掉其他内容
5 定义启动脚本
cp support-files/mysql.server /etc/init.d/mysqld
vim /etc/init.d/mysqld
拷贝启动文件,并编辑
定义basedir和datadir
Linux 学习总结(三十)lamp之mysql安装
/etc/init.d/mysqld start
出现sucess 后表示启动成功, 可以ps aux |grep mysqld 查看下进程。
6 要实现开机启动,可以

chkconfig --add mysqld    //加入系统服务列表
chkconfig mysqld on

备注:
一直以为mysql 优先加载/etc/my.cnf 该配置文件,后面发现原来不是这样的,按照我目前的理解,/etc 下面的配置文件应该属于yum 直接安装的应用。然而我们采用的是二进制免编译包的安装办法。那么为啥我们上面的配置没有问题呢,因为这个加载都定义在启动脚本中,在support-files/mysql.server文件中,定义了优先加载$basedir 下面的my.cnf配置文件。如果没有定义,才去找/etc/my.cnf,我们刚配置的/etc/my.cnf之所以可以生效,是因为$basedir /my.cnf没有去定义,都处在注释状态。

相关内容

热门资讯

美媒又想起这茬:2年前在地中海... 【文/观察者网 阮佳琪】2024年12月23日,载有16名船员的俄罗斯“大熊星座”号货船在西班牙近海...
App过度索取授权或被境外间谍... 微信公众号“国家安全部”5月13日发文: 手机里各种各样的应用程序(APP)五花八门,在方便我们生...
广合科技获得发明专利授权:“一... 证券之星消息,根据天眼查APP数据显示广合科技(001389)新获得一项发明专利授权,专利名为“一种...
华尔街科技老将:大科技公司分化... 5月11日,互联网泡沫时期的知名芯片分析师、Niles Investment Management创...
香港80后“地产女王”烧炭身亡... 据《香港01》报道,5月12日,香港九龙传统豪宅地段加多利山畔的豪宅项目Kadoorie Hill发...
谷歌发布安卓 AI 系统,这就... 和去年一样,在正式的 Google I/O 开发者大会之前,谷歌为 Android 单独开了一次小型...
300斤医生走红 曾一年猛涨1...   300斤医生走红 曾一年猛涨100斤  【300斤医生走红 曾一年猛涨100斤】5月11日,上海...
新乡市主要负责同志职务调整 日前,中共河南省委决定:魏建平同志任中共新乡市委书记,李卫东同志不再担任中共新乡市委书记、常委、委员...
九阳电饭锅H01故障 H01是因为上盖异常高温,有可能是机板不良造成的;同时也可能是故障前没有清洗上盖或溢出米浆等情况造成...
电饭煲显示e3是什么原因 1、可能是电饭煲里面的食物水分烧干之后,密封圈在高温运转的环境下被烧焦了,这个情况下可能会出现故障提...