LNMP架构介绍 MySQL安装 PHP安装 Nginx介绍

Stella981
• 阅读 506

LNMP架构介绍

LNMP的简介:

  • LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构。
  • Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器。
  • Mysql是一个小型关系型数据库管理系统。
  • PHP是一种在服务器端执行的嵌入HTML文档的脚本语言。
  • 这四种软件均为免费开源软件,组合到一起,成为一个免费、高效、扩展性强的网站服务系统。

LNMP的特点:

Nginx是一个小巧而高效的Linux下的Web服务器软件,是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler 站点开发的,已经在一些俄罗斯的大型网站上运行多年,相当的稳定。Nginx性能稳定、功能丰富、运维简单、处理静态文件速度快且消耗系统资源极少。

LNMP的优点:

  • 作为 Web 服务器:相比 Apache,Nginx 使用更少的资源,支持更多的并发连接,体现更高的效率。
  • 作为负载均衡服务器:Nginx 既可以在内部直接支持 Rails 和 PHP,也可以支持作为 HTTP代理服务器对外进行服务。Nginx 用C编写,不论是系统资源开销还是CPU使用效率都比Perlbal要好的多。
  • 作为邮件代理服务器:Nginx同时也是一个非常优秀的邮件代理服务器(最早开发这个产品的目的之一也是作为邮件代理服务器),Last/fm 描述了成功并且美妙的使用经验。
  • Nginx 安装非常的简单:配置文件非常简洁(还能够支持perl语法)。Nginx支持平滑加载新的配置,还能够在不间断服务的情况下进行软件版本的升级。

流程:

并且php是作为一个独立服务存在的,这个服务叫做php-fpm,Nginx直接处理静态请求,动态请求会转发给php-fpm

LNMP架构介绍 MySQL安装 PHP安装  Nginx介绍

MySQL安装

[root@jiangshan src]# cd /usr/local/src
[root@jiangshan src]# wget http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz 
[root@jiangshan src]# ls
mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz

解压

tar zxvf mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz
## 移动并重命名
[root@jiangshan src]# mv mysql-5.6.35-linux-glibc2.5-x86_64 /usr/local/mysql
[root@jiangshan src]# cd /usr/local/mysql

####创建用户

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

####初始化

[root@jiangshan mysql]# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysql
## --user指定用户 
##--datadir 数据存放目录(data目录必须存在)
## --defaults-file=/etc/my.cnf指定配置文件位置 不加默认为/etc/my.cnf

#####初始化错误

[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::Dumper
## 解决
yum install -y perl-Data-Dumper.x86_64

####检测 查看是否输出两个ok或者echo $?是否输出0

[root@localhost mysql]# echo $?
0

####拷贝配置文件

## my-default.cnf为配置文件模板
cp support-files/my-default.cnf  /etc/my.cnf             #配置文件
cp support-files/mysql.server /etc/init.d/mysqld        #启动脚本
  • my-default.cnf为配置文件模板
  • 配置文件的默认位置为/etc/my.cnf,如果配置文件没有放在这。启动时需要指定配置文件位置,–defaults-file=filename

默认有my.conf文件可以修改

[root@jiangshan mysql]# rpm -qf /etc/my.cnf
mariadb-libs-5.5.52-1.el7.x86_64
[root@jiangshan mysql]# vim  /etc/my.conf
[mysqld]
datadir=/var/lib/mysql                                      ##改为 /data/mysql
socket=/var/mysq/lib/mysql.sock                           ##改为 /tmp/mysql.sock
[mysqld_safe]
log-error=/var/log/mariadb/mariadb.log                  加#注释
lpid-file=/var/run/mariadb/mariadb.pid                    加#注释

####修改配置文件

vi  /etc/init.d/mysqld
  • datadir:/usr/local/mysql 软件安装目录

  • basedir:/data/mysql 数据存放目录

服务启动

[root@jiangshan mysql]# /etc/init.d/mysqld 

####关闭MySQL

service mysqld stop

[root@jiangshan mysql]# service mysqld stop
Shutting down MySQL.. SUCCESS! 
[root@jiangshanmysql]# ps aux   |grep  "mysql"
root      4608  0.0  0.0 112664   976 pts/0    R+   23:23   0:00 grep --color=auto mysql

PHP安装

####下载二进制包

cd /usr/local/src
wget http://cn2.php.net/distributions/php-5.6.30.tar.gz

####解压

tar  -zxvf php-6.6.30.tar.gz
cd php-5.6.30

####初始化安装

./configure --prefix=/usr/local/php --with-apxs2=/usr/local/apache2.4/bin/apxs --with-config-file-path=/usr/local/php/etc  --with-mysql=/usr/local/mysql --with-pdo-mysql=/usr/local/mysql --with-mysqli=/usr/local/mysql/bin/mysql_config --with-libxml-dir --with-gd --with-jpeg-dir --with-png-dir --with-freetype-dir --with-iconv-dir --with-zlib-dir --with-bz2 --with-openssl --with-mcrypt --enable-soap --enable-gd-native-ttf --enable-mbstring --enable-sockets --enable-exif

##编译中除了指定安装位置,还需要指定Apache和MySQL的相关位置,这也是为什么PHP需要在最后安装。因为PHP需要Apache和MySQL的支持

####依旧可以使用echo $?查询是否成功

make  &&  make  install  && echo $?

####拷贝配置文件

cp php.ini-production  /usr/local/php/etc/php.ini

####如何查看PHP安装时的编译参数以及配置php.ini的位置

/usr/local/php/bin/php -i|less

####Apache是否加载了php模块,即形成.so文件

[root@jiangshan ~]# ls /usr/local/apache2.4/modules/libphp5.so 
/usr/local/apache2.4/modules/libphp5.so

####查询php加载模块

/usr/local/php/bin/php -m
[root@jiangshan ~ ]# /usr/local/php/bin/php -m
[PHP Modules]
bz2
Core
ctype
date
dom
ereg
exif
fileinfo
filter
gd
hash
.........

Nginx介绍

  • Nginx官网 nginx.org,最新版1.13,最新稳定版1.12

  • Nginx应用场景:web服务、反向代理、负载均衡

  • Nginx著名分支,淘宝基于Nginx开发的Tengine,使用上和Nginx一致,服务名,配置文件名都一样,和Nginx的最大区别在于Tenging增加了一些定制化模块,在安全限速方面表现突出,另外它支持对js,css合并

  • Nginx核心+lua相关的组件和模块组成了一个支持lua的高性能web容器openresty,

    参考

##拓展

Nginx为什么比Apache Httpd高效:原理篇

apache和nginx工作原理比较

mod_php 和 mod_fastcgi以及php-fpm的比较

概念了解:CGI,FastCGI,PHP-CGI与PHP-FPM

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Wesley13 Wesley13
2年前
LNMP架构之环境搭建
本文索引:LAMP架构介绍Mysql的安装PHP的安装Nginx介绍Nginx的安装LNMP架构介绍LNMPLinuxNingxMysqlPHP!lnmp(https://github.com/castielLu/pic/blob/master
Stella981 Stella981
2年前
CentOS 7.6 源码安装搭建LNMP架构(Nginx、MYSQL、PHP)
LNMP架构LNMP是什么搭建环境搭建准备LNMP软件包搭建nginx搭建mysql数据库搭建php搭建Discuz!论坛LNMP是什么LNMP:Linux系统下NginxMySQLPHP这种网站服务器架构。Nginx是一个高性能的HTTP和
Easter79 Easter79
2年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这