准备工作
最小化安装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
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
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 设置开机启动
创建群组 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
LNMP安装参考如下文章
Ubuntu 16.04 下源码配置LNMP开发环境 http://www.linuxidc.com/Linux/2016-09/135381.htm
Ubuntu 14.04 搭建 LNMP http://www.linuxidc.com/Linux/2015-05/116933.htm
Ubuntu 14.04 LTS 安装 LNMP Nginx\PHP5 (PHP-FPM)\MysqL http://www.linuxidc.com/Linux/2014-05/102351.htm
在部署LNMP的时候遇到Nginx启动失败的2个问题 http://www.linuxidc.com/Linux/2013-03/81120.htm
Ubuntu安装Nginx PHP5-fpm MysqL(LNMP环境搭建) http://www.linuxidc.com/Linux/2012-10/72458.htm
更多CentOS相关信息见CentOS 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=14