lnmp集群的搭建及优化

本文详细介绍了LNMP(Linux、Nginx、MySQL、PHP)集群的搭建过程,包括MySQL的安装、Nginx的配置以及PHP的集成。此外,还探讨了如何在PHP中增加memcache模块以提升性能,并分享了使用OpenResty增强Nginx功能以及通过Nginx添加memcache支持的方法。同时,文章提到了Discuz论坛的搭建,以及在优化过程中考虑的Tomcat应用。
摘要由CSDN通过智能技术生成

lnmp

名词解释

LNMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写。L指Linux,N指Nginx,M一般指MySQL,也可以指MariaDB,P一般指PHP,也可以指Perl或Python。
LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构。
Linux是一类Unix计算机操作系统的统称,是目前最流行的免费操作系统。代表版本有:debian、centos、ubuntu、fedora、gentoo等。
Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器。
Mysql是一个小型关系型数据库管理系统。
PHP是一种在服务器端执行的嵌入HTML文档的脚本语言。
这四种软件均为免费开源软件,组合到一起,成为一个免费、高效、扩展性强的网站服务系统。

我们为什么采用LNMP这种架构?
采用Linux、PHP、MySQL的优点我们不必多说。
Nginx是一个小巧而高效的Linux下的Web服务器软件,是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,已经在一些俄罗斯的大型网站上运行多年,目前很多国内外的门户网站、行业网站也都在是使用Nginx,相当的稳定。
Nginx相当的稳定、功能丰富、安装配置简单、低系统资源……
在这里插入图片描述

首先,浏览器发送http request请求到服务器(Nginx),服务器响应并处理web请求,将一些静态资源(CSS,图片,视频等)保存服务器上,然后将php脚本通过接 口传输协议(网关协议)PHP-FCGI(fast-cgi)传输给PHP-FPM(进程管理程序),PHP-FPM不做处理,然后PHP-FPM调用 PHP解析器进程,PHP解析器解析php脚本信息。PHP解析器进程可以启动多个,进行并发执行。然后将解析后的脚本返回到PHP-FPM,PHP- FPM再通过fast-cgi的形式将脚本信息传送给Nginx.服务器再通过Http response的形式传送给浏览器。浏览器再进行解析与渲染然后进行呈现。

FastCGI的主要优点是把动态语言和HTTP服务器分离开来,是Nginx专一处理静态请求和向后转发动态请求,而PHP/PHP-FPM服务器专一解析PHP动态请求。

相关原理名词解释

搭建

mysql

下载
mysql-boost-5.7.17.tar.gz
源码编译数据库
带boost库的源码包

tar zxf mysql-boost-5.7.17.tar.gz
yum install -y cmake
cd mysql-5.7.17
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/lnmp/mysql \ #安装目录 
      -DMYSQL_DATADIR=/usr/local/lnmp/mysql/data \  #数据库存放目录
	  -DMYSQL_UNIX_ADDR=/usr/local/lnmp/mysql/data/mysql.sock \ #Unix socket 文件路径
	  -DWITH_MYISAM_STORAGE_ENGINE=1 \  #安装 myisam 存储引擎
	  -DWITH_INNOBASE_STORAGE_ENGINE=1 \ #安装 innodb 存储引擎
	  -DDEFAULT_CHARSET=utf8 \ #使用 utf8 字符
	  -DDEFAULT_COLLATION=utf8_general_ci \ #校验字符
	  -DEXTRA_CHARSETS=all \#安装所有扩展字符集
	  -DWITH_BOOST=boost/boost_1_59_0/
遇到报错,按提示解决依赖性
'重新编译时,需要清除原来的对象文件和缓存信息'
'rm -fr CmakeCache.txt'

后面编译会有一个warning:
CMake Warning at cmake/bison.cmake:20 (MESSAGE):
  Bison executable not found in PATH
Call Stack (most recent call first):
  sql/CMakeLists.txt:514 (INCLUDE)
##解决##
yum install -y bison

make && make install (过程较长) ##如果make还有问题,删除原来的目录,重新解压编译

制作启动脚本


[root@server5 support-files]# pwd
/root/mysql-5.7.17/support-files
[root@server5 support-files]# cp mysql.server /etc/init.d/mysqld

将原来的/etc/my.cnf备份,重新拷贝安装包里的过去

[root@server5 etc]# cp my.cnf my.cnf.bak
[root@server5 support-files]# cp my-default.cnf /etc/my.cnf
修改配置:
basedir = /usr/local/lnmp/mysql
datadir = /usr/local/lnmp/mysql/data
socket = /usr/local/lnmp/mysql/data/mysql.sock

添加用户和组:

groupadd -g 27 mysql
useradd -u 27 -g 27 mysql (id=27是因为rpm默认安装时mysql用户的id为27,并非强制)

chown mysql.mysql /usr/local/lnmp/mysql -R (修改mysql目录的权限,使其对mysql用户可写)

将mysql命令添加到环境变量

vim ~/.bash_profile
添加:PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin
生效:source ~/.bash_profile

初始化mysql:

mysqld --user=mysql --initialize(以mysql用户身份初始化)
初始化会生成一个临时密码,用于登录mysql(要记住此密码)

将mysql目录的所有者改为root

chown root /usr/local/lnmp/mysql -R
chown mysql /usr/local/lnmp/mysql/data -R  ##数据目录所有者必须是mysql,不然mysql用户不能写

启动mysql

/etc/init.d/mysqld start

进入mysql

mysql -uroot -p
执行:show databases; 会报错
需要执行:mysql_secure_installation,修改密码

nginx

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值