CentOS 6.5 源码编译搭建LNMP(三台独立主机实现)
搭建前准备:
1.三台独立主机
nginx:192.168.1.102
php-fpm:192.168.1.105
mysql:192.168.1.103
2.相关软件的源码包
nginx:nginx-1.10.2
php:php-5.6.28
mysql:mariadb-5.5.53
3.开发环境及依赖包组
包:openssl-devel;pcre-devel;zlib-devel
包组:Development Tools;Server Platform Development
开始搭建:
第一台主机的操作:nginx服务器主机
1.解压展开源码包nginx-1.10.2.tar.gz
tar -xf nginx-1.10..tar.gz
2.创建相应路径以便编译时使用
mkdir -pv /var/cache/nginx
3.cd至nginx-1.10.2目录,运行以下命令
./configure --prefix=/usr/local/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock --http-client-body-temp-path=/var/cache/nginx/client_temp --http-proxy-temp-path=/var/cache/nginx/proxy_temp --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp --http-scgi-temp-path=/var/cache/nginx/scgi_temp --user=nginx --group=nginx --with-http_ssl_module --with-http_realip_module --with-http_addition_module --with-http_sub_module --with-http_dav_module --with-http_flv_module --with-http_mp4_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_random_index_module --with-http_secure_link_module --with-http_stub_status_module --with-http_auth_request_module --with-threads --with-stream --with-stream_ssl_module --with-http_slice_module --with-file-aio --with-http_v2_module
4.make && make install 即可
5.开启nginx,在浏览器测试,出现即没有问题
6.配置nginx支持php-fpm
#vim /etc/nginx/nginx.conf 写入
server {
listen ;
server_name www.a.com;
location / {
root /test/html;
index index.html index.htm index.php;
}
location ~ \.php$ {
root /test/html;
fastcgi_pass 192.168.1.105:;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /www/test1/$fastcgi_script_name;
include fastcgi_params;
}
}
第二台主机的操作:php的主机
1.解压展开源码包php-5.6.28.tar.bz2
2.cd至php-5.6.28目录,执行
./configure --prefix=/usr/local/php56 --with-mysql --with-openssl --with-mysqli --enable-mbstring --with-png-dir --with-jpeg-dir --with-freetype-dir --with-zlib --with-libxml-dir=/usr --enable-xml --enable-sockets --with-mcrypt --with-config-file-path=/etc/php56 --with-config-file-scan-dir=/etc/php56.d --with-bz2 --enable-fpm
其中,--enable-fpm是关键选项
3.make && make install
4.配置文件的操作
①#cp php.ini-development /etc/php.ini
②#cp sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm (将php-fpm加入到系统服务中)
③#chkconfig --add php-fpm
查看添加结果:#chkconfig --list php-fpm

则完成添加;
注意:此处复制php-fpm到/etc/rc.d/init.d/目录下时,有可能php-fpm自身没有任何执行权限,会导致添加系统服务时失败,自行添加执行权限即可解决这个问题
5.修改php-fpm配置文件
①修改php-fpm的pid设置

②修改php-fpm的进程属主

③修改php-fpm的监听地址

这几项是服务正常开启运行的比较关键的几项,其余配置在此不再赘述
6.开启php-fpm服务
service php-fpm start

确保PHP主机的IP:9000处于监听状态即可
7.创建动态资源目录,做测试用,此处是/www/test1目录,创建一个index.php文件
8.开始测试,效果如下
此为请求静态资源
此为请求动态资源
第三台主机的操作:mysql主机
1.此处安装mariadb-5.5.53,首先创建mariadb用户和组
groupadd mariadb
useradd -r -g mariadb -s /sbin/nologin
2.安装依赖包
yum -y install gcc gcc-c++ cmake ncurses libxml2 libxml2-devel bison bison-devel
3.开始编译
cmake . -DMYSQL_UNIX_ADDR=/tmp/mariadb.sock -DSYSCONFDIR=/etc -DMYSQL_TCP_PORT= -DEXTRA_CHARSETS=all -DMYSQL_USER=mariadb -DCMAKE_INSTALL_PREFIX=/usr/local/mariadb -DMYSQL_DATADIR=/mydata/data -DWITH_XTRADB_STORAGE_ENGINE= -DWITH_FEDERATEDX_STORAGE_ENGINE= -DWITH_ARCHIVE_STORAGE_ENGINE= -DWITH_MYISAM_STORAGE_ENGINE= -DWITH_INNOBASE_STORAGE_ENGINE= -DWITH_ARCHIVE_STPRAGE_ENGINE= -DWITH_BLACKHOLE_STORAGE_ENGINE= -DWIYH_READLINE= -DWIYH_SSL=system -DVITH_ZLIB=system -DWITH_LOBWRAP= -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci
4.make && make install
此过程比较慢,请耐心等待
5.更改安装目录的属主属组,并创建数据存储目录、修改其相应的权限
mkdir -pv /mydata/data
chown -R mariadb:mariadb /mydata/data
cd /usr/local/mariadb
chown -R :mariadb ./*


6.初始化数据库,复制配置文件
#scripts/mysql_install_db --user=mariadb --datadir=/mydata/data/
#cp mysql.server /etc/rc.d/init.d/mysqld
#cp my-large.cnf /etc/my.cnf
7.修改配置文件/etc/my.cnf
在mysqld下添加三个选项:
datadir = /mydata/data
innodb_file_per_table = ON
skip_name_resolve = ON
8.将mysqld加入系统服务,并启动之
#chkconfig --add mysqld
注意:此处如果启动失败,显示错误为

则修改/etc/rc.d/init.d/mysqld,找到第311行,

然后再编辑/etc/my.cnf,在[mysqld]中加入

之后再加入一个模块[mysqld_safe]

最后修改/usr/local/mariadb的目录属主属组为mariadb用户即可
# chown -R mariadb:mariadb /usr/local/mariadb/
如果出现其他错误,则查看/var/log/mariadb_error.log日志,对症下药即可
至此,mariadb已成功安装并启动

在第二台主机编写php访问mysql的代码,测试一下

到此为止,三台主机各自配置完毕,LNMP环境可正常运行
拓展:
一、为php主机安装xcache,提供加速:
1.此处编译安装xcache-3.2.0,还需要一个安装组件php-devel
2.解压缩后,cd至xcache-3.2.0目录,执行
/usr/local/php56/bin/phpize #为php新增一个模块
3.编译操作
./configure --enable-xcache --with-php-congig=/usr/local/php56/bin/php-config
4.make && make install
5.安装完成后,出现以下结果:

将红框内的字符串复制下来备用
6.然后执行
# mkdir -pv /etc/php56.d
# cp xcache.ini /etc/php56.d
注意:此处创建的目录/etc/php56.d必须跟编译php时的编译选项:--with-config-file-scan-dir=/etc/php56.d一致,否则php找不到xcache.ini,导致xcache无法工作;
# vim /etc/php56.d/xcache.ini

7.重载php-fpm,再次请求页面,就会看到:

二、安装wordpress(个人信息发布平台)
1.此处用的是wordpress-4.7-zh_CN.zip,直接解压缩即可
2.在nginx主机和php主机各存放一份压缩好的wordpress,位置是各主机对应在虚拟主机中的root定义的位置

3.在php主机上操作如下:
# cp cp wp-config-sample.php wp-config.php
# vim wp-config.php

4.测试效果如下:

三、安装phpmyadmin(图形化数据库管理工具)
1.安装包phpMyAdmin-4.6.5.2-all-languages.zip
2.与wordpress很相似,放在各自对应的路径下即可,然后修改php主机的配置文件:
# cp cp config.sample.inc.php config.inc.php
# vim config.inc.php

3.访问即可,效果如下:

CentOS 6.5 源码编译搭建LNMP(三台独立主机实现)的更多相关文章
- 源码编译搭建LNMP环境
LNMP源码编译 1.LNMP介绍 LNMP=Linux Nginx Mysql PHP Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器.Ng ...
- CentOS 6.5 源码编译搭建LAMP(两台独立主机实现)
搭建前准备: 1.两台独立主机 httpd:192.168.1.105 php-fpm:192.168.1.105 mariadb:192.168.1.103 2.相关软件的源码包 httpd:htt ...
- CentOS 7.0源码包搭建LNMP方法分享(实际环境下)
CentOS 7.0编译安装Nginx1.6.0+MySQL5.6.19+PHP5.5.14 一.配置防火墙,开启80端口.3306端口 CentOS 7.0默认使用的是firewall作为防火墙,这 ...
- Centos 7.x 源码编译搭建Nginx
环境: centos 7 防火墙关闭 Selinx关闭 Nginx Web安装 安装依赖库 yum install pcre-devel pcre gcc gcc-c++ zlib zlib-deve ...
- CentOS 7上源码编译安装和配置LNMP Web+phpMyAdmin服务器环境
CentOS 7上源码编译安装和配置LNMP Web+phpMyAdmin服务器环境 什么是LNMP? LNMP(别名LEMP)是指由Linux, Nginx, MySQL/MariaDB, PHP/ ...
- 源码编译配置lnmp部署zabbix
环境说明: [root@wcy ~]# cat /etc/redhat-release CentOS release 6.9 (Final) [root@wcy ~]# uname -a Linux ...
- WordPress安装篇(5):源码编译安装LNMP并部署WordPress
与YUM方式安装相比,源码编译安装方式更灵活,安装过程中能自定义功能和参数,特别是在批量部署服务器又要求软件版本及配置一致时,源码编译安装的优势很明显.本文介绍如何通过源码编译方式安装Nginx1.1 ...
- CentOS 7.4 源码编译安装 Redis
一.CentOS 7.4 源码编译安装 Redis 1.下载源码并解压 wget http://download.redis.io/releases/redis-4.0.10.tar.gz tar ...
- 基于源码编译的lnmp架构实现论坛的搭建及memcache的应用
系统环境: RHEL6 x86-64 selinux and iptables disabled LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构 Linux是一类 ...
随机推荐
- 关于java 中文乱码问题 自己的一点解决方案
早上做导出的时候,url拼接参数中文出现了乱码.查了半天.终于中午搞定了. 在web.xml中加了转码过滤器,tomcat的server.xml中也加入URIEncoding="UTF-8& ...
- css实现阴影效果(box-shadow)
box-shadow 使用方法 设置块阴影 语法: box-shadow:<length> <length> <length> <length> || ...
- 论文笔记之: Person Re-Identification by Multi-Channel Parts-Based CNN with Improved Triplet Loss Function
Person Re-Identification by Multi-Channel Parts-Based CNN with Improved Triplet Loss Function CVPR 2 ...
- 转:RabbitMQ基础知识
RabbitMQ基础知识 一.背景 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然 ...
- 使用pt-stalk分析MySQL的性能波动 (转)
简介 在MySQL服务器出现短暂(5~30秒)的性能波动的时候,一般的性能监控工具都很难抓住故障现场,也就很难收集对应较细粒度的诊断信息.另外,如果这种波动出现的频率很低,例如几天才一次,我们也很难人 ...
- [solr] - 环境搭建2
前面使用Tomcat搭建solr,参考文章: http://www.cnblogs.com/HD/p/3977799.html 原来solr可以不使用tomcat/jboss等服务器,它自身已经集成了 ...
- Hibernate5.2之HQL查询
Hibernate5.2之HQL查询 一. 介绍 Hibernate的 ...
- Logistic Regression逻辑回归
参考自: http://blog.sina.com.cn/s/blog_74cf26810100ypzf.html http://blog.sina.com.cn/s/blog_64ecfc2f010 ...
- Notice: Trying to get property of non-object problem(PHP)解决办法 中间件只能跳转不能返任何数据
这里实际是调用了一个zend的数据库访问的方法,使用了fetchAll方法,但由于数据库中没有该记录,所以返回的对象是null,所以我就判断对象是否为null: 复制代码代码如下: if($obj== ...
- Code Igniter + PHP5.3 + SqlServer2008配置
1.配置apache+php5.3 2.配置sql server服务器,并允许远程连接. 3.去http://www.microsoft.com/en-us/download/details.aspx ...