系统:Centos7.4

一台服务器安装nginx、php、mysql

原理不是很懂,但实测如下两种环境下都能成功,这里做下记录:

1、一个干净的系统,从0开始完成所有步骤,完成LNMP搭建

2、已经装了mysql,之后再装nginx、php,完成LNMP搭建(安装php编译时要注意指定mysql的安装路径等信息)

注意:安装前一定检查是否装有mariadb数据库(系统安装时选择某项安装会集成安装上的),若有请卸载,不然后面初始化mysql时会报错,百度了很久都没找原因,都说是权限问题,后来在重复搞整时看到有关于mariabd的打印,猜测是这个原因,卸载mariadb问题解决。

Can't create/write to file '/data/mysql/xx.pid' (Errcode: 13)

步骤如下:

一、源码ginx安装

1、安装nginx需要的环境依赖库、工具等

yum -y install pcre pcre-devel openssl-devel openssh  wget 

2、下载nginx安装包至/usr/local/src下

wget -c -P /usr/local/src http://mirrors.yangxingzhen.com/nginx/nginx-1.13.4.tar.gz

3、安装编译器

yum -y install gcc gcc-c++

4、编译安装nginx

cd /usr/local/src

tar zxf nginx-1.13.4.tar.gz

cd /src/nginx-1.13.4

#编译前可以根据企业实际需要选择是否隐藏nginx版本等信息

sed -i -e 's/1.13.4/123/g' -e 's/nginx\//abc/g' -e 's/"NGINX"/"abc"/g'  ./src/core/nginx.h

#预编译(根据实际需求添加相应模块)

./configure --user=www --group=www --prefix=/usr/local/nginx/ --with-http_stub_status_module --with-http_ssl_module

#编译、安装(-j8表示同时用8核CPU进行编译)

make -j8 && make install

5、创建nginx启动用户,默认用户为www,不授予登陆权限

useradd -s /sbin/nologin www

6、启动nginx并测试是否能正常访问

#检测配置文件是否正确

/usr/local/nginx/sbin/nginx -t

#启动nginx

/usr/local/nginx/sbin/nginx

7、根据具体需求对nginx.conf配置文件进行修改调整

cp /usr/local/nginx/conf/nginx.conf   /usr/local/nginx/conf/nginx.conf.bak

#为方便查看配置文件,可将多余的注释和空行清空

grep -vE "^$|#"  nginx.conf.default >nginx.conf

#修改配置

vim  /usr/local/nginx/conf/nginx.conf

worker_processes  ;
events {
worker_connections ;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout ;
include conf.d/*.conf; # 开启虚拟主机,将会去此目录下找配置文件,在找不到时才会往下进行
server {
listen 80;
server_name abc.c.com;
location / {
root html;
index index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}

#创建虚拟主机配置文件目录并创建一个配置,如nginx.conf配置所示,conf.d文件夹与nginx.conf配置文件处于同级。

mkdir -p /usr/local/nginx/conf/conf.d

vim /usr/local/nginx/conf/conf.d/abc1.conf    #应该根据具体需求进行配置

server{
listen 80;
server_name www.abc.com;
root /usr/local/nginx/html/abc/public; # 该项要修改为你准备存放相关网页的路径 location / {
index index.php index.html index.htm;
#如果请求既不是一个文件,也不是一个目录,则执行一下重写规则
if (!-e $request_filename)
{
#地址作为将参数rewrite到index.php上。
rewrite ^/(.*)$ /index.php?s=$1;
#若是子目录则使用下面这句,将subdir改成目录名称即可。
#rewrite ^/subdir/(.*)$ /subdir/index.php?s=$1;
}
} location /api/ {
index index.php index.html index.htm;
#如果请求既不是一个文件,也不是一个目录,则执行一下重写规则
if (!-e $request_filename)
{
#地址作为将参数rewrite到index.php上。
#rewrite ^/(.*)$ /index.php?s=$1;
#若是子目录则使用下面这句,将subdir改成目录名称即可。
rewrite ^/api/(.*)$ /api/index.php?s=$1;
}
} location ~* ^\/upload\/.+\.(html|php)$ {
return 404;
} location ~* ^\/plugins\/.+\.(html|php)$ {
return 404;
}

location ~* ^\/themes\/.+\.(html|php)$ {
return 404;
} #proxy the php scripts to php-fpm
location ~ \.php {
include fastcgi_params;
##pathinfo支持start
#定义变量 $path_info ,用于存放pathinfo信息
set $path_info "";
#定义变量 $real_script_name,用于存放真实地址
set $real_script_name $fastcgi_script_name;
#如果地址与引号内的正则表达式匹配
if ($fastcgi_script_name ~ "^(.+?\.php)(/.+)$") {
#将文件地址赋值给变量 $real_script_name
set $real_script_name $1;
#将文件地址后的参数赋值给变量 $path_info
set $path_info $2;
}
#配置fastcgi的一些参数
fastcgi_param SCRIPT_FILENAME $document_root$real_script_name;
fastcgi_param SCRIPT_NAME $real_script_name;
fastcgi_param PATH_INFO $path_info;
###pathinfo支持end
fastcgi_intercept_errors on; fastcgi_pass 127.0.0.1:9000;
# fastcgi_pass 如果是 sock形式,可能是下面的配置
# fastcgi_pass unix:/tmp/php-cgi.sock
} }

#平滑重启nginx,访问域名查看是否有结果(如果是静态网站,现在能正常访问了,但这里是动态网站,需要php解释器,还需要连接数据库,访问肯定是报错一堆)

/usr/local/nginx/sbin/nginx -s reload

二、mysql数据库安装

1、安装依赖环境

yum -y install cmake ncurses-devel perl  autoconf  

2、下载安装包

cd /usr/loca/src

wget  http://mirrors.163.com/mysql/Downloads/MySQL-5.6/mysql-5.6.39.tar.gz

3、 编译安装

tar zxf mysql-5.6.39.tar.gz

cd mysql-5.6.39

#预编译(根据经验,感觉是将以下配置写入my.cnf默认配置中,所以只要你不修改my.cnf配置文件,以下配置就属于默认配置,若修改了my.cnf配置文件就以修改后为准)

cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_DATADIR=/data/mysql \
-DSYSCONFDIR=/etc \
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \
-DMYSQL_USER=mysql \
-DMYSQL_TCP_PORT= \
-DWGE_ENGINE= \
-DWITH_INNOBASE_STORAGE_ENGINE= \
-DWITH_PARTITION_STORAGE_ENGINE= \
-DWITH_BLACGINE= \
-DWITH_MYISAM_STORAGE_ENGINE= \
-DWITH_READLINE= \
-DENABLED_LOCAL_INFILE= \
-DWITH_EXDDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DEXTRA_CHARSETS=all \
-DWITH_BIG_DEBUG=

将知道的进行解释(其它的以后查到了再进行更新):

-DCMAKE_INSTALL_PREFIX=  #指定安装目录
-DMYSQL_DATADIR=  #指定数据库的存放目录即数据目录
-DSYSCONFDIR=  #指定默认my.cnf配置文件路径,如果遇到一个服务器装多个mysql时,可以对其进行修改,实测有效。
-DMYSQL_UNIX_ADDR=  #sock命令以及存放路径指定,一台服务器多个mysql时,不要重名
-DMYSQL_USER=  #指定mysql启动使用的用户
-DMYSQL_TCP_PORT=  #指定数据库端口
-DWITH_EXDDEFAULT_CHARSET=  #设置默认数据库字符集
----------------------------------------------------------------------------
#编译、安装
make -j8 && make install 4、创建mysql启动用户
useradd -s /sbin/nologin mysql

5、mysql安装目录授权(编译安装时会自动创建目录)、数据目录创建(数据库初始化时要用,所以必须提前创建)和授权等

chown -R mysql:mysql /usr/local/mysql

mkdir -p /data/mysql

chown -R mysql:mysql /data/mysql

6、修改my.cnf配置文件(很初始的配置,根据实际需求进行调整)

vim /etc/my.cnf

[client]
default-character-set = utf8
[mysql]
default-character-set = utf8
[mysqld]
datadir = /data/mysql
socket = /tmp/mysql.sock
user = mysql
log-error = /var/log/mysqld.log
character_set_server = utf8

7、初始化数据库(会在/data/mysql下根据my.cnf配置初始创建一些数据文件和库文件,如果是新装数据库,可重复初始化,每次初始化前将原来生成的文件删除干净。已投入生产的不要此操作.)

/usr/local/mysql/scripts/mysql_install_db --user=mysql --datadir=/data/mysql --basedir=/usr/local/mysql

8、启动数据库

#软链接让mysql的命令全局直接使用

ln -s /usr/local/mysql/bin/* /usr/bin

#数据库系统启动制作

cp /usr/local/mysql/support-files/mysql.server   /etc/init.d/mysqld  #若一台服务器多个mysql可以重新命名如根据数据库版本来区分,mysqld55或mysqld56

chmod o+x /etc/init.d/mysqld   

/etc/init.d/mysqld start或service mysqld start

#设置开机启动

chkconfig --add mysqld

hkconfig mysqld on

chkconfig --list mysqld

 三、PHP(FastCGI)安装

1、安装php函数依赖库等

yum install -y zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel libiconv-devel freetype-devel libpng-devel gd-devel libcurl-devel libxslt-devel

2、安装libmcrypt库、mhash加密扩展库、mcrypt加密扩展库(根据实际需要进行安装)

#提前安装epel.repo扩展源,不然无法进行安装(根据实际系统版本指定epel-6或epel-7)

wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo

yum -y install libmcrypt-devel mhash mcrypt

3、源码安装libiconv(系统环境不同编译时可能会出现部分系统报错,实测有些系统报错,有些没有报错)

cd /usr/local/src

wget -c http://mirrors.yangxingzhen.com/libiconv/libiconv-1.14.tar.gz

tar zxf libiconv-1.14.tar.gz

cd libiconv-1.14

./configure --prefix=/usr/local/libiconv

#编译时若出现报错,可按此操作解除。

make -j8 && make install

解决办法:

find . -name "stdio.in.h"

./srclib/stdio.in.h

vim ./srclib/stdio.in.h

大概在698行位置,删除stdio.in.h文件中_GL_WARN_ON_USE (gets, "gets is a security hole - use fgets instead");行即可

#重新进行编译安装就过了

make -j8 && make install

4、源码安装php

cd /usr/local/src

wget -c http://mirrors.sohu.com/php/php-5.6.29.tar.gz

tar zxf php-5.6.29.tar.gz

cd php-5.6.29

ln -s /usr/local/mysql/lib/libmysqlclient.so.18  /usr/lib64

#预编译(参数中有关于mysql的信息,比如指定mysql的安装路径,一定要正确配置)

./configure --prefix=/usr/local/php \
--with-config-file-path=/usr/local/php/etc \
--with-mysql=/usr/local/mysql \
--with-mysqli=/usr/local/mysql/bin/mysql_config \
--with-pdo-mysql=/usr/local/mysql \
--enable-opcache \
--with-gettext \
--with-iconv-dir=/usr/local/libiconv \
--with-freetype-dir \
--with-jpeg-dir \
--with-png-dir \
--with-zlib \
--with-libxml-dir \
--enable-xml \
--disable-rpath \
--enable-bcmath \
--enable-shmop \
--enable-sysvsem \
--enable-inline-optimization \
--with-curl \
--enable-mbregex \
--enable-fpm \
--enable-mbstring \
--with-mcrypt \
--with-gd \
--enable-gd-native-ttf \
--with-openssl \
--with-mhash \
--enable-pcntl \
--enable-sockets \
--with-xmlrpc \
--enable-soap \
--enable-short-tags \
--enable-static \
--with-fpm-user=www \
--with-fpm-group=www \
--enable-ftp \
--enable-zip

#编译安装

make -j8&&make install

5、配置并启动php

先从源码包拷贝php.ini文件到etc下

cp /usr/local/src/php-5.6.29/php.ini-development  /usr/local/php/etc/php.ini

cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf

#启动php

/usr/local/php/sbin/php-fpm

四、web站点配置

1、将web代码放置nginx配置文件指定目录下,并修改权限

通常情况下需要将代码文件所属用户指定为nginx启动用户(www),不然会出现无访问访问权限导致报错

chown -R www:www  /usr/local/nginx/html/abc

2、创建库、数据库访问用户,并导入后端数据库

mysql -uroot -p

create database abc character set=utf8;

grant all on abc.* to userabc@'localhost' identified by '123456';

source  abc.sql

flush privileges;

3、将nginx、php-fpm重启,并访问站点。

LNMP环境搭建网站的更多相关文章

  1. Linux下-LNMP环境搭建博客网站(全过程)

    通常我们所说的LNMP是指一个网站基本的组织框架,即Linux系统支持,Nginx静态服务,Mysql数据库支持以及PHP动态编程语言支持.目前Mysql数据库被Oracle数据库分析公司收购,其创始 ...

  2. LNMP环境搭建

    LNMP环境搭建 Linux + Nginx + MySQL + PHP PHP是一种脚本语言,当前中国乃至世界上使用PHP语言开发的网站非常普遍 Nginx是一个web服务软件,和apache是一类 ...

  3. 阿里云(ECS)Centos服务器LNMP环境搭建

    阿里云( ECS ) Centos7 服务器 LNMP 环境搭建 前言 第一次接触阿里云是大四的时候,当时在校外公司做兼职,关于智能家居项目的,话说当时俺就只有一个月左右的 php 后台开发经验(还是 ...

  4. LNMP环境搭建:Nginx安装、测试与域名配置

    Nginx作为一款优秀的Web Server软件同时也是一款优秀的负载均衡或前端反向代理.缓存服务软件 2.编译安装Nginx (1)安装Nginx依赖函数库pcre pcre为“perl兼容正则表达 ...

  5. LNMP环境搭建之php安装,wordpress博客搭建

    LNMP环境搭建之php安装,wordpress博客搭建 一.介绍: 1.什么是CGI CGI全称是"通用网关接口"(Common Gateway Interface),HTTP服 ...

  6. LNMP环境搭建——MySQL篇

    The world's most popular open source database 1.Install MySQL root@kallen:~# apt-get install mysql-s ...

  7. Ubuntu16.04 lnmp 环境搭建

    Ubuntu16.04 lnmp 环境搭建 nginx 安装 sudo apt-add-repository ppa:nginx/stablesudo apt-add-repository ppa:o ...

  8. LNMP环境搭建之编译安装指南(php-5.3.27.tar.gz)

    测试环境:CentOS release 6.5 (Final) 软件安装:nginx   mysql-5.5.32-linux2.6-x86_64.tar.gz   php-5.3.27.tar.gz ...

  9. LNMP环境搭建哈哈

    经过一番折腾,终于将LNMP环境搭建完成了.本文介绍的LNMP环境是在windows的Oracle VM VirtualBox中的Centos虚拟机上搭建的,各个软件的版本为:Centos7 + Ng ...

随机推荐

  1. 【WIP】Ruby JSON

    创建: 2018/03/22 以后有空补上 注: JSON.generate 参数只能是Obejct或者Array, 不可以是Hash https://docs.ruby-lang.org/ja/la ...

  2. [App Store Connect帮助]八、维护您的 App(1)App 维护概述

    您在 App Store 上发行 App 后,需要执行一些任务来回复顾客反馈并在整个产品周期内维护您的 App.您可以按任何顺序执行这些任务. 监控顾客评论.销售情况和分析 您可以在 App 页面的“ ...

  3. react-native页面之间的相互传值

    react-native页面之间的相互传值 之前在自己学习react-native的时候,在页面跳转和传值问题上花了一段时间去网上搜索和查找资料,自己总结了两个方法.可以参考 https://blog ...

  4. 依赖注入(二)Autofac简单使用

    Autofac简单使用 源码下载传上源码,终于学会传文件了. 首先 还是那句话:“不要信我,否则你死得很惨!”. C#常见的依赖注入容器 IoC in .NET part 1: Autofac IoC ...

  5. 进击的Python【第十二章】:mysql介绍与简单操作,sqlachemy介绍与简单应用

    进击的Python[第十二章]:mysql介绍与简单操作,sqlachemy介绍与简单应用 一.数据库介绍 什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数 ...

  6. 使用HttpClient携带证书报错_Certificate for <IP> doesn't match any of the subject alternative names:[域名]

    使用HttpClient携带pfx证书通过Https协议发送SOUP报文调用WebService接口时报如下错误: Exception in thread "main" javax ...

  7. VS2010的一个错误,无法加载类型

    一个解决方案中的一个项目X,启动时总是报错,无法加载一个同一个解决方案中另一个项目A生成EXE中的数据类型. 做了如下的步骤解决问题. 1:检查项目A,未发现错误,调试启动A,一切正常. 2:检查项目 ...

  8. jdk 1.8下 java ArrayList 添加元素解析

    转载请注明http://www.cnblogs.com/majianming/p/8006452.html 有人问我,java ArrayList底层是怎么实现的?我就回答数组,他再问我,那它是怎么实 ...

  9. RabbitMQ四:生产者--队列--消费者

    AMQP协议的梳理和名词解析  建议先把上篇AMQP协议先看一遍,理解一下,由于用XMind绘图,电脑屏幕比较小,不能截取全部,如果想要全图和源代码,请下面留言....... 可以点击图片,打开到新的 ...

  10. QML中使用相对路径

    QML里有三种路径: 默认使用URL路径. "qrc:///filepath".这用来索引资源文件. "file:///绝对路径".这用来索引本地文件系统中的文 ...