一.准备工作
1、配置本地YUM源
2、关闭selinux以及iptables
service iptables stop
chkconfig iptables off
setenforce 0

vim /etc/selinux/config
修改为: SELINUX=disabled

3、卸载系统RPM包安装的Apahce,Mysql服务
rpm -e --nodeps mysqld
rpm -e --nodeps httpd
4、关闭一些不必要的自启动:可参考excl表格
5、拷贝源码包到本地
yum -y install lrzsz
拖拽 iso 文件到 xshell
创建挂载目录以及工作目录:
mkdir /iso /soft
挂载镜像到 /iso 目录:
mount –o loop lamp.iso /iso
6、挂载点下的文件直接解压不了,需要复制到其他位置进行解压(多而且繁琐)
cp -a /iso/* /soft/
6.1或者用脚本解压:
bash /iso/jieya.sh /iso /soft
二.源码编译安装
1.安装编译环境
yum –y install gcc*
2.安装libxml2
yum -y install libxml2-devel python-devel
cd /soft/libxml2-2.9.1
./configure --prefix=/usr/local/libxml2 && make && make install
3.安装libmcryp
libmcrypt是加密算法扩展库。支持DES, 3DES, RIJNDAEL, Twofish, IDEA, GOST, CAST-256, ARCFOUR, SERPENT, SAFER+等算法。
cd /soft/libmcrypt-2.5.8
./configure --prefix=/usr/local/libmcrypt && make && make install
4.安装libltdl,也在libmcrypt源码目录中,非新软件
cd /soft/libmcrypt-2.5.8/libltdl
./configure --enable-ltdl-install && make && make install
5.安装mhash
Mhash是基于离散数学原理的不可逆向的php加密方式扩展库,其在默认情况下不开启。mhash的可以用于创建校验数值,消息摘要,
消息认证码,以及无需原文的关键信息保存(如密码)等。
cd /sort/mhash-0.9.9.9
./configure && make && make install
6.安装mcrypt
mcrypt 是 php 里面重要的加密支持扩展库。Mcrypt库支持20多种加密算法和8种加密模式
cd /soft/mcrypt-2.6.8/
LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib ./configure --with-libmcrypt-prefix=/usr/local/libmcrypt && make && make install
7.安装zlib库
zlib是提供数据压缩用的函式库,由Jean-loup Gailly与Mark Adler所开发,初版0.9版在1995年5月1日发表。zlib使用DEFLATE算法,最初
是为libpng函式库所写的,后来普遍为许多软件所使用。此函式库为自由软件,使用zlib授权
cd /soft/zlib-1.2.3/
./configure
vi Makefile
找到CFLAGS=-O3 -DUSE_MMAP 在后面加入 –fPIC变成 CFLAGS=-O3 –DUSE_MMAP -fPIC
make && make install
8.安装libpng
libpng 软件包包含 libpng 库.这些库被其他程式用于解码png图片
cd /soft/libpng-1.2.31
./configure --prefix=/usr/local/libpng && make && make install
9.安装jpeg6
用于解码.jpg和.jpeg图片
yum -y install libtool*
mkdir /usr/local/jpeg6
mkdir /usr/local/jpeg6/bin
mkdir /usr/local/jpeg6/lib
mkdir /usr/local/jpeg6/include
mkdir -p /usr/local/jpeg6/man/man1
cd /soft/jpeg-6b
cp /usr/share/libtool/config/config.sub .
cp /usr/share/libtool/config/config.guess .
./configure --prefix=/usr/local/jpeg6/ --enable-shared --enable-static && make && make
* --enable-shared与--enable-static参数分别为建立共享库和静态库使用的libtool
10.安装freetype
cd /soft/freetype-2.3.5
./configure --prefix=/usr/local/freetype/ && make && make install
11.安装apache
cd /soft/pcre-8.34
./configure && make && make install
cp -r /soft/apr-1.4.6 /soft/httpd-2.4.7/srclib/apr
cp -r /soft/apr-util-1.4.1 /soft/httpd-2.4.7/srclib/apr-util
cd /soft/httpd-2.4.7
./configure --prefix=/usr/local/apache2/ --sysconfdir=/usr/local/apache2/etc/ --with-included-apr --enable-so --enable- deflate=shared --enable-expires=shared --enable-rewrite=shared && make && make install
启动 Apache 服务:/usr/local/apache2/bin/apachectl start
测试 Apache 服务是否开启:netstat –tlun | grep :80
设置Apache系统引导时启动:echo "/usr/local/apache2/bin/apachectl start" >> /etc/rc.local
12.安装ncurses
Ncurses提供字符终端处理库,包括面板和菜单。它提供了一套控制光标,建立窗口,改变前景背景颜色以及处理鼠标操作的函数。
使用户在字符终端下编写应用程序时绕过了那些恼人的底层机制。简而言之,他是一个可以使应用程序直接控制终端屏幕显示的函数库。
yum -y install ncurses-devel
cd /soft/ncurses-5.9
./configure --with-shared --without-debug --without-ada --enable-overwrite && make && make install
* 若不安装ncurses编译MySQL时会报错* --without-ada参数为设定不编译为ada绑定,因进入chroot环境不能使用ada ;--enable- overwrite参数为定义把头文件安装到/tools/include下而不是/tools/include/ncurses目录* --with-shared 生成共享库
13.安装cmake&bison
mysql在5.5以后,不再使用./configure工具,进行编译安装。而使用cmake工具替代./configure工具。cmake的具体用法参考文档cmake说明。 bison是一个自由软件,用于自动生成语法分析器程序,可用于所有常见的操作系统
yum -y install cmake
yum -y install bison
14.安装mysql
useradd -M -s /sbin/nologin mysql
* 添加用户组mysql ,将mysql用户默认组设置为mysql用户组
cd /soft/mysql-5.5.48
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 && make && make install

-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端口

cd /usr/local/mysql/
chown -R root .
chown -R mysql data
*修改 MySQL 目录权限
cp support-files/my-medium.cnf /etc/my.cnf
*复制mysql配置文件
/usr/local/mysql/scripts/mysql_install_db --user=mysql
*创建数据库授权表,初始化数据库
/usr/local/mysql/bin/mysqld_safe --user=mysql &
*启动 MySQL 服务
echo "/usr/local/mysql/bin/mysqld_safe --user=mysql &" >> /etc/rc.local
*设置开机自启动 MySQL
/usr/local/mysql/bin/mysqladmin -uroot password 123
*设定 MySQL 初始密码,给 MySQL 用户 root 加密码 123
测试 MySQL数据库能否使用:/usr/local/mysql/bin/mysql-uroot-p
mysql>show databases;
15.安装php
yum -y install libtool*
cd /soft/php-7.0.7
./configure --prefix=/usr/local/php/ --with-config-file-path=/usr/local/php/etc/ --with-apxs2=/usr/local/apache2/bin/apxs --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-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 --with-gd --without-pear && make && make install

--with-config-file-path=/usr/local/php/etc/ 指定配置文件目录
--with-apxs2=/usr/local/apache2/bin/apxs 指定apache动态模块位置
--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-mcrypt=/usr/local/libmcrypt/ 指定libmcrypt位置
--with-mysqli=/usr/local/mysql/bin/mysql_config 指定mysqli位置
--with-gd 启用gd库
--enable-soap 支持soap服务
--enable-mbstring=all 支持多字节,字符串
--enable-sockets 支持套接字
--with-pdo-mysql=/usr/local/mysql 启用mysql的pdo模块支持
--without-pear 不安装pear(安装pear需要连接互联网,PEAR是PHP扩展与应用库)

mkdir /usr/local/php/etc/
cp /soft/php-7.0.7/php.ini-production /usr/local/php/etc/php.ini

链接 Apache 与 PHP:
vim /usr/local/apache2/etc/httpd.conf
AddType application/x-httpd-php .php .phtml
AddType application/x-httpd-php-source .phps
*在配置文件中添加, .phtml为将.phps做为PHP源文件进行语法高亮显示

拷贝 PHP 脚本到 /usr/local/apache2/htdocs/ 留做测试: cp /iso/php/* /usr/local/apache2/htdocs/

测试 Apache 是否解析 PHP ,浏览器访问测试 http://本机 IP/php-test.php
测试 PHP 连接 MySQL: http://本机ip/mysql-test.php
16.安装openssl
OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用
程序供测试或其它目的使用。
yum -y install openssl-devel
cd /soft/php-7.0.7/ext/openssl
mv config0.m4 config.m4
/usr/local/php/bin/phpize
./configure --with-openssl --with-php-config=/usr/local/php/bin/php-config && make && make install
17.编译安装memcache
cd /soft/pecl-memcache-php7
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config && make && make install
vim /usr/local/php/etc/php.ini
extension_dir = "/usr/local/php/lib/php/extensions/no-debug-zts-20151012/"
*打开注释并修改
extension="openssl.so";
extension="memcache.so";
#在区域内添加

测试:
重启 apache 服务器,可以访问网页 phpinfo 函数,在页面中找到 memcache

安装 memcache 源代码
useradd -M -s /sbin/nologin memcache
yum -y install /iso/libevent/*
cd /soft/memcached-1.4.17
./configure --prefix=/usr/local/memcache && make && make install

启动服务,查看是否开启
/usr/local/memcache/bin/memcached -umemcache & netstat -an | grep :11211
写入自启动
echo "/usr/local/memcache/bin/memcached -umemcache &" >> /etc/rc.local

测试 memcache 是否工作 memcache.php http://本机ip/memcache.php
memcache.php文件注意修改路径和密码

lamp搭建的更多相关文章

  1. 买错的电影票,含着泪也得看-LAMP搭建&Linux基础

    hi 没说过,上周五室友过生请客,在龙湖里吃嗨了喝爽了,回去的路上侃侃而谈.说好的这周一起去看年内最后的大片,火星救援的,谁知道老子眼神不好,买错了电影的时间...把周六的约定提前到了今儿个下午,ma ...

  2. (原创)LAMP搭建之二:apache配置文件详解(中英文对照版)

    LAMP搭建之二:apache配置文件详解(中英文对照版) # This is the main Apache server configuration file. It contains the # ...

  3. (原创)LAMP搭建之一:图解如何安装并检查LAMP

    LAMP搭建之一:图解如何安装并检查LAMP 第一步:安装Linux(RedHat5) 第二步:rpm -qa httpd(查看apache是否安装) rpm -qa php(查看php是否安装) r ...

  4. LAMP 搭建wordpress部署教程贴.

    LAMP 搭建wordpress部署教程贴.这是一篇主要将LAMP,并且通过wordpress来进行验证,演示.如何去部署PHP CMS很多新手看到LAMP就很很头大,觉得很难搞,编译安装,搞了好几天 ...

  5. Ubuntu 14.04 LAMP搭建(Apache 2.47+MySQL 5.5+PHP5.5)

    原文:Ubuntu LAMP搭建 为了数据库课程设计,只好自己搭一个数据库系统,采用LAMP方式. 一.安装 1.安装Apache sudo apt-get install apache2 Apach ...

  6. LVS之-LAMP搭建wordpress

    author:JevonWei 版权声明:原创作品 LVS搭建wordpress,涉及的知识点有DNS,LAMP,NFS及LVS 网络拓扑图 网络环境 NFS 192.168.198.130 mysq ...

  7. LAMP 搭建

    p { margin-bottom: 0.25cm; line-height: 120% } LAMP 搭建 承 Ubuntu 17.10.1安装, 定制. 参考 电子工业出版社, Ubuntu完美应 ...

  8. Linux:LAMP搭建DISCU!论坛

    LAMP搭建DISCU!论坛 试验机为centos6.8 i686 应用的包 mysql-5.1.73-linux-i686-glibc23.tar.gz httpd-2.2.24.tar.bz2 p ...

  9. 生产环境LAMP搭建 - 基于 fastcgi

    生产环境LAMP搭建 - 基于 fastcgi 由于在module模式,php只是已http的模块形式存在,无形中加重了http的服务负载,通常在企业架构中,使用fastcgi的模式,将所有的服务都设 ...

  10. LAMP 搭建练习

    目录 LAMP 搭建 1:CentOS 7, lamp (module): http + php + phpMyAdmin + wordpress 192.168.1.7 配置虚拟主机 xcache ...

随机推荐

  1. Windows开发,关于通过写代码加载PDB的那些事

    最近,接到一个活,要写一个程序,用来批量分析一堆dll和对应的PDB, 其实工作很简单,就是根据一堆偏移,通过PDB文件,找到对应dll里面对应位置的明文符号, 简单的需求,实现起来,通常都很麻烦, ...

  2. BUUCTF CRYPTO部分题目wp

    对密码学了解不多,做一下熟悉熟悉 1,看我回旋踢 给的密文synt{5pq1004q-86n5-46q8-o720-oro5on0417r1} 简单的凯撒密码,用http://www.zjslove. ...

  3. gulp构建前端,压缩css,js文件,实现浏览器自动刷新

    一.安装node nodejs下载地址:https://nodejs.org/ nodejs自带npm模块管理器,安装完成之后打开dos命令窗口输入 node -v就能查看nodejs是否安装成成功 ...

  4. shells - 有效登录 shell 的路径名

    描述 /etc/shells 是一个文本文件,其中包含有效登录 shell 的路径全名. chsh(1) 需要参考这个文件,并且其他程序也可以查询该文件.有些程序从这个文件判断用户是不是标准用户.比如 ...

  5. go语言从例子开始之Example19.接口

    接口 是方法特征的命名集合. Example: package main import "fmt" //让方法,实现api这个接口. type api interface{ get ...

  6. mysql---级联更新和删除操作

    我们通常有这样的需求:删除表Table 1中记录,需要同时删除其它表中与Table 1有关的若干记录. 对于这种,我们有两种解决方法: 一,使用innodb表的外键约束 ALTER TABLE `sc ...

  7. IE历史纪录

    signed int __cdecl sub_475790(_BYTE *a1) { signed int result; // eax DWORD v2; // [esp+10h] [ebp-10h ...

  8. mybatis generator 生成的example类的使用方法

    generator 生成的example类 示例 1. 搜索数据库Id不为空打元组 java代码 @RequestMapping("/test") public String ex ...

  9. 数据结构---Java---Hastable

    1.概述 1.1 Hashtable是线程安全的: 1.2 源码 public class Hashtable<K,V> extends Dictionary<K,V> imp ...

  10. spring框架的一些测试思路

    一.Spring Boot Actuators Spring Boot Actuator是Spring Boot提供的对应用系统的监控和管理的集成功能,可以查看应用配置的详细信息,例如自动化配置信息. ...