[关闭]
@52fhy 2015-12-04T20:29:08.000000Z 字数 11247 阅读 352

第六天 环境搭建

Linux


一、准备工作

 
1、安装编译工具gcc、gcc-c++
 注意解决依赖关系,推荐使用yum安装,若不能联网可使用安装光盘做为yum源:
1)编辑yum配置文件:

  1. # mount /dev/cdrom /mnt/cdrom
  2. # vi /etc/yum.repos.d/CentOS-Media.repo
  3.   [c5-media]
  4.   name=CentOS-$releasever - Media
  5.   baseurl=file:///mnt/cdrom * 修改为光盘挂载点
  6.   file:///media/cdrom/
  7.   file:///media/cdrecorder/
  8.   gpgcheck=1
  9.   enabled=1 * 改为1意为启用
  10.   gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-5

2)剪切/etc/yum.repos.d/CentOS-Base.repo

  1. # mv /etc/yum.repos.d/CentOS-Base.repo /backup

3)依次安装gcc、gcc-c++

  1. # yum -y install gcc
  2. # yum -y install gcc-c++

2、关闭系统RPM安装包的Apache、MySQL的服务
 关闭启动的服务httpd、mysqld

  1. # service httpd stop
  2. # service mysqld stop

确定rpm包安装的httpd和mysqld不能开机自启动

  1. chkconfig --level 2345 httpd off
  2. chkconfig --level 2345 mysqld off

或者卸载掉:

  1. rpm -e http
  2. rpm -e mysql

3、关闭SELinux,允许防火墙80端口访问
使用setup
关闭防火墙和SElinux

1)关闭SELinux

  1. # vi /etc/selinux/config
  1. SELINUX=disabled #若安装时没有禁用SELinux

将enforcing改为disabled
修改后需重新启动Linux方可生效!

2)关闭防火墙Netfilter/iptables
因尚未做防火墙讲解,直接简单的关闭所有防火墙设置:

  1. iptables -F * 如果没有禁用防火墙,默认80端口禁止访问
  2. iptables -Z
  3. iptables -X

4、关闭不必要自启动服务

5、拷贝源码包,解包解压缩
建议将LAMP环境安装源码包统一存放在一个目录下,如/lamp
可编写个批量处理脚本,一次性把所有.tar.gz的安装包解包解压缩

  1. # vi tar.sh
  2. #!/bin/bash
  3. cd /lamp
  4.   /bin/ls *.tar.gz > ls.list
  5.   /bin/ls *.tgz >> ls.list
  6. for TAR in `cat ls.list`
  7.    do
  8. /bin/tar -zxf $TAR
  9.    done
  10.   /bin/rm ls.list

6、查看确认磁盘空间未满

  1. df -h

/分区已满,可以移动安装包到其他分区或删除其他无用文件

如何确定报错:
1)安装过程停止
2)停止后,一页界面中出现error或者warning

如何确定安装成功:
进入安装目录,确认安装程序出现,就是成功

二、编译安装

每个源码包配置编译安装完成后,确认安装目录下是否生成安装文件

  1. make clean

Libxml2 是一个xml c语言版的解析器,本来是为Gnome项目开发的工具,是一个基于MIT License的免费开源软件。它除了支持c语言版以外,还支持c++、PHP、Pascal、Ruby、Tcl等语言的绑定,能在Windows、Linux、Solaris、MacOsX等平台上运行。功能还是相当强大的,相信满足一般用户需求没有任何问题。

libxml是一个用来解析XML文档的函数库。它用C语言写成, 并且能为多种语言所调用,例如C语言,C++,XSH。C#, Python,Kylix/Delphi,Ruby,和PHP等。Perl中也可以使用XML::LibXML模块。它最初是为GNOME开发的项目,但现在可以用在各种各样的方面。libXML 代码可移植性非常好,因为它基于标准的ANSI C库, 并采用MIT许可证。

  1. yum install -y libxml2-devel #如果报错,安装此包后再尝试安装
  2. yum -y install python-devel #必须有
  3. cd /lamp/libxml2-2.9.1
  4. ./configure --prefix=/usr/local/libxml2/
  5. make
  6. make install

libmcrypt是加密算法扩展库。支持DES, 3DES, RIJNDAEL, Twofish, IDEA, GOST, CAST-256, ARCFOUR, SERPENT, SAFER+等算法。

  1. cd /lamp/libmcrypt-2.5.8
  2. ./configure --prefix=/usr/local/libmcrypt/
  3. make
  4. make install

需调用gcc-c++编译器,未安装会报错

  1. cd /lamp/libmcrypt-2.5.8/libltdl
  2. ./configure --enable-ltdl-install
  3. make
  4. make install
  1. cd /lamp/mhash-0.9.9.9
  2. ./configure
  3. make
  4. make install

mcrypt 是 php 里面重要的加密支持扩展库。Mcrypt库支持20多种加密算法和8种加密模式。

  1. cd /lamp/mcrypt-2.6.8
  2. LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib \
  3. ./configure --with-libmcrypt-prefix=/usr/local/libmcrypt
  4. #以上为一条命令。LD_LIBRARY_PATH用于指定libmcrypt和mhash的库的位置。
  5. --with-libmcrypt-prefix用于指定libmcrypt软件位置
  6. make
  7. make install

注意:mcrypt没有安装完成,这是php的模块,需要等php安装完成之后,再继续安装

zlib是提供数据压缩用的函式库,由Jean-loup Gailly与Mark Adler所开发,初版0.9版在1995年5月1日发表。zlib使用DEFLATE算法,最初是为libpng函式库所写的,后来普遍为许多软件所使用。此函式库为自由软件,使用zlib授权。

  1. cd /lamp/zlib-1.2.3
  2.  ./configure
  3. make
  4. make install >> /root/zlib.log

zlib指定安装目录可能造成libpng安装失败,故不指定,为卸载方便,建议make install执行结果输出到安装日志文件,便于日后卸载。

libpng 软件包包含 libpng 库.这些库被其他程式用于解码png图片

  1. cd /lamp/libpng-1.2.31
  2. ./configure --prefix=/usr/local/libpng
  3. make
  4. make install

用于解码.jpg和.jpeg图片

  1. mkdir /usr/local/jpeg6
  2. mkdir /usr/local/jpeg6/bin
  3. mkdir /usr/local/jpeg6/lib
  4. mkdir /usr/local/jpeg6/include
  5. mkdir -p /usr/local/jpeg6/man/man1
  6. #目录必须手工建立
  7. cd /lamp/jpeg-6b
  8. ./configure --prefix=/usr/local/jpeg6/ --enable-shared --enable-static
  9. make
  10. make install

--enable-shared--enable-static参数分别为建立共享库和静态库使用的libtool。

FreeType库是一个完全免费(开源)的、高质量的且可移植的字体引擎,它提供统一的接口来访问多种字体格式文件,包括TrueType, OpenType, Type1, CID, CFF, Windows FON/FNT, X11 PCF等。支持单色位图、反走样位图的渲染。FreeType库是高度模块化的程序库,虽然它是使用ANSI C开发,但是采用面向对象的思想,因此,FreeType的用户可以灵活地对它进行裁剪。

  1. cd /lamp/freetype-2.3.5
  2. ./configure --prefix=/usr/local/freetype/
  3. make
  4. make install
  1. mkdir /usr/local/gd2
  2. cd /lamp/gd-2.0.35

png错误,修改方法:

  1. vi gd_png.c

#include "png.h"替换为 #include "/usr/local/libpng/include/png.h"

  1. ./configure --prefix=/usr/local/gd2/ --with-jpeg=/usr/local/jpeg6/ --with-freetype=/usr/local/freetype/ --with-png=/usr/local/libpng/
  2. make
  3. make install

若前面配置zlib时没有指定安装目录,gd配置时不要添加--with-zlib=/usr/local/zlib/参数

  1. configure: error: Bundled APR requested but not found at ./srclib/. Download and unpack the corresponding apr and apr-util packages to ./srclib/.
  2.  #如果报错,则:
  3.  tar zxvf apr-1.4.6.tar.gz
  4.  tar zxvf apr-util-1.4.1.tar.gz
  5.  cp -r /lamp/apr-1.4.6 /lamp/httpd-2.4.7/srclib/apr
  6.  cp -r /lamp/apr-util-1.4.1 /lamp/httpd-2.4.7/srclib/apr-util
  7.  #解压apr和apr-util,复制并取消版本号
  8.  
  9. configure: error: pcre-config for libpcre not found. PCRE is required and available from
  10.  #如果报错,则:
  11.  tar zxvf pcre-8.34.tar.gz
  12.  cd pcre-8.34
  13.  ./configure && make && make install
  14.  
  15. checking whether to enable mod_ssl... configure: error: mod_ssl has been requested but can not be built due to prerequisite failures
  16.  #如果报错,则:
  17.  yum install openssl-devel

安装apache
--sysconfdir=/usr/local/apache2/etc/重新指定了apache的配置文件目录,如果不指定默认是/usr/local/apache2/conf/目录

  1. cd /lamp/httpd-2.4.7
  2. ./configure --prefix=/usr/local/apache2/ --sysconfdir=/usr/local/apache2/etc/ --with-included-apr --enable-so --enable-deflate=shared --enable-expires=shared --enable-rewrite=shared
  3. make
  4. make install

若前面配置zlib时没有指定安装目录,Apache配置时不要添加--with-z=/usr/local/zlib/参数

启动Apache测试:

  1. /usr/local/apache2/bin/apachectl start
  2. ps aux | grep httpd
  3. netstat tlun | grep :80

若启动时提示/usr/local/apache2/modules/mod_deflate.so无权限,可关闭SELinux或者执行命令chcon -t texrel_shlib_t /usr/local/apache2/modules/mod_deflate.so ,类似此类.so文件不能载入或没有权限的问题,都是SELinux问题,使用命令:chcon -t texrel_shlib_t 文件名即可解决,MySQL和Apache也可能有类似问题。

通过浏览器输入地址访问:http://Apache服务器地址,若显示“It works”即表明Apache正常工作

设置Apache系统引导时启动:

  1. echo "/usr/local/apache2/bin/apachectl start" >> /etc/rc.d/rc.local

Ncurses 提供字符终端处理库,包括面板和菜单。它提供了一套控制光标,建立窗口,改变前景背景颜色以及处理鼠标操作的函数。使用户在字符终端下编写应用程序时绕过了那些恼人的底层机制。简而言之,他是一个可以使应用程序直接控制终端屏幕显示的函数库。
1、yum安装

  1. yum -y install ncurses-devel

注:如果报错,包找不到,是*通配符没有识别,给文件名加双引号

  1. yum -y install ncurses-devel*

2、源代码编译:

  1. cd /lamp/ncurses-5.9
  2. ./configure --with-shared --without-debug --without-ada --enable-overwrite
  3. make
  4. make install

若不安装ncurses编译MySQL时会报错;
--without-ada参数为设定不编译为ada绑定,因进入chroot环境不能使用ada ;
--enable-overwrite参数为定义把头文件安装到/tools/include下而不是/tools/include/ncurses目录;
--with-shared生成共享库

  1. yum -y install cmake
  2. yum -y install bison
  1. groupadd mysql
  2. useradd -g mysql mysql

添加用户组mysql ,将mysql用户默认组设置为mysql用户组
 

  1. cd /lamp/mysql-5.5.23
  2. cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DENABLED_LOCAL_INFILE=1 -DMYSQL_USER=mysql -DMYSQL_TCP_PORT=3306

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql 安装位置
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock 指定socket(套接字)文件位置
-DEXTRA_CHARSETS=all 扩展字符支持
-DDEFAULT_CHARSET=utf8 默认字符集
-DDEFAULT_COLLATION=utf8_general_ci 默认字符校对
-DWITH_MYISAM_STORAGE_ENGINE=1 安装myisam存储引擎
-DWITH_INNOBASE_STORAGE_ENGINE=1 安装innodb存储引擎
-DWITH_MEMORY_STORAGE_ENGINE=1 安装memory存储引擎
-DWITH_READLINE=1 支持readline库
-DENABLED_LOCAL_INFILE=1 启用加载本地数据
-DMYSQL_USER=mysql 指定mysql运行用户
-DMYSQL_TCP_PORT=3306 指定mysql端口

  1. make
  2. make install
  3. make clean
  4. rm CMakeCache.txt #如果报错,清除缓存,请使用以上命令
  5.  
  6. cd /usr/local/mysql/
  7. chown -R mysql .
  8. chgrp -R mysql . #修改mysql目录权限
  9. /usr/local/mysql/scripts/mysql_install_db --user=mysql #创建数据库授权表,初始化数据库
  10. chown -R root .
  11. chown -R mysql data #修改mysql目录权限
  12. cp support-files/my-medium.cnf /etc/my.cnf #复制mysql配置文件

再执行一遍

  1. /usr/local/mysql/scripts/mysql_install_db --user=mysql

启动MySQL服务:
1.用原本源代码的方式去使用和启动mysql

  1. /usr/local/mysql/bin/mysqld_safe --user=mysql &

2.重启以后还要生效:

  1. vi /etc/rc.local
  2. /usr/local/mysql/bin/mysqld_safe --user=mysql &

为了避免每次都输出mysql相关信息,可以对输出重定向

  1. /usr/local/mysql/bin/mysqld_safe --user=mysql >/dev/null 2>&1 &

3.设定mysql密码

  1. /usr/local/mysql/bin/mysqladmin -uroot password 123

清空历史命令 history -c
给mysql用户root加密码123
注意密码不能写成 “123”

  1. /usr/local/mysql/bin/mysql -u root -p
  2.  mysql>show databases;
  3.  mysql>use test;
  4.  mysql>show tables;
  1. yum -y install libtool*
  2. yum -y install libtool-ltdl*
  1. vi /usr/local/gd2/include/gd_io.h
  2. typedef struct gdIOCtx
  3.  {
  4.   ……
  5.   void (*data);
  6.   #加入此句
  7.  }
  8.  #php 5.4 的bug,检测gd库有问题,需要手工修改
  1. cd /lamp/ php-5.4.25
  2. ./configure --prefix=/usr/local/php/ --with-config-file-path=/usr/local/php/etc/ --with-apxs2=/usr/local/apache2/bin/apxs --with-mysql=/usr/local/mysql/ --with-libxml-dir=/usr/local/libxml2/ --with-jpeg-dir=/usr/local/jpeg6/ --with-png-dir=/usr/local/libpng/ --with-freetype-dir=/usr/local/freetype/ --with-gd=/usr/local/gd2/ --with-mcrypt=/usr/local/libmcrypt/ --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-soap --enable-mbstring=all --enable-sockets --with-pdo-mysql=/usr/local/mysql --without-pear

若前面配置zlib时没有指定安装目录,PHP配置时不要添加--with-zlib-dir=/usr/local/zlib/参数
选项:
--with-config-file-path=/usr/local/php/etc/ 指定配置文件目录
--with-apxs2=/usr/local/apache2/bin/apxs 指定apache动态模块位置
--with-mysql=/usr/local/mysql/ 指定mysql位置
--with-libxml-dir=/usr/local/libxml2/ 指定libxml位置
--with-jpeg-dir=/usr/local/jpeg6/ 指定jpeg位置
--with-png-dir=/usr/local/libpng/ 指定libpng位置
--with-freetype-dir=/usr/local/freetype/ 指定freetype位置
--with-gd=/usr/local/gd2/ 指定gd位置
--with-mcrypt=/usr/local/libmcrypt/ 指定libmcrypt位置
--with-mysqli=/usr/local/mysql/bin/mysql_config 指定mysqli位置
--enable-soap 支持soap服务
--enable-mbstring=all 支持多字节,字符串
--enable-sockets 支持套接字
--without-pear 不安装pear(安装pear需要连接互联网。PEAR是PHP扩展与应用库)

  1. make
  2. make install

创建目录

  1. mkdir /usr/local/php/etc

生成php.ini

  1. cp /lamp/php-5.4.25/php.ini-production /usr/local/php/etc/php.ini

测试Apache与PHP的连通性,看Apache是否能解析php文件

  1. vi /usr/local/apache2/etc/httpd.conf
  2. AddType application/x-httpd-php .php .phtml .phps

(注意大小写)
.phtml为将.phps做为PHP源文件进行语法高亮显示
重启Apache服务:

  1. /usr/local/apache2/bin/apachectl stop
  2. /usr/local/apache2/bin/apachectl start

Apache无法启动,提示cadnnot restore segment prot after reloc: Permission denied错误,为SELinux问题,可关闭SELinux或者执行命令chcon -t texrel_shlib_t /usr/local/apache2/modules/libphp5.so

测试:

  1. vi /usr/local/apache2/htdocs/test.php
  1. <?php
  2. phpinfo();
  3.    ?>

通过浏览器输入地址访问:http://Apache服务器地址/test.php
Rpm包安装的网页默认目录 /var/www/html/
有时第一次浏览器测试会失败,关闭浏览器重启再尝试即可,非编译错误

Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

  1. yum -y install zlib-devel
  2. cd memcache-3.0.8
  3. /usr/local/php/bin/phpize
  4. ./configure --with-php-config=/usr/local/php/bin/php-config
  5. make && make install
  1. cd /lamp/php-5.4.25/ext/mcrypt/
  2. /usr/local/php/bin/phpize
  3. ./configure --with-php-config=/usr/local/php/bin/php-config --with-mcrypt=/usr/local/libmcrypt/
  4. make
  5. make install
  6. #php安装完成后,通过这些命令安装mcrypt模块

修改/usr/local/php/etc/php.ini

  1. extension_dir = "/usr/local/php/lib/php/extensions/no-debug-zts-20100525/"
  2. #打开注释,并修改
  3. extension="memcache.so";
  4. extension="mcrypt.so";
  5. #添加
  6. #重启apache,在phpinfo中可以找到这两个模块

首先安装依赖包libevent

  1. yum -y install libevent*”
  2. #在CentOS 6.3第二张光盘中,请换盘
  3. cd /lamp/memcached-1.4.17
  4. ./configure --prefix=/usr/local/memcache
  5. make && make install
  6. useradd memcache
  7. #添加memcache用户,此用户不用登录,不设置密码
  8. /usr/local/memcache/bin/memcached -umemcache &
  9. netstat -an | grep :11211
  10. telnet 192.168.10.1 11211
  11. stats

写入自启动:

  1. vi /etc/rc.d/rc.local
  2. /usr/local/memcache/bin/memcached -umemcache &
  1. cp -r phpMyAdmin-4.1.4-all-languages /usr/local/apache2/htdocs/phpmyadmin
  2. cd /usr/local/apache2/htdocs/phpmyadmin
  3. cp config.sample.inc.php config.inc.php
  4. vi config.inc.php
  5. $cfg['Servers'][$i]['auth_type'] = 'cookie';
  6. $cfg['Servers'][$i]['auth_type'] = 'http';

设置auth_type为http ,即设置为HTTP身份认证模式
通过浏览器输入地址访问:http://Apache服务器地址/phpmyadmin/index.php
用户名为root ,密码为MySQL设置时指定的root密码(lampbrother)

安装过程中大多错误其实为输入错误,可以通过history命令查看历史记录检查。

  1. GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123' WITH GRANT OPTION;

sql语句,不是linux命令

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注