当前位置:   article > 正文

CentOS 7下安装nginx+php+mysql_centos7 部署php+ nginx

centos7 部署php+ nginx

目录

一、安装Nginx

1、安装make

2、安装g++

3、安装PCRE库

4、安装zlib库

5、安装ssl

6、下载和解压nginx

7、添加nginx用户和用户组

8、配置nginx安装参数

9、编译并且安装nginx

10、启动nginx

二、安装PHP

1、添加 epel 源

2、安装依赖

3、下载和安装php

4、为php提供配置文件

5、为php-fpm提供配置文件

6、添加用户和用户组

7、修改配置文件

8、启动php-fpm

9、整合nginx和php-fpm

10、测试php文件

三、安装mysql

1、下载mysql的repo源 并安装

2、配置文件

3、 启动mysql服务

4、登录mysql并重置密码


nginx+php+mysql安装

本次通过源码编译安装,所以在开始前先把编译环境(gcc g++ 和库开发库)安装好,如果服务器已经安装好请跳过。

本文 # 号开头的都为命令(除了位置文件)。

一、安装Nginx

1、安装make

make命令是GNU的工程化编译工具,用于编译众多相互关联的源代码问价,以实现工程化的管理,提高开发效率。

# yum -y install gcc automake autoconf libtool make

2、安装g++

# yum install gcc gcc-c++

3、安装PCRE库

本次安装的是pcre-8.39.tar.gz 可以通过官网网址下载最新的源码库ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/

使用下面命令下载编译和安装 PCRE 包:

  1. $切换到/usr/local/src 目录下
  2. # cd /usr/local/src
  3. $下载源码包
  4. # wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz
  5. $解压源码包
  6. # tar -zxvf pcre-8.39.tar.gz
  7. $进入源码包
  8. # cd pcre-8.39
  9. $检查当前的环境是否满足要安装软件的依赖关系
  10. #./configure
  11. $编译并且安装
  12. # make && make install

4、安装zlib库

http://zlib.net/zlib-1.2.11.tar.gz 可以到官网下载最新的 zlib 源码包,使用下面命令下载编译和安装 zlib包:

  1. $切换到 /usr/local/src目录
  2. # cd /usr/local/src
  3. $下载zlib源码包
  4. # wget http://zlib.net/zlib-1.2.11.tar.gz
  5. $解压源码包
  6. # tar -zxvf zlib-1.2.11.tar.gz
  7. $进入源码包
  8. # cd zlib-1.2.11
  9. $检查当前环境是否满足编译安装的依赖关系
  10. # ./configure
  11. $编译并且安装
  12. # make && make install

5、安装ssl

某些服务器默然没有安装,已经安装的跳过。使用下面命令下载编译和安装。

  1. $切换到/usr/local/src 目录下
  2. # cd /usr/local/src
  3. $下载源码包
  4. # wget https://www.openssl.org/source/openssl-1.1.0b.tar.gz
  5. $解压源码包
  6. # tar -zxvf openssl-1.1.0b.tar.gz
  7. $切换到源码包
  8. # cd cd openssl-1.1.0b
  9. $检查当前的环境是否满足要安装软件的依赖关系
  10. # ./config
  11. $编译并且安装安装
  12. # make && make install

以上基本的环境安装好之后可以开始安装nginx了

这里我安装的是比较稳定的版本ngixn-1.10.2,其他版本的也类似。可到官网 http://nginx.org/download 下载

本次安装的目录是 /usr/local/nginx 使用下面命令下载编译和安装。

6、下载和解压nginx

  1. $切换到该目录下载资源包
  2. # cd /usr/local/src
  3. $下载源码包
  4. # wget http://nginx.org/download/nginx-1.10.2.tar.gz
  5. $解压源码包
  6. # tar -zxvf nginx-1.10.2.tar.gz

7、添加nginx用户和用户组

  1. $进入源码包
  2. # cd nginx-1.10.2
  3. $添加nginx用户和用户组
  4. # groupadd -r nginx
  5. # useradd -r -g nginx nginx

8、配置nginx安装参数

  1. $在/usr/local/src/pcre-8.39/nginx-1.10.2目录中配置以下参数
  2. # ./configure \
  3. --prefix=/usr/local/nginx \
  4. --sbin-path=/usr/local/nginx/sbin/nginx \
  5. --conf-path=/usr/local/nginx/nginx.conf \
  6. --pid-path=/usr/local/nginx/nginx.pid \
  7. --user=nginx \
  8. --group=nginx \
  9. --with-http_ssl_module \
  10. --with-http_flv_module \
  11. --with-http_mp4_module \
  12. --with-http_stub_status_module \
  13. --with-http_gzip_static_module \
  14. --http-client-body-temp-path=/var/tmp/nginx/client/ \
  15. --http-proxy-temp-path=/var/tmp/nginx/proxy/ \
  16. --http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ \
  17. --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \
  18. --http-scgi-temp-path=/var/tmp/nginx/scgi \
  19. --with-pcre=/usr/local/src/pcre-8.39 \
  20. --with-zlib=/usr/local/src/zlib-1.2.11 \
  21. --with-openssl=/usr/local/src/openssl-1.1.0b \

注1:部分参数分析:

--with-pcre=/usr/local/src/pcre-8.39 指的是pcre-8.39 的源码路径。

--with-zlib=/usr/local/src/zlib-1.2.11 指的是zlib-1.2.11 的源码路径。

--with-openssl=/usr/local/src/openssl-1.1.0b 指的是openssl-1.1.0b 的源码路径。

--conf-path=/usr/local/nginx/nginx.conf 指的是配置文件的生成路径。

--prefix=/usr/local/nginx 指的是nginx安装路径

注2:编译选项:(可不看)

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

9、编译并且安装nginx

  1. $编译并且安装
  2. # make && make install

10、启动nginx

为了确保80端口是开放的并且没有占用,我们可以通过以下命令查看。

# netstat -ano|grep 80

如上图所示说明80端口是开放的并且没有被占用

注:如果没开启可以通过以下命令开启80端口

  1. $开启80端口
  2. # firewall-cmd --zone=public --add-port=80/tcp --permanent
  3. $重启防火墙
  4. # firewall-cmd --reload

通过以下命令启动

  1. $前先 创建/var/tmp/nginx/client目录,不然会报错
  2. # mkdir -p /var/tmp/nginx/client
  3. $切换到/usr/local/nginx/sbin目录下
  4. $启动
  5. # ./nginx

启动不出错的情况下我们课通过浏览器输入主机地址测试下,成功如下图所示。

到这nginx就安装完成了

nginx本身不是处理PHP的,它只是个web服务器,当接收到请求后,如果是php请求,则发给php解释器处理,并把结果返回给客户端。

nginx一般是把请求发fastcgi管理进程处理,fascgi管理进程选择cgi子进程处理结果并返回被nginx

二、安装PHP

本文以php-fpm为例介绍如何使nginx支持PHP

安装前安装一些依赖

1、添加 epel 源

# rpm -Uvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm

2、安装依赖

  1. # 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
  2. # yum -y install gcc gcc-c++ glibc
  3. # yum -y install libmcrypt-devel mhash-devel libxslt-devel \
  4. libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel \
  5. zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel \
  6. ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel \
  7. krb5 krb5-devel libidn libidn-devel openssl openssl-devel

3、下载和安装php

  1. $切换到、usr/local/src 目录下
  2. # cd /usr/local/src
  3. $下载源码包
  4. # wget http://au1.php.net/get/php-7.1.10.tar.gz/from/this/mirror
  5. $解压源码包
  6. # tar -zvxf mirror
  7. $切换包源码包目录
  8. # cd php-7.1.10
  9. $检查是否满足编译环境
  10. # ./configure --prefix=/usr/local/php --enable-fpm --with-mcrypt \
  11. --enable-mbstring --enable-pdo --with-curl --disable-debug --disable-rpath \
  12. --enable-inline-optimization --with-bz2 --with-zlib --enable-sockets \
  13. --enable-sysvsem --enable-sysvshm --enable-pcntl --enable-mbregex \
  14. --with-mhash --enable-zip --with-pcre-regex --with-pdo-mysql --with-mysqli \
  15. --with-gd --with-jpeg-dir --with-freetype-dir --enable-calendar
  16. $编译并且安装
  17. # make && make install

4、为php提供配置文件

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

5、为php-fpm提供配置文件

  1. # cp etc/php-fpm.conf.default etc/php-fpm.conf
  2. # cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
  3. # cp /usr/local/php/etc/php-fpm.d/www.conf.default /usr/local/php/etc/php-fpm.d/www.conf

6、添加用户和用户组

  1. 切换到 /usr/local/php 目录下
  2. # cd /usr/local/php
  3. # groupadd www
  4. # useradd -g www www

7、修改配置文件

  1. $切换到 /usr/local/php/etc/下
  2. # cd usr/local/php/etc/
  3. $打开php-fpm.conf配置文件
  4. # vim php-fpm.conf

修改

pid = /usr/local/php/var/run/php-fpm.pid

  1. $切换到 cd /usr/local/php/etc/php-fpm.d目录下
  2. # cd /usr/local/php/etc/php-fpm.d
  3. $打开www.conf配置文件
  4. # vim www.conf

修改

user = www
group = www

pm.max_children = 150

pm.start_servers = 8

pm.min_spare_servers = 5

pm.max_spare_servers = 10

8、启动php-fpm

# /usr/local/php/sbin/./php-fpm

9、整合nginx和php-fpm

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

修改如下 ( #号开头为注释)

  1. user www;
  2. worker_processes auto;
  3. #error_log logs/error.log;
  4. #error_log logs/error.log notice;
  5. #error_log logs/error.log info;
  6. pid /usr/local/nginx/nginx.pid;
  7. worker_rlimit_nofile 51200;
  8. events {
  9. worker_connections 1024;
  10. }
  11. http {
  12. include mime.types;
  13. default_type application/octet-stream;
  14. #log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  15. # '$status $body_bytes_sent "$http_referer" '
  16. # '"$http_user_agent" "$http_x_forwarded_for"';
  17. #access_log logs/access.log main;
  18. sendfile on;
  19. #tcp_nopush on;
  20. #keepalive_timeout 0;
  21. keepalive_timeout 65;
  22. #gzip on;
  23. server {
  24. listen 80;
  25. server_name localhost;
  26. #charset koi8-r;
  27. #access_log logs/host.access.log main;
  28. location / {
  29. root html;
  30. index index.html index.htm;
  31. }
  32. #error_page 404 /404.html;
  33. # redirect server error pages to the static page /50x.html
  34. #
  35. error_page 500 502 503 504 /50x.html;
  36. location = /50x.html {
  37. root html;
  38. }

重启nginx

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

10、测试php文件

在/usr/local/nginx/html下创建index.php文件

# touch index.php

输入一下内容

  1. <?php
  2. phpinfo();
  3. ?>

打开浏览器测试成功如下

到此php-fpm就安装完成了

三、安装mysql

1、下载mysql的repo源 并安装

此源安装的是最新版的

  1. # cd /usr/local/src/
  2. # wget http://repo.mysql.com/mysql57-community-release-el7-8.noarch.rpm
  3. # rpm -ivh mysql57-community-release-el7-8.noarch.rpm
  4. # yum -y install mysql-server

2、配置文件

默认配置文件路径: /etc/my.cnf 

  1. $ 编写my.cnf文件
  2. # vim /etc/my.cnf

配置后如下(#号是注释)

  1. # For advice on how to change settings please see
  2. # For advice on how to change settings please see
  3. # http://dev.mysql.com/doc/refman/5.7/en/server-configuration-defaults.html
  4. [mysqld]
  5. #
  6. # Remove leading # and set to the amount of RAM for the most important data
  7. # cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
  8. # innodb_buffer_pool_size = 128M
  9. #
  10. # Remove leading # to turn on a very important data integrity option: logging
  11. # changes to the binary log between backups.
  12. # log_bin
  13. #
  14. # Remove leading # to set options mainly useful for reporting servers.
  15. # The server defaults are faster for transactions and fast SELECTs.
  16. # Adjust sizes as needed, experiment to find the optimal values.
  17. # join_buffer_size = 128M
  18. # sort_buffer_size = 2M
  19. # read_rnd_buffer_size = 2M
  20. datadir=/var/lib/mysql
  21. socket=/var/lib/mysql/mysql.sock
  22. server_id = 1
  23. expire_logs_days = 3
  24. port=3306
  25. sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
  26. # Disabling symbolic-links is recommended to prevent assorted security risks
  27. symbolic-links=0
  28. log-error=/var/log/mysqld.log
  29. pid-file=/var/run/mysqld/mysqld.pid

3、 启动mysql服务

# service mysqld restart

4、登录mysql并重置密码

mysql安装后密码是随机的,可以通过以下命令查看

# grep "password" /var/log/mysqld.log

运行后密码如下

输入命令登录

  1. $ 输入以下命令回车输入刚才查看的密码
  2. # mysql -u root -p

登录成功后,我们必须重置密码不然不能操作数据库,会报错如下

error You must reset your password using ALTER USER statement before executing this statement.),解决方法:

  1. $为了防止输入的密码过于简单而不能修改
  2. # set global validate_password_policy=0;
  3. 新密码
  4. # SET PASSWORD = PASSWORD('your new password');
  5. # ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;
  6. # flush privileges;

修改密码成功后如下

到此nginx+php+mysql环境已经搭建好了!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/151015
推荐阅读
相关标签
  

闽ICP备14008679号