美文网首页LAMP
CentOS 6.5下编译安装新版LNMP

CentOS 6.5下编译安装新版LNMP

作者: 搬砖的作家 | 来源:发表于2016-09-30 15:59 被阅读144次

    准备工作
    最小化安装centos6.5
    我们安装完成CentOS系统,默认都是系统自带的yum源,国内用户用yum安装软件的时候,是比较慢的,为了提高效率,一般我们会配置国内的yum源。

    wget http://mirrors.163.com/.help/CentOS6-Base-163.repo
    mv  CentOS6-Base-163.repo  /etc/yum.repos.d/
    yum makecache
    

    建立一个软件包存放的目录

    cd ~
    mkdir src
    

    清理已经安装包

    rpm -e httpd
    rpm -e mysql
    rpm -e php
    yum -y remove httpd
    yum -y remove mysql
    yum -y remove php
    
    #搜索apache包
    rpm -qa http*
    
    #强制卸载apache包
    rpm -e --nodeps 查询出来的文件名
    
    #检查是否卸载干净
    rpm -qa|grep http*
    

    selinux可能会致使编译安装失败,我们先禁用它。永久禁用,需要重启生效

    sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
    

    安装必备工具

    yum -y install make gcc gcc-c++ gcc-g77 flex bison file libtool libtool-libs autoconf kernel-devel libjpeg libjpeg-devel libpng libpng-devel libpng10 libpng10-devel gd gd-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glib2 glib2-devel bzip2 bzip2-devel libevent libevent-devel ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel krb5 krb5-devel libidn libidn-devel openssl openssl-devel gettext gettext-devel ncurses-devel gmp-devel pspell-devel unzip libcap lsof
    

    安装mysql5.6.33
    按照标准需要给mysql创建所属用户和用户组

    groupadd mysql                             创建用户组            
    创建一个用户,不允许登陆和不创主目录              
    useradd -s /sbin/nologin -g mysql -M mysql  
    tail -1 /etc/passwd                        检查创建用户
    

    centos最小化安装后,会有mysql的库因此先卸载!

    rpm -qa|grep mysql                                检查安装与否
    rpm -e mysql-libs-5.1.73-3.el6_5.x86_64 --nodeps   强制卸载 
    

    MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具。 因此,我们首先要在系统中源码编译安装cmake工具。

    wget --no-check-certificate http://www.cmake.org/files/v2.8/cmake-2.8.12.2.tar.gz 
    tar zxvf cmake-2.8.12.2.tar.gz 
    cd cmake-2.8.12.2 
    ./configure 
    make && make install
    

    使用cmake来编译安装mysql5.6.33

    wget http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.33.tar.gz
    tar zxvf mysql-5.6.33.tar.gz
    cd mysql-5.6.17
    cmake \
    -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
    -DMYSQL_DATADIR=/usr/local/mysql/data \
    -DSYSCONFDIR=/etc \
    -DWITH_MYISAM_STORAGE_ENGINE=1 \
    -DWITH_INNOBASE_STORAGE_ENGINE=1 \
    -DWITH_MEMORY_STORAGE_ENGINE=1 \
    -DWITH_READLINE=1 \
    -DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.sock \
    -DMYSQL_TCP_PORT=3306 \
    -DENABLED_LOCAL_INFILE=1 \
    -DWITH_PARTITION_STORAGE_ENGINE=1 \
    -DEXTRA_CHARSETS=all \
    -DDEFAULT_CHARSET=utf8 \
    -DDEFAULT_COLLATION=utf8_general_ci \
    -DMYSQL_USER=mysql \
    -DWITH_DEBUG=0 \
    -DWITH_SSL=system
    make && make install
    

    修改/usr/local/mysql权限

    chmod +w /usr/local/mysql
    chown -R mysql:mysql /usr/local/mysql
    

    关于my.cnf配置文件:

    在启动MySQL服务时,会按照一定次序搜索my.cnf,先在/etc目录下找,找不到则会搜索”$basedir/my.cnf” 就是安装目录下 /usr/local/mysql/my.cnf,这是新版MySQL的配置文件的默认位置! 注意:在CentOS 6.x版操作系统的最小安装完成后,在/etc目录下会存在一个my.cnf,需要将此文件更名为其他的名字。 如:/etc/my.cnf.bak,否则,该文件会干扰源码安装的MySQL的正确配置,造成无法启动, 由于我们已经卸载了最小安装完成后的mysq库所以,就没必要操作了。

    进入support-files目录

    cd support-files/     如果还有my.cnf请备份
    mv /etc/my.cnf     /etc/my.cnf.bak
    cp my-default.cnf  /etc/my.cnf  如果愿意也可以复制配置文件到etc下
    

    执行初始化配置脚本,创建系统自带的数据库和表,注意配置文件的路径

    /usr/local/mysql/scripts/mysql_install_db --defaults-file=/etc/my.cnf --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql
    

    拷贝mysql安装目录下support-files服务脚本到init.d目录

    cp support-files/mysql.server /etc/init.d/mysqld    #拷贝脚本
    chmod +x /etc/init.d/mysqld              #赋予权限
    

    设置开机启动

    chkconfig mysqld on
    启动MySQL
    service mysqld start
    或者
    /etc/init.d/mysql start
    

    MySQL5.6.x启动成功后,root默认没有密码,我们需要设置root密码。 设置之前,我们需要先设置PATH,要不,不能直接调用mysql

    修改/etc/profile文件
    vi /etc/profile
    在文件末尾添加
    PATH=/usr/local/mysql/bin:$PATH
    export PATH
    

    让配置立即生效

    source /etc/profile
    

    登陆测试,默认是没有密码,直接回车就可进入

    mysql -uroot -p
    

    设置mysql密码

    /usr/local/mysql/bin/mysqladmin -uroot -p password '你的密码'
    

    注意如果复制上去不能改变密码请手动输入

    登陆进命令行模式

    mysql -uroot -p
    

    输入上面设置的密码以后能够成功登陆后就标志着我们的mysql已经安装完成了,是不是感觉特别兴奋呢,至于mysql的详细设置我们在以后的项目在具体介绍
    接下来我们安装php
    安装依赖关系
    libiconv库为需要做转换的应用提供了一个iconv()的函数,以实现一个字符编码到另一个字符编码的转换。 错误提示:configure: error: Please reinstall the iconv library.

    wget http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.14.tar.gz
    tar zxvf libiconv-1.14.tar.gz
    cd libiconv-1.14
    ./configure --prefix=/usr/local/libiconv
    make && make install
    cd ..
    

    libmcrypt是加密算法扩展库。 错误提示:configure: error: Cannot find imap library (libc-client.a). Please check your c-client installation.

    wget http://iweb.dl.sourceforge.net/project/mcrypt/Libmcrypt/2.5.8/libmcrypt-2.5.8.tar.gz
    tar zxvf libmcrypt-2.5.8.tar.gz
    cd libmcrypt-2.5.8
    ./configure
    make && make install
    cd ..
    

    Mhash是基于离散数学原理的不可逆向的php加密方式扩展库,其在默认情况下不开启。 mhash的可以用于创建校验数值,消息摘要,消息认证码,以及无需原文的关键信息保存 错误提示:configure: error: “You need at least libmhash 0.8.15 to compile this program. http://mhash.sf.net/

    wget http://124.202.164.16/files/104300000800FF47/soft.beauty-soft.net/lib/mhash/mhash-0.9.9.9.tar.gz
    tar -xzvf mhash-0.9.9.9.tar.gz
    cd mhash-0.9.9.9
    ./configure
    make && make install
    cd ..
    

    mcrypt 是 php 里面重要的加密支持扩展库,Mcrypt扩展库可以实现加密解密功能,就是既能将明文加密,也可以密文还原。

    wget http://jaist.dl.sourceforge.net/project/mcrypt/MCrypt/2.6.8/mcrypt-2.6.8.tar.gz
    tar zxvf mcrypt-2.6.8.tar.gz
    cd mcrypt-2.6.8
    ./configure
    make && make install
    cd ..
    

    编译mcrypt可能会报错:configure: error: *** libmcrypt was not found

    vi  /etc/ld.so.conf
    最后一行添加
    /usr/local/lib/
    载入
    ldconfig
    

    编译mcrypt可能会报错:/bin/rm: cannot remove `libtoolT': No such file or directory

    修改 configure 文件,把RM='$RM'改为RM='$RM -f' 这里的$RM后面一定有一个空格。 如果后面没有空格,直接连接减号,就依然会报错。

    正式开始编译php!

    wget http://au1.php.net/get/php-5.6.26.tar.gz/from/this/mirror
    mv mirror   php-5.6.26.tar.gz
    tar zxvf php-5.6.26.tar.gz
    cd php-5.6.26
    ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --enable-fpm --with-fpm-user=www --with-fpm-group=www --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --with-iconv-dir --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-magic-quotes --enable-safe-mode --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers --enable-mbregex --enable-mbstring --with-mcrypt --enable-ftp --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --without-pear --with-gettext --disable-fileinfo --enable-maintainer-zts
    make && make install
    

    修改fpm配置php-fpm.conf.default文件名称

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

    复制php.ini配置文件

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

    复制php-fpm启动脚本到init.d

    cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm
    chmod +x /etc/init.d/php-fpm  赋予执行权限
    chkconfig --add php-fpm        添加为启动项
    chkconfig php-fpm on            设置开机启动
    

    按照标准,给php-fpm创建一个指定的用户和组

    创建群组
    groupadd www
    创建一个用户,不允许登陆和不创主目录 
    useradd -s /sbin/nologin -g www -M www
    

    立即启动php-fpm

    service php-fpm start
    #或者
    /etc/init.d/php-fpm start
    

    回到src/目录
    安装nginx
    Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,由俄罗斯的程序设计师Igor Sysoev所开发,其特点是占有内存少,并发能力强,第一个公开版本0.1.0发布于2004年10月4日
    1、安装prce(重定向支持)和openssl(https支持,如果不需要https可以不安装。)

    yum -y install pcre*
    yum -y install openssl*
    

    CentOS 6.5 我安装的时候是选择的“基本服务器”,默认这两个包都没安装全,所以这两个都运行安装即可。
    接下来开始安装

    wget http://219.239.26.4/files/32480000085AA7C7/nginx.org/download/nginx-1.10.1.tar.gz
    tar -zxvf nginx-1.10.1.tar.gz
    cd nginx-1.10.1
    ./configure --prefix=/usr/local/nginx-1.10.1 \
    --with-http_ssl_module  \
    --with-http_stub_status_module --with-pcre
    make
    make install
    

    开启nginx进程

    /usr/local/nginx-1.10.1/sbin/nginx
    重启或关闭进程:
    /usr/local/nginx-1.10.1/sbin/nginx -s reload
    /usr/local/nginx-1.10.1/sbin/nginx -s stop
    

    关闭防火墙,或者添加防火墙规则就可以测试了。

    service iptables stop  关闭防火墙  
    或者添加一条防火墙规则
    -A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT
    service iptables restart
    

    相关文章

      网友评论

      • rosekissyou:楼主知道怎么访问127.0.0.1的文件夹吗?我的安装好了不能访问文件夹

      本文标题:CentOS 6.5下编译安装新版LNMP

      本文链接:https://www.haomeiwen.com/subject/rpbkyttx.html