先装好rhel6.5 配置好实验环境

关掉NetworkManager,并停止掉开机自启动
[root@duwensql ~]# service NetworkManager stop [root@duwensql ~]# chkconfig -- list NetworkManager [root@duwensql ~]# chkconfig NetworkManager off关掉iptables
[root@duwensql ~]# iptables -F [root@duwensql ~]# service iptables save iptables£o·àe1ò±£′μ /etc/sysconfig/iptables£o [è·¨] [root@duwensql ~]# chkconfig iptables off关掉selinux
[root@duwensql ~]# getenforce Enforcing [root@duwensql ~]# setenforce usage: setenforce [ Enforcing | Permissive | 1 | 0 ] [root@duwensql ~]# setenforce 0 [root@duwensql ~]# [root@duwensql ~]# vim /etc/selinux/config打开这个档案以后你可以看到如下的内容,把SELINUX的值改成disabled就好
# This file controls the state of SELinux on the system. # SELINUX= can take one of these three values: # enforcing - SELinux security policy is enforced. # permissive - SELinux prints warnings instead of enforcing. # disabled - No SELinux policy is loaded. SELINUX=disabled # SELINUXTYPE= can take one of these two values: # targeted - Targeted processes are protected, # mls - Multi Level Security protection. SELINUXTYPE=targeted修改主机名映射,可以不改,但是为了方便还是改下吧
[root@duwensql ~]# cat /etc/hosts 127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4 ::1 localhost localhost.localdomain localhost6 localhost6.localdomain6 [root@duwensql ~]# echo "192.168.20.253 duwensql.cn MySQL" >> /etc/hosts [root@duwensql ~]# cat /etc/hosts 127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4 ::1 localhost localhost.localdomain localhost6 localhost6.localdomain6 192.168.20.253 duwensql.cn MySQL [root@duwensql ~]#修改主机名,就是编辑下面的这个档案,这里只贴上修改后的内容
[root@duwensql ~]# cat /etc/sysconfig/network NETWORKING=yes HOSTNAME=duwensql.cn GATEWAY=192.168.20.2 NTPSERVERARGS=iburst [root@duwensql ~]#配置本地yum源
[root@duwensql ~]# [root@duwensql ~]# mount /dev/sr0 /mnt/ mount: block device /dev/sr0 is write-protected, mounting read-only [root@duwensql ~]# df -h | tail -1 /dev/sr0 3.6G 3.6G 0 100% /mnt [root@duwensql ~]# echo "/dev/sr0 /mnt/ iso9660 defaults 0 0" >> /etc/fstab [root@duwensql ~]# rm -rf /etc/yum.repos.d/* [root@duwensql ~]# cat > /etc/yum.repos.d/rhel6.repo <检测依赖环境,包括gcc,gcc-c++,autoconf,automake,zlib ,zlib-devel, openssl ,openssl-devel ,pcre-devel,
[root@duwensql ~]# [root@duwensql ~]# yum install -y gcc gcc-c++ autoconf automake [root@duwensql ~]# yum install -y zlib zlib-devel openssl openssl-devel pcre-devel为了方便从xshell上传软件包,这里安装一个工具
[root@duwensql ~]# rpm /mnt/Packages/lrzsz-0.12.20-27.1.el6.x86_64.rpm -ih warning: /mnt/Packages/lrzsz-0.12.20-27.1.el6.x86_64.rpm: Header V3 RSA/SHA256 Signature, key ID fd431d51: NOKEY ########################################### [100%] ########################################### [100%] [root@duwensql ~]#//上传软件包:nginx-1.6.0.tar.gz mysql-5.5.30.tar.gz php-5.4.14.tar.bz2
[root@duwensql ~]# rz z waiting to receive.**B0100000023be50 [root@duwensql ~]# ls anaconda-ks.cfg install.log.syslog nginx-1.6.0.tar.gz 公共的 视频 文档 音乐 install.log mysql-5.5.30.tar.gz php-5.4.14.tar.bz2 模板 图片 下载 桌面正式开始安装MySQL了
解压到指定目录/usr/local/src/
[root@duwensql ~]# [root@duwensql ~]# tar -zxf mysql-5.5.30.tar.gz -C /usr/local/src/建一个mysql用户,这里把这个用户显示出来
[root@duwensql ~]# tail -1 /etc/passwd mysql:x:500:500::/home/mysql:/sbin/nologin [root@duwensql ~]#//安装cmake
[root@duwensql ~]# yum install -y cmake建立mysql的目录
[root@duwensql /]# mkdir /server [root@duwensql ~]# cd /usr/local/src/mysql-5.5.30/ [root@duwensql mysql-5.5.30]# cmake -DCMAKE_INSTALL_PREFIX=/server/mysql-5.5 -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSERS=all -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINT=1 -DENABLED_LOCAL_INFILE=1 -DMYSQL_DATADIR=/server/mysql/data -DMYSQL_USER=mysql//报错啦啦啦啦
CMake Error at cmake/readline.cmake:83 (MESSAGE): Curses library not found. Please install appropriate package, remove CMakeCache.txt and rerun cmake.On Debian/Ubuntu, package name is libncurses5-dev, on Redhat and derivates it is ncurses-devel. Call Stack (most recent call first): cmake/readline.cmake:127 (FIND_CURSES) cmake/readline.cmake:217 (MYSQL_USE_BUNDLED_LIBEDIT) CMakeLists.txt:269 (MYSQL_CHECK_READLINE) -- Configuring incomplete, errors occurred!//这个错误就是ncurses这个依赖没有装,yum安装一下
[root@duwensql ncurses-5.9]# yum -y install ncurses-devel//装了那个ncurses依赖,还是报错,就只好把这个CMakeCache.txt找出来干掉了
[root@duwensql mysql-5.5.30]# find / -name CMakeCache.txt /usr/local/src/mysql-5.5.30/CMakeCache.txt [root@duwensql mysql-5.5.30]# rm -rf /usr/local/src/mysql-5.5.30/CMakeCache.txt//OK,现在重新cmake

//呐开心不,没有报错了呢!!!
现在make &&make install,过程就不写了
配置运行环境
[root@duwensql mysql-5.5.30]# cd /server/ [root@duwensql server]# ls mysql-5.5 [root@duwensql server]# chown -R mysql:mysql /server/mysql-5.5/复制mysql配置文件
[root@duwensql server]# cd /etc/ [root@duwensql etc]# ll my.cnf -rw-r--r--. 1 root root 251 8月 9 2013 my.cnf [root@duwensql etc]# mv ./my.cnf ./my.cnf.back [root@duwensql etc]# cp /usr/local/src/mysql-5.5.30/support-files/my-large.cnf /etc/my.cnf [root@duwensql etc]#这个步骤是加入开机启动项
[root@duwensql init.d]# cp /usr/local/src/mysql-5.5.30/support-files/mysql.server /etc/init.d/mysqld5.5 [root@duwensql init.d]# chmod +x ./mysqld5.5 [root@duwensql init.d]# pwd /etc/init.d [root@duwensql init.d]#//这里要改下,大概在第70行
[root@duwensql init.d]# vim /etc/init.d/mysqld5.5 [root@duwensql init.d]# head -71 /etc/init.d/mysqld5.5 |tail -7 then basedir=/server/mysql-5.5 bindir=/server/mysql-5.5/bin if test -z "$datadir" then datadir=/server/mysql-5.5/data fi [root@duwensql init.d]#//加入开机启动项
[root@duwensql init.d]# chkconfig mysqld5.5 on [root@duwensql init.d]# chkconfig --list mysqld5.5 mysqld5.5 0:关闭1:关闭2:启用3:启用4:启用5:启用6:关闭 [root@duwensql init.d]#初始化mysql
[root@duwensql init.d]# cd /usr/local/src/mysql-5.5.30/scripts/ [root@duwensql scripts]# chmod +x mysql_install_db [root@duwensql scripts]# ./mysql_install_db --defaults-file=/etc/my.cnf --basedir=/server/mysql-5.5 --datadir=/server/mysql-5.5/data --user=mysql Installing MySQL system tables... OK Filling help tables... OK To start mysqld at boot time you have to copy support-files/mysql.server to the right place for your system PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER ! To do so, start the server, then issue the following commands: /server/mysql-5.5/bin/mysqladmin -u root password 'new-password' /server/mysql-5.5/bin/mysqladmin -u root -h duwensql password 'new-password' Alternatively you can run: /server/mysql-5.5/bin/mysql_secure_installation which will also give you the option of removing the test databases and anonymous user created by default. This is strongly recommended for production servers. See the manual for more instructions. You can start the MySQL daemon with: cd /server/mysql-5.5 ; /server/mysql-5.5/bin/mysqld_safe & You can test the MySQL daemon with mysql-test-run.pl cd /server/mysql-5.5/mysql-test ; perl mysql-test-run.pl Please report any problems with the /server/mysql-5.5/scripts/mysqlbug script! [root@duwensql scripts]#开启mysql
[root@duwensql scripts]# /etc/init.d/mysqld5.5 start Starting MySQL... [确定] [root@duwensql scripts]#测试MySQL
//我这里最开始在家目录输入mysql显示没有命令,是因为没有加入环境变量的缘故啦,这里就不写出来了,直接到绝对路径去测试
root@duwensql mysql-test]# cd /server [root@duwensql server]# ls mysql-5.5 [root@duwensql server]# cd mysql-5.5/ [root@duwensql mysql-5.5]# ls bin COPYING data docs include INSTALL-BINARY lib man mysql-test README scripts share sql-bench support-files [root@duwensql mysql-5.5]# cd bin/ [root@duwensql bin]# ./mysql Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 1 Server version: 5.5.30-log Source distribution Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | mysql | | performance_schema | | test | +--------------------+ 4 rows in set (0.04 sec) mysql>ctrl + c 退出
给他加个环境变量吧
[root@duwensql ~]# echo $PATH /usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin [root@duwensql ~]# PATH="$PATH":/server/mysql-5.5/bin/设置mysql的root账户密码,并测试登陆
[root@duwensql ~]# mysqladmin -uroot password '123456' [root@duwensql ~]# mysql -u root -p123456 Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 4 Server version: 5.5.30-log Source distribution Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql>ctrl + c 退出
MySQL安装完了
来安装nginx吧
解压
[root@duwensql ~]# tar -zxf nginx-1.6.0.tar.gz编译
[root@duwensql nginx-1.6.0]# ./configure --prefix=server/nginx-1.6.0 --user=nginx --group=nginx --with-http_dav_module --with-http_stub_status_module --with-http_addition_module --with-http_sub_module --with-http_flv_module --with-http_mp4_module结果太多就不写了,放一个图

make&&make install
[root@duwensql nginx-1.6.0]# make -j 4 && make install开始配置
[root@duwensql nginx-1.2.8]# pwd /server/nginx-1.2.8 [root@duwensql nginx-1.2.8]# vim conf/nginx.conf第二行加
user nginx nginx;然后加下面的内容,括号{前面有空格
location ~ \.php$ { root html; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /server/nginx-1.2.8/html$fastcgi_script_name; include fastcgi_params; }大概的位置如下图

启动服务
[root@duwensql nginx-1.2.8]# /server/nginx-1.2.8/sbin/nginx把服务加入开机启动
[root@duwensql nginx-1.2.8]# echo '/server/nginx-1.2.8/sbin/nginx & ' >> /etc/rc.local [root@duwensql nginx-1.2.8]#测试下

测试配置文件和重新加载配置文件
[root@duwensql nginx-1.2.8]# /server/nginx-1.2.8/sbin/nginx -t nginx: the configuration file /server/nginx-1.2.8/conf/nginx.conf syntax is ok nginx: configuration file /server/nginx-1.2.8/conf/nginx.conf test is successful [root@duwensql nginx-1.2.8]# /server/nginx-1.2.8/sbin/nginx -s reload来安装PHP
给PHP添加扩展模块:libmcrypt-2.5.8.tar.gz
1、 让 PHP 编译支持这个功能
2、 生成扩展模块
3、 --with-mcrypt=/usr/local/
安装libmcrypt库
[root@duwensql ~]# tar -zxf libmcrypt-2.5.8.tar.gz [root@duwensql ~]# cd libmcrypt-2.5.8 [root@duwensql libmcrypt-2.5.8]# ./configure --prefix=/usr/local/ [root@duwensql libmcrypt-2.5.8]# echo $? 0 [root@duwensql libmcrypt-2.5.8]# make -j 4 && make install加个环境
[root@duwensql libmcrypt-2.5.8]# yum -y install php-pear解压以及编译
//在这一步出了好多好多错误,始料不及啊,本文把错误和解决贴上,如果还是不明白的话可以直接搜索错误,这里就不写了
[root@duwensql ~]# tar jxf php-5.4.14.tar.bz2 -C /usr/local/src/ [root@duwensql ~]# cd /usr/local/src/php-5.4.14/ [root@duwensql php-5.4.14]# ./configure --prefix=/server/php-5.4-nginx --with-config-file-path=/server/php-5.4-nginx --with-mysql=/server-5.5/ --with-mysqli=/server/mysql-5.5/bin/mysql_config --with-iconv-dir --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers --enable-mbregex --enable-fpm --enable-mbstring --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --with-mcrypt=/usr/local/报错1
####### configure: error: xml2-config not found. Please check your libxml2 installation. [root@duwensql php-5.4.14]#解决1
[root@duwensql php-5.4.14]# yum -y install libxml2*重新编译
[root@duwensql php-5.4.14]# ./configure --prefix=/server/php-5.4-nginx --with-config-file-path=/server/php-5.4-nginx --with-mysql=/server/mysql-5.5/ --with-mysqli=/server/mysql-5.5/bin/mysql_config --with-iconv-dir --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers --enable-mbregex --enable-fpm --enable-mbstring --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --with-mcrypt=/usr/local/报错2
checking if we should use cURL for url streams... yes checking for cURL in default path... not found configure: error: Please reinstall the libcurl distribution - easy.h should be in解决2:
[root@duwensql php-5.4.14]# yum -y install curl-devel重新编译
[root@duwensql php-5.4.14]#./configure --prefix=/server/php-5.4-nginx --with-config-file-path=/server/php-5.4-nginx --with-mysql=/server/mysql-5.5/ --with-mysqli=/server/mysql-5.5/bin/mysql_config --with-iconv-dir --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers --enable-mbregex --enable-fpm --enable-mbstring --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --with-mcrypt=/usr/local/报错3
checking whether to enable JIS-mapped Japanese font support in GD... no checking for fabsf... yes checking for floorf... yes configure: error: jpeglib.h not found解决3:*不要丢了
[root@duwensql php-5.4.14]# yum -y install libjpeg*再次编译
[root@duwensql php-5.4.14]./configure --prefix=/server/php-5.4-nginx --with-config-file-path=/server/php-5.4-nginx --with-mysql=/server/mysql-5.5/ --with-mysqli=/server/mysql-5.5/bin/mysql_config --with-iconv-dir --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers --enable-mbregex --enable-fpm --enable-mbstring --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --with-mcrypt=/usr/local/报错4:
checking for jpeg_read_header in -ljpeg... yes If configure fails try --with-vpx-dir=解决4:*不要丢了
[root@duwensql php-5.4.14]# yum -y install libpng*再次编译
[root@duwensql php-5.4.14]#./configure --prefix=/server/php-5.4-nginx --with-config-file-path=/server/php-5.4-nginx --with-mysql=/server/mysql-5.5/ --with-mysqli=/server/mysql-5.5/bin/mysql_config --with-iconv-dir --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers --enable-mbregex --enable-fpm --enable-mbstring --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --with-mcrypt=/usr/local/报错5:
configure: error: freetype.h not found.解决5:*不要丢掉了
[root@duwensql php-5.4.14]# yum -y install freetype*再次编译
[root@duwensql php-5.4.14]#./configure --prefix=/server/php-5.4-nginx --with-config-file-path=/server/php-5.4-nginx --with-mysql=/server/mysql-5.5/ --with-mysqli=/server/mysql-5.5/bin/mysql_config --with-iconv-dir --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers --enable-mbregex --enable-fpm --enable-mbstring --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --with-mcrypt=/usr/local/报错6:
checking for specified location of the MySQL UNIX socket... no configure: error: Cannot find MySQL header files under /server-5.5/. Note that the MySQL client library is not bundled anymore!这个应该是指定路径错误,改下
再次编译
[root@duwensql php-5.4.14]#./configure --prefix=/server/php-5.4-nginx --with-config-file-path=/server/php-5.4-nginx --with-mysql=/server/mysql-5.5/ --with-mysqli=/server/mysql-5.5/bin/mysql_config --with-iconv-dir --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers --enable-mbregex --enable-fpm --enable-mbstring --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --with-mcrypt=/usr/local/报错7:
configure: error: wrong mysql library version or lib not found. Check config.log for more information.解决7:
“=/server/mysql-5.5/bin/mysql_config”删掉试试
改好以后的执行:
[root@duwensql php-5.4.14]# ./configure --prefix=/server/php-5.4-nginx --with-config-file-path=/server/php-5.4-nginx --with-mysql=/server/mysql-5.5/ --with-mysqli --with-iconv-dir --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers --enable-mbregex --enable-fpm --enable-mbstring --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --with-mcrypt=/usr/local/历经千辛万苦啊

这里贴上一些参数的意思
--with-iconv-dir #字符集转换 需要的扩展模块
–without-iconv 关闭 iconv 函数,种字符集间的转换
–with-freetype-dir 打开对 freetype 字体库的支持
–with-jpeg-dir 打开对 jpeg 图片的支持
–with-png-dir 打开对 png 图片的支持
–with-libxml-dir 打开 libxml2 库的支持
–disable-rpath 关闭额外的运行库文件
–enable-bcmath 打开图片大小调整,用到 zabbix 监控的时候用到了这个模块
下面 是make && make install
[root@duwensql php-5.4.14]# make -j 4 && make install生成配置文件
[root@duwensql ~]# cp /usr/local/src/php-5.4.14/php.ini-production /server/php-5.4-nginx/php.ini生成php-fpm配置文件
[root@duwensql ~]# cp /server/php-5.4-nginx/etc/php-fpm.conf.default /server/php-5.4-nginx/etc/php-fpm.conf生成php-fpm启动脚本
[root@duwensql ~]# cp /usr/local/src/php-5.4.14/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm [root@duwensql ~]# chmod +x /etc/init.d/php-fpm [root@duwensql ~]# /etc/init.d/php-fpm start Starting php-fpm done [root@duwensql ~]# netstat -anptu | grep 9000 tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 76616/php-fpm [root@duwensql ~]#测试php
[root@duwensql ~]# vim /server/nginx-1.2.8/html/a.php [root@duwensql ~]# cat /server/nginx-1.2.8/html/a.php [root@duwensql ~]#效果图如下

The End!
另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。