LAMP架构介绍、MYSQL介绍、安装

  1. 云栖社区>
  2. 博客>
  3. 正文

LAMP架构介绍、MYSQL介绍、安装

科技小能手 2017-11-12 16:32:00 浏览739

LAMP 架构

LAMP 指的Linux(操作系统)、Apache(httpd服务器)、MySQL(数据库软件)和PHP(有时也是指Per或Python)的缩写,一般用来建立web服务器(三个角色可以在一台机器,也可以分开。但是,Apache和PHP要安装在一起)。

LAMP 架构介绍

  • httpd、PHP、MySQL三者如何工作
    q77B6.png

说明: Apache和PHP是一个整体,因为PHP是以一个模块的形式和Apache结合在一起的。但是Apache不能直接和MySQL直接打交道,它只能通过PHP模块去MySQL中取数据,拿到数据后PHP把数据交给Apache,Apache再把数据交给用户。服务器上的图片、js、css等文件属于静态文件;数据库文件是动态文件。

MySQL、MariaDB 介绍

MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。(MySQL是由mysql ab公司开发,在2008年被sun公司收购,2009年sun被Oracle公司收购。)

MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护。MariaDB直到5.5版本,均依照MySQL的版本。从2012年11月12日起发布的10.0.0版开始,不再依照MySQL的版号。10.0.x版以5.5版为基础,加上移植自MySQL5.6版的功能和自行开发的新功能。

MySQL 版本

community 社区版(社区版,免费的);enterprise 企业版(收费的);GA(generally available) 通用版,在生产环境中使用;DMR(development milestone release) 开发里程碑版本;RC(release candidate) 发行候选版本;Beta 开放测试版本;Alpha 内部测试版本。

安装MySQL

  • MySQL 的几个常用安装包:rpm包、源码包、二进制免编译包

  • 下载包之前需要查看系统的版本,根据系统版本来选择需要安装的包。通过命令uname -a可以查看到关于系统版本的信息。(x86_64为64为操作系统,i686 i586为32位操作系统)

  • 下载包

    将二进制免编译包下载到/usr/local/src/目录下。
    [root@localhost ~]# cd /usr/local/src
    [root@localhost src]# wget http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz

    下载完成之后,在目录/usr/local/src/下会有一个压缩包 mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz

  • 解压包

    在/usr/local/src/目录下解压包

    [root@localhost src]# tar -zxv -f mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz

  • 移动解压后的文件并修改文件名

    将解压出来的mysql-5.6.35-linux-glibc2.5-x86_64 文件移动到/usr/local/目录下,并改名为mysql。

    [root@localhost src]# mv mysql-5.6.35-linux-glibc2.5-x86_64 /usr/local/mysql

  • 切换到/usr/local/mysql/目录

    切换到/usr/local/mysql/目录下之后,检查目录下是否下是否存在以下文件、目录。

    [root@localhost src]# cd /usr/local/mysql/
    [root@localhost mysql]# ls
    bin COPYING data docs include lib man mysql-test README scripts share sql-bench support-files

  • 创建mysql用户、创建/data/目录

    [root@localhost mysql]# useradd mysql
    [root@localhost mysql]# mkdir /data/

  • 初始化mysql

    [root@localhost mysql]# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysql
    FATAL ERROR: please install the following Perl modules before executing ./scripts/mysql_install_db:
    Data::Dumpe

    Installing MySQL system tables..../bin/mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory
    缺少libaio.so包

提示缺少perl模块,模块名为dump

  • 使用yum list命令配合grep查看需要安装的包

    [root@localhost mysql]# yum list | grep perl | grep -i dumper
    perl-Data-Dumper.x86_64 2.145-3.el7 base 
    perl-Data-Dumper-Concise.noarch 2.020-6.el7 epel 
    perl-Data-Dumper-Names.noarch 0.03-17.el7 epel 
    perl-XML-Dumper.noarch 0.81-17.el7 base

    查找到相关的包后就挨个安装。然后再安装mysql。

注意:如果在安装过程中出现两个ok,则安装成功。或者使用命令echo $? 命令,输出结果为0则安装成功。结果为1则安装失败。

  • 拷贝配置文件

    配置文件的目录为:/usr/local/mysql/support-files/my-default.cnf

    [root@localhost mysql]# cp support-files/my-default.cnf /etc/my.cnf

mysql的配置文件固定放在/etc/下,并且名字为my.cnf(如果为其它目录需要去指定,否则系统只会去找/etc/my.cnf文件。)

  • 也可以不拷贝配置文件,直接使用现成的

    在/etc/目录下有my.cnf文件,编辑此文件。

    将下面两行修改成如下内容:
    datadir=/data/mysql
    socket=/tmp/mysql.sock
    注释掉这三行:

    log-error=/var/log/mariadb/mariadb.log

    pid-file=/var/run/mariadb/mariadb.pid

    !includedir /etc/my.cnf.d

  • 启动脚本

    启动脚本目录为:/usr/local/mysql/support-files/mysql.server

    将启动脚本拷贝到/etc/init.d/目录下,改名为:mysqld
    [root@localhost mysql]# cp support-files/mysql.server /etc/init.d/mysqld

    编辑/etc/init.d/mysqld文件:
    basedir=/usr/local/mysql
    datadir=/data/mysql
    (46,47行)

    权限变更:
    将文件权限改为755(默认为755,不需要改)
    chomd 755 /etc/init.d/mysqld

    设置开机启动,将该服务加到系统服务列表中:
    [root@localhost mysql]# chkconfig --add mysqld
    [root@localhost mysql]# chkconfig --list

    注意:该输出结果只显示 SysV 服务,并不包含原生 systemd 服务。SysV 配置数据可能被原生 systemd 配置覆盖。 
    如果您想列出 systemd 服务,请执行 'systemctl list-unit-files'。
    欲查看对特定 target 启用的服务请执行
    'systemctl list-dependencies [target]'。
    mysqld 0:关 1:关 2:开 3:开 4:开 5:开 6:关

    还可以直接用命令启动:

    /etc/init.d/mysqld start

    service mysqld start

    [root@localhost mysql]# service mysqld start
    Starting MySQL.Logging to '/data/mysql/localhost.localdomain.err'.
    . SUCCESS! #启动成功
    可以使用命令:
    ps aux | grep mysqld 查看进程
    netstat -lntp 查看监听端口

    停止mysqld服务
    service mysqld stop

    命令行的方式启动(&在后台启动):
    /usr/local/mysql/bin/mysqld_safe --defaults-file=/etc/my.cnf --user=mysql --datadir=/data/mysql &

  • 关闭mysqld服务

    使用killall命令关闭服务。

  • kill命令和killall命令

kill命令和killall命令都是用来杀死系统中的进程,区别是:

1、kill用来杀死单个进程,killall用来杀死进程树

2、使用kill命令会立刻结束正在运行中的进程,如果该进程正在进行磁盘的读写,那么数据会因为进程的结束而丢失,而killall命令会等待该数据读写完毕后再将相关进程结束,相对来说使用起来更加安全。


本文转自 豆渣锅 51CTO博客,原文链接:http://blog.51cto.com/754599082/2050796