一.准备工作
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. 绿盟扫出来个http host 漏洞

    这个漏洞搞了大半天,想过从后台拦截,也想过从前台拦截,都是无从下手!网上也找了很多资料,有点乱,后来自己结合网上的办法,搞出如下解决办法:在tomcat server.xml里配置host 因为外网是 ...

  2. input只读效果

    有两种方式可以实现input的只读效果:disabled 和 readonly. 自然两种出来的效果都是只能读取不能编辑,可是两者有很大不同. Disabled说明该input无效,及其value不会 ...

  3. sourcetree配置gitlab

    一.准备 1.安装git,下载地址:https://git-scm.com/download 安装教程百度一下      git客户端(1.产生gitlab服务端和本地git相互传输时所需要校验的私钥 ...

  4. CentOS 7.3 环境配置java和tomcat开机启动

    Centos7下添加开机自启动服务和脚本  https://blog.csdn.net/GMingZhou/article/details/78677953 安装部分参考我的博文,仅参考他的开机启动部 ...

  5. Dubbox管理中心的部署及使用

    安装: 我们在开发时,需要知道注册中心都注册了哪些服务,以便我们开发和测试.我们可以通过部署一个管理中心来实现.其实管理中心就是一个web应用,部署到tomcat即可. (1)编译源码,得到war包 ...

  6. Java集合框架的基础接口有哪些?

    Collection为集合层级的根接口.一个集合代表一组对象,这些对象即为它的元素.Java平台不提供这个接口任何直接的实现. Set是一个不能包含重复元素的集合.这个接口对数学集合抽象进行建模,被用 ...

  7. Linux中的系统服务_02

    Linux中的系统服务_02 1. 在linux增加服务后,如果要实现随着操作系统的启动而启动,需要是用chkconfig命令,加入到系统服务中. 但是对于的脚本的表头,需要增加如下内容 #!/bin ...

  8. fiddler 4 抓取 https 设置

    Fiddler抓取https 设置 1.打开fiddler,点击工具栏中的Tools—>Options,点击Actions,选择最后一项,Reset All certificates,然后关闭, ...

  9. Java 的内置对象

    1.Request对象 该对象封装了用户提交的信息,通过调用该对象相应的方法可以获取封装的信息,即使用该对象可以获取用户提交的信息.    当Request对象获取客户提交的汉字字符时,会出现乱码问题 ...

  10. MOSFET学习

    MOS/CMOS集成电路简介及N沟道MOS管和P沟道MOS管 在实际项目中,我们基本都用增强型mos管,分为N沟道和P沟道两种. 我们常用的是NMOS,因为其导通电阻小,且容易制造.在MOS管原理图上 ...