设为首页 收藏本站
查看: 590|回复: 0

[经验分享] Linux 学习总结(三十)lamp之mysql安装

[复制链接]

尚未签到

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


二 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
DSC0001.jpg

  我们发现缺少perl 模块下的 Dumper包,我们尝试着找下
  yum list |grep perl |grep -i dumper    // -i 忽略大小写
DSC0002.jpg

  我们可以尝试安装这两个包,看是否可以解决上面问题,也可以两个都装上,再初始化。
  我们yum安装了上面第一个包后,再次初始化,发现又有一个问题,真是出师不利,不过不用怕,上网查了下解决办法:缺少libaio库文件,直接放了个大招,yum install -y libaio* 后来我发现可以直接
  yum povides libaio.so.1 找这个库文件,毕竟这个模糊匹配安装让人不踏实。
DSC0003.jpg

  安装完后,echo $?  结果为0 ,这下好了
  cp support-files/my-default.cnf  /etc/my.cnf
  拷贝配置文件模板并编辑,我们发现/etc/下已经有一个my.cnf 那么就可以不用上面那个my-default.cnf文件了,直接编辑该文件即可
  4 编辑配置文件
  vim  /etc/my.cnf
DSC0004.jpg

  我们定义datadir 和 socket 然后注释掉其他内容
  5 定义启动脚本
  cp support-files/mysql.server /etc/init.d/mysqld
  vim /etc/init.d/mysqld
  拷贝启动文件,并编辑
  定义basedir和datadir
DSC0005.jpg

  /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没有去定义,都处在注释状态。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-606862-1-1.html 上篇帖子: mysql主从配置&&基于keepalived的主备切换 下篇帖子: DBA:MySQL数据库类型
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表