nginx+php+mysql 环境搭建

准备工作:
当前操作目录为  /usr/work
a. 正式开始前,编译环境gcc g++ 开发库之类的需要提前装好。
# yum install gcc gcc-c++
b.  安装PCRE库
ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz 下载最新的 PCRE 源码包,使用下面命令下载编译和安装 PCRE 包:
wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz
tar -zxvf pcre-8.39.tar.gz
cd pcre-8.39
./configure
make && make install
c. 安装zlib库
http://zlib.net/zlib-1.2.11.tar.gz 下载最新的 zlib 源码包,使用下面命令下载编译和安装 zlib包:
  wget http://zlib.net/zlib-1.2.11.tar.gz 
  tar -zxvf zlib-1.2.11.tar.gz 
  cd zlib-1.2.11
  ./configure 
  make && make install
d. 安装ssl(某些vps默认没装ssl)
wget https://www.openssl.org/source/openssl-1.1.0b.tar.gz
tar -zxvf openssl-1.1.0b.tar.gz
./config
make && make install
1. 安装nginx 
1)下载nginx
以安装最新稳定版ngixn-1.10.2为例子,其他版本也一样。
下面是把 Nginx 安装到 /usr/work/webserver/nginx目录下的详细步骤
  /usr/work/webserver/
 wget http://nginx.org/download/nginx-1.10.2.tar.gz
 tar -zxvf nginx-1.10.2.tar.gz
 cd nginx-1.10.2
2)添加nginx用户和用户组
groupadd -r nginx
useradd -r -g nginx nginx
3)配置nginx安装参数
--prefix=/usr/work/tool/nginx \
--sbin-path=/usr/work/tool/nginx/sbin/nginx \
--conf-path=/usr/work/tool/nginx/nginx.conf \
--pid-path=/usr/lwork/tool/nginx/nginx.pid \
--user=nginx \
--group=nginx \
--with-http_ssl_module \
--with-http_flv_module \
--with-http_mp4_module \
--with-http_stub_status_module \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/tmp/nginx/client/ \
--http-proxy-temp-path=/var/tmp/nginx/proxy/ \
--http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ \
--http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \
--http-scgi-temp-path=/var/tmp/nginx/scgi \
--with-pcre=/usr/work/tool/pcre-8.39 \
--with-zlib=/usr/work/tool/zlib-1.2.11 \
--with-openssl=/usr/work/tool/openssl-1.1.0b \
注:当前所在目录一定要是/usr/work/webserver/nginx-1.10.2
--with-pcre=/usr/work/pcre-8.39 指的是pcre-8.39的源码路径。
--with-zlib=/usr/work/zlib-1.2.11 指的是zlib-1.2.11的源码路径。
--with-openssl=/usr/work/openssl-1.1.0b 指的是openssl-1.1.0b的源码路径。
编译安装
4)启动nginx
/usr/work/tool/nginx/sbin/nginx
如果出现报错 ,则建立该目录就行了   mkdir -p /var/tmp/nginx/client
nginx: [emerg] mkdir() "/var/tmp/nginx/client/" failed (2: No such file or directory)
打开浏览器访问此机器的 IP,如果浏览器出现 Welcome to nginx! 则表示 Nginx 已经安装并运行成功
ps:
若访问403 如图

则在nginx.conf 中将user 改为权限高的用户即可 如: sudo sbin/nginx -s reload重启即可
user root;
若nginx成功运行后,通过ip地址无法访问服务器 则可能是防火墙的问题 需要开放80端口或关闭防火墙
开启80端口 
firewall-cmd --zone=public --add-port=80/tcp --permanent 
命令含义: 
--zone #作用域 
--add-port=80/tcp #添加端口,格式为:端口/通讯协议 
--permanent #永久生效,没有此参数重启后失效 
重启防火墙 
firewall-cmd --reload
或者永久关闭防火墙
systemctl stop firewalld.service  //停止防火墙
systemctl disable firewalld.service //不再开机停止运行防火墙
nginx编译选项
make是用来编译的,它从Makefile中读取指令,然后编译。
make install是用来安装的,它也从Makefile中读取指令,安装到指定的位置。
configure命令是用来检测你的安装平台的目标特征的。它定义了系统的各个方面,包括nginx的被允许使用的连接处理的方法,比如它会检测你是不是有CC或GCC,并不是需要CC或GCC,它是个shell脚本,执行结束时,它会创建一个Makefile文件。nginx的configure命令支持以下参数:

  • --prefix=
  • path
  •     定义一个目录,存放服务器上的文件 ,也就是nginx的安装目录。默认使用 
  • /usr/local/nginx。
  • --sbin-path=
  • path
  •  设置nginx的可执行文件的路径,默认为  
  • prefix
  • /sbin/nginx
  • .
  • --conf-path=
  • path
  •   设置在nginx.conf配置文件的路径。nginx允许使用不同的配置文件启动,通过命令行中的-c选项。默认为
  • prefix
  • /conf/nginx.conf
  • .
  • --pid-path=
  • path  设置nginx.pid文件,将存储的主进程的进程号。安装完成后,可以随时改变的文件名 , 在nginx.conf配置文件中使用 PID指令。默认情况下,文件名 为
  • prefix
  • /logs/nginx.pid
  • .
  • --error-log-path=
  • path
  •  设置主错误,警告,和诊断文件的名称。安装完成后,可以随时改变的文件名 ,在nginx.conf配置文件中 使用 的error_log指令。默认情况下,文件名 为
  • prefix
  • /logs/error.log
  • .
  • --http-log-path=
  • path
  •   设置主请求的HTTP服务器的日志文件的名称。安装完成后,可以随时改变的文件名 ,在nginx.conf配置文件中 使用 的access_log指令。默认情况下,文件名 为
  • prefix
  • /logs/access.log
  • .
  • --user=
  • name
  •   设置nginx工作进程的用户。安装完成后,可以随时更改的名称在nginx.conf配置文件中 使用的 user指令。默认的用户名是nobody。
  • --group=
  • name
  •   设置nginx工作进程的用户组。安装完成后,可以随时更改的名称在nginx.conf配置文件中 使用的 user指令。默认的为非特权用户。
  • --with-select_module
  •  
  • --without-select_module 启用或禁用构建一个模块来允许服务器使用select()方法。该模块将自动建立,如果平台不支持的kqueue,epoll,rtsig或/dev/poll。
  • --with-poll_module
  •  
  • --without-poll_module
  •  启用或禁用构建一个模块来允许服务器使用poll()方法。该模块将自动建立,如果平台不支持的kqueue,epoll,rtsig或/dev/poll。
  • --without-http_gzip_module
  •  — 不编译压缩的HTTP服务器的响应模块。编译并运行此模块需要zlib库。
  • --without-http_rewrite_module
  •   不编译重写模块。编译并运行此模块需要PCRE库支持。
  • --without-http_proxy_module
  •  — 不编译http_proxy模块。
  • --with-http_ssl_module
  •  — 使用https协议模块。默认情况下,该模块没有被构建。建立并运行此模块的OpenSSL库是必需的。
  • --with-pcre=
  • path
  •  — 设置PCRE库的源码路径。PCRE库的源码(版本4.4 - 8.30)需要从PCRE网站下载并解压。其余的工作是Nginx的./ configure和make来完成。正则表达式使用在location指令和 ngx_http_rewrite_module 模块中。
  • --with-pcre-jit
  •  —编译PCRE包含“just-in-time compilation”(1.1.12中, pcre_jit指令)。
  • --with-zlib=
  • path
  •  —设置的zlib库的源码路径。要下载从 zlib(版本1.1.3 - 1.2.5)的并解压。其余的工作是Nginx的./ configure和make完成。ngx_http_gzip_module模块需要使用zlib 。
  • --with-cc-opt=
  • parameters
  •  — 设置额外的参数将被添加到CFLAGS变量。例如,当你在FreeBSD上使用PCRE库时需要使用:
  • --with-cc-opt="-I /usr/local/include。
  • .如需要需要增加 
  • select()支持的文件数量
  • :
  • --with-cc-opt="-D FD_SETSIZE=2048".
  • --with-ld-opt=
  • parameters
  •  —设置附加的参数,将用于在链接期间。例如,当在FreeBSD下使用该系统的PCRE库,应指定:
  • --with-ld-opt="-L /usr/local/lib".

2. 安装php-fpm
什么是PHP-FPM
PHP-FPM是一个PHP FastCGI管理器,是只用于PHP,可以在 http://php-fpm.org/download下载得到.
PHP-FPM其实是PHP源代码的一个补丁,旨在将FastCGI进程管理整合进PHP包中。必须将它patch到你的PHP源代码中,在编译安装PHP后才可以使用。
新版PHP已经集成php-fpm了,不再是第三方的包了,推荐使用PHP-FPM提供了更好的PHP进程管理方式,可以有效控制内存和进程、可以平滑重载PHP配置,比spawn-fcgi具有更多优点,所以被PHP官方收录了。在./configure的时候带 –enable-fpm参数即可开启PHP-FPM,其它参数都是配置php的,具体选项含义可以查看这里
安装前准备
添加 epel 源
# rpm -Uvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
安装依赖
# yum install gcc bison bison-devel zlib-devel libmcrypt-devel mcrypt mhash-devel openssl-devel libxml2-devel libcurl-devel bzip2-devel readline-devel libedit-devel sqlite-devel
libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel \
zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel \
ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel \
krb5 krb5-devel libidn libidn-devel openssl openssl-devel
安装php
wget http://cn.php.net/distributions/php-7.1.13.tar.gz
tar -zxvf php-7.1.13.tar.gz 
cd php-7.1.13
./configure --prefix=/usr/work/php --enable-fpm --with-mcrypt \
--enable-mbstring --enable-pdo --with-curl --disable-debug --disable-rpath \
--enable-inline-optimization --with-bz2 --with-zlib --enable-sockets \
--enable-sysvsem --enable-sysvshm --enable-pcntl --enable-mbregex \
--with-mhash --enable-zip --with-pcre-regex --with-pdo-mysql --with-mysqli \
--with-gd --with-jpeg-dir --with-freetype-dir --enable-calendar
以上就完成了php-fpm的安装
下面是对php-fpm运行用户进行设置
1)为php提供配置文件
cp php.ini-production /usr/work/php/etc/php.ini
2)为php-fpm提供配置文件
cd /usr/work/php
cp etc/php-fpm.conf.default etc/php-fpm.conf
cp php-fpm.d/www.conf.default php-fpm.d/www.conf
vim etc/php-fpm.conf  或者  vim php-fpm.d/www.conf
修改
user = www
group = www
pm.max_children = 150
pm.start_servers = 8
pm.min_spare_servers = 5
pm.max_spare_servers = 10
pid = /usr/local/php/var/run/php-fpm.pid 
然后启动   /usr/work/php/sbin/php-fpm
然后使用ps aux | grep php-fpm命令来查看是否启动成功
需要注意的是php7中www.conf这个配置文件配置phpfpm的端口号等信息,如果你修改默认的9000端口号需在这里改,再改nginx的配置
3)nginx和php-fpm整合
修改nginx.conf
        location ~ \.php$ {
            root           html;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            include        fastcgi_params;
        }
注:
在浏览器访问出现File not found时一般有两种情况
第一种情况:/scripts路径问题
fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
nginx的配置文件无法识别
/scripts
路径 , 所以我们将配置文件中的
/scripts
改为
$document_root即可
第二种情况:目录权限问题
就是把你root文件夹设为其他用户允许 ,

3. 安装MySQL
下载
wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz
解压 
tar -zxvf mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz 
解压后如下

创建mysql 用户组合用户
sudo groupadd mysql
sudo useradd -r -g mysql mysql
改变解压后的文件夹所属组和用户
mv mysql-5.7.21-linux-glibc2.12-x86_64 mysql
sudo ./bin/mysqld --user=mysql --basedir=/usr/work/tool/mysql/ --datadir=/usr/work/tool/mysql/data/ --initialize

cp -a ./support-files/mysql.server  /etc/init.d/mysqld
启动mysql  
sudo /etc/init.d/mysqld start
连接数据库
./mysql -uroot -p

修改密码
set password = password('123');

创建数据库
 create database test DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
为指定用户分配指定数据库权限
grant all privileges on test.* jone@localhost identified by '123';

ps:
a. 如果出现如下报错,是因为5.7已经不支持这样安装了

要采用sudo ./bin/mysqld --user=mysql --basedir=/usr/work/tool/mysql/ --datadir=/usr/work/tool/mysql/data/ --initialize这种方式
b.安装时如果出现报错:

则,yum 安装libaio即可
sudo yum install -y libaio
c. 安装时如果出现如下错误,则说明 datadir 指向的目标目录下已经有数据文件,因此,需要先确保 datadir 目标目录下是空的,避免误操作破坏已有数据。

启动时报错


/etc/my.cnf 下相关内容注释掉即可


参考:
nginx +php : https://www.cnblogs.com/jacksea/p/7667684.html
mysql : http://blog.csdn.net/wb96a1007/article/details/51559741#comments
            https://tieba.baidu.com/p/3881791613?red_tag=0376281197  安装问题
            http://blog.csdn.net/huaishu/article/details/50540814  创建mysql用户方法
./configure \
make && make install
yum -y install libmcrypt-devel mhash-devel libxslt-devel \
cd /usr/work
make && make install
 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值