• Linux 安装Nginx+PHP+MySQL教程


    一、安装nginx
    通过yum安装openssl:
    
    yum -y install openssl openssl-devel
    通过yum安装pcre:
    
    yum -y install  pcre-devel
    通过yum安装zlib:
    
    yum -y install  zlib-devel
    tar zxvf nginx-1.8.0.tar.gz 
    cd nginx-1.8.0 
    ./configure --prefix=/home/nginx //配置安装目录

      

    make 编译 (make的过程是把各种语言写的源码文件,变成可执行文件和各种库文件)
    
    make install 安装 (make install是把这些编译出来的可执行文件和库文件复制到合适的地方)
    启动nginx /home/nginx/sbin/nginx 
    重启nginx /home/nginx/sbin/nginx -s reload
    

     二、linux防火墙开放特定端口(iptables)

    查看状态:
    iptables -L -n
    下面添加对特定端口开放的方法:
    使用iptables开放如下端口
    /sbin/iptables -I INPUT -p tcp --dport 8000 -j ACCEPT
    保存
    /etc/rc.d/init.d/iptables save
    重启服务
    service iptables restart
    查看需要打开的端口是否生效?
    /etc/init.d/iptables status
    
    法2:
    或直接编辑/etc/sysconfig/iptables
    -A INPUT -p tcp -m tcp --dport 4000 -j ACCEPT
    保存在前面部分
    再重启:
    service iptables restart

     三、安装PHP

    首先打开php官网http://php.net/点击导航栏的Downloads进入下载页面:http://php.net/downloads.php

    这里下载最新版的php 7.0.5 的源码包:

    tar 是打包程序, bzip2 和 gzip是两种压缩软件.
    tar -zcvf: tar 调用gzip打包压缩, 出来的包是.tar.gz
    tar -jcvf: tar 调用bzip2打包压缩, 出来的包是.tar.bz2.
    同样, 解.tar.gz包用 tar -zxvf, 解.tar.bz2包用 tar -jxvf.

    下载下来之后上传至服务器

    因为php安装需要编译,所以服务器应该保证gcc和g++环境的安装

    tar -xvzf php-7.0.5.tar.gz
    cd php-7.0.5
    

     接下来进行参数配置,配置前如果没有libxml2和libxml2-devel会报错,所以应该更新libxml2并安装libxml2-devel,使用在线安装:

    yum -y install openssl
    yum -y install openssl-devel
    yum -y install curl
    yum -y install curl-devel
    yum -y install libcurl-devel yum -y install libjpeg yum -y install libjpeg-devel yum -y install libpng yum -y install libpng-devel yum -y install freetype yum -y install freetype-devel yum -y install pcre yum -y install pcre-devel yum -y install libxslt yum -y install libxslt-devel yum -y install bzip2 yum -y install bzip2-devel

    安装完成之后,执行配置:

    ./configure --prefix=/home/php --with-curl --with-freetype-dir --with-gd --with-gettext --with-iconv-dir --with-kerberos --with-libdir=lib64 --with-libxml-dir --with-mysqli --with-openssl --with-pcre-regex --with-pdo-mysql --with-pdo-sqlite --with-pear --with-png-dir --with-jpeg-dir --with-xmlrpc --with-xsl --with-zlib --with-bz2 --with-mhash --enable-fpm --enable-bcmath --enable-libxml --enable-inline-optimization --enable-gd-native-ttf --enable-mbregex --enable-mbstring --enable-opcache --enable-pcntl --enable-shmop --enable-soap --enable-sockets --enable-sysvsem --enable-sysvshm --enable-xml --enable-zip
    

      实际上这里的配置项比上述还多,可以使用 ./configure --help 命令查看所有选项,这里注意在php7中--with-mysql原生支持已经不存在了,操作都变成mysqli或者pdo了;以上这些选项在正常的php开发中完全够用了,后期如果需要,可以选择手动开启相应的模块

    然后执行编译:

    make

    若此时提示libtool: link: `xx’ is not a valid libtool object

    解决方法
    用命令
    make clean
    然后在重新执行命令

    编译时间可能会有点长,编译完成之后,执行安装:

    make install

    php的默认安装位置上面已经指定为/home/php,接下来配置相应的文件:

    cp php.ini-development /home/php/lib/php.ini
    cp /home/php/etc/php-fpm.conf.default /home/php/etc/php-fpm.conf
    cp sapi/fpm/php-fpm /home/bin
    

      然后设置php.ini,使用: vim /home/php/lib/php.ini打开php配置文件找到cgi.fix_pathinfo配置项,这一项默认被注释并且值为1,根据官方文档的说明,这里为了当文件不存在时,阻止Nginx将请求发送到后端的PHP-FPM模块,从而避免恶意脚本注入的攻击,所以此项应该去掉注释并设置为0

    设置完毕保存并退出

      另外注意一个地方就是php.ini配置文件的位置可以在编译前配置参数中设置,编译参数可以写成:--with-config-file-path=/home/php 这样的话php就回去指定的目录下读取php.ini配置文件,如果不加这个参数默认位置就是php安装目录下的lib目录,具体也可以在phpinfo()输出界面查看,如果php.ini放到其他位置,php读取不到,那么所有的配置修改后都是不生效的,这点要注意

    此时首先应该创建web用户:

    groupadd www-data
    useradd -g www-data www-data
    

     然后网上一些教程说让修改php-fpm.conf添加以上创建的用户和组,这时候使用vim /home/php-fpm.conf打开文件后找不到官方所提示的位置:

     

    如果此时随便在一个位置添加,那么接下来启动php-fpm的时候,会报目录找不到的错误,所以不要在php-fpm.conf中添加用户和组,这个时候翻到php-fpm.conf最后一行会发现如下内容(如果编译时添加--prefix选项以下位置会自动补全,默认是下面是空的,要注意):

    这里引入了php-fpm.d目录下所有的conf配置文件,但是NONE需要修改为我们的实际目录:/home/php

    默认情况下etc/php-fpm.d/下有一个名为www.conf.defalut的配置用户的文件,执行下面命令复制一个新文件并且打开:

    cp /usr/local/etc/php-fpm.d/www.conf.default /usr/local/etc/php-fpm.d/www.conf
    vim /usr/local/etc/php-fpm.d/www.conf
    

      默认user和group的设置为nobody,将其改为www-data

     

    修改完成之后,保存并退出,然后执行以下命令启动php-fpm服务:

    /home/php/sbin/php-fpm
    

      启动完毕之后,php-fpm服务默认使用9000端口,使用 netstat -tln | grep 9000 可以查看端口使用情况:

    9000端口正常使用,说明php-fpm服务启动成功

      然后执行 vim /home/nginx/nginx.conf编辑nginx配置文件,具体路径根据实际的nginx.conf配置文件位置编辑,下面主要修改nginx的server {}配置块中的内容,修改location块,追加index.php让nginx服务器默认支持index.php为首页:

    然后配置.php请求被传送到后端的php-fpm模块,默认情况下php配置块是被注释的,此时去掉注释并修改为以下内容:

    这里面很多都是默认的,root是配置php程序放置的根目录,主要修改的就是fastcgi_param中的/scripts为$document_root

      修改完上面的,回到nginx.conf第一行,默认是#user nobody;  这里要去掉注释改为user www-data;或者user www-data www-data;表示nginx服务器的权限为www-data

      修改完这些保存并退出,然后重启nginx:

    /home/nginx/nginx -s stop
    /home/nginx/nginx 
    

     四、安装MySQL

     

    去网站下载MySQL的yum源,地址如下:
    http://repo.mysql.com/
    Linux上先查看系统的版本号,根据版本号对应下载
    more /etc/redhat-release

    rpm -Uvh http://repo.mysql.com/mysql-community-release-el6-5.noarch.rpm

    yum -y upgrade mysql
    mysql_upgrade

    五、设置开机启动

    1、设置nginx开机启动

    1、在/etc/init.d/目录下创建脚本

    vi  /etc/init.d/nginx
    

    2、更改脚本权限

    chmod 775 /etc/init.d/nginx
    

    3、编写脚本内容

    #!/bin/bash
    # nginx Startup script for the Nginx HTTP Server
    # it is v.0.0.2 version.
    # chkconfig: - 85 15
    # description: Nginx is a high-performance web and proxy server.
    #              It has a lot of features, but it's not for everyone.
    # processname: nginx
    # pidfile: /var/run/nginx.pid
    # config: /usr/local/nginx/conf/nginx.conf
    nginxd=/home/nginx/sbin/nginx
    nginx_config=/home/nginx/conf/nginx.conf
    nginx_pid=/home/nginx/logs/nginx.pid
    RETVAL=0
    prog="nginx"
    # Source function library.
    . /etc/rc.d/init.d/functions
    # Source networking configuration.
    . /etc/sysconfig/network
    # Check that networking is up.
    [ ${NETWORKING} = "no" ] && exit 0
    [ -x $nginxd ] || exit 0
    # Start nginx daemons functions.
    start() {
    if [ -e $nginx_pid ];then
       echo "nginx already running...."
       exit 1
    fi
       echo -n $"Starting $prog: "
       daemon $nginxd -c ${nginx_config}
       RETVAL=$?
       echo
       [ $RETVAL = 0 ] && touch /var/lock/subsys/nginx
       return $RETVAL
    }
    # Stop nginx daemons functions.
    stop() {
            echo -n $"Stopping $prog: "
            killproc $nginxd
            RETVAL=$?
            echo
            [ $RETVAL = 0 ] && rm -f /var/lock/subsys/nginx /var/run/nginx.pid
    }
    # reload nginx service functions.
    reload() {
        echo -n $"Reloading $prog: "
        #kill -HUP `cat ${nginx_pid}`
        killproc $nginxd -HUP
        RETVAL=$?
        echo
    }
    # See how we were called.
    case "$1" in
    start)
            start
            ;;
    stop)
            stop
            ;;
    reload)
            reload
            ;;
    restart)
            stop
            start
            ;;
    status)
            status $prog
            RETVAL=$?
            ;;
    *)
            echo $"Usage: $prog {start|stop|restart|reload|status|help}"
            exit 1
    esac
    exit $RETVAL
    

      

    vi /etc/rc.local

    加入一行  /etc/init.d/nginx start    保存并退出,下次重启会生效。

  • 相关阅读:
    Objective-C中的Block回调模式
    [LINUX-02]linux内存管理
    Linux设备模型(8)_platform设备
    Face Alignment
    dlib 人脸识别论文 One Millisecond Face Alignment with an Ensemble of Regression Trees
    linux内核函数kmap_atomic用法
    [LINUX-01]对比LINUX和CORTEX-M启动流程
    -02-建立PetaLinux工程
    linux内核启动流程(文章最后流程图)
    uboot笔记:uboot命令分析+实现
  • 原文地址:https://www.cnblogs.com/blog-dyn/p/6646146.html
Copyright © 2020-2023  润新知