源码包搭建LAMP环境

第一步

1、安装编译工具 gcc*

安装数据库编译工具  cmake   bison

yum -y install gcc* cmake  bison

2、下载LAMP压缩包:lamp.zip ,使用脚本批量解压 tar.sh

3、关闭防火墙、Selinux

第二步

分别编译安装各个源码包(共有17个包)

1、可以直接安装的源码包

2.1、 # 安装libxml2

先安装   yum -yinstall python-devel

mkdir /usr/local/libxml2/

cd /lamp/libxml2-2.9.1

./configure--prefix=/usr/local/libxml2/ && make&& make install

2.2、# 安装libmcrypt

mkdir /usr/local/libmcrypt/

cd /lamp/libmcrypt-2.5.8

./configure --prefix=/usr/local/libmcrypt/  && make &&   make install

2.3、# 安装libltdl

也在libmcrypt源码目录中

cd/lamp/libmcrypt-2.5.8/libltdl

./configure--enable-ltdl-install  &&  make && make install

2.4、# 安装 mhash

cd /lamp/mhash-0.9.9.9

./configure   && make &&  make install

2.5、# 安装mcrypt

cd/lamp/mcrypt-2.6.8

LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib ./configure

--with-libmcrypt-prefix=/usr/local/libmcrypt

make &&   make install

2.6、# 安装zlib

cd  /lamp/zlib-1.2.3

./configure

vi Makefile

将 CFLAGS=-O3 -DUSE_MMAP

修改为CFLAGS=-O3 –DUSE_MMAP –fPIC

make&&  make install

2.7、# 安装libpng

mkdir /usr/local/libpng/

cd /lamp/libpng-1.2.31

./configure--prefix=/usr/local/libpng/ && make&& make install

2.8、# 安装jpeg6

必须先安装   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 /lamp/jpeg-6b

cp /usr/share/libtool/config/config.sub     .

cp /usr/share/libtool/config/config.guess

#复制libtool中的文件,覆盖jpeg-6b中的文件(64位中的问题,32位没有此报错)

cd /lamp/jpeg-6b

./configure--prefix=/usr/local/jpeg6/ --enable-shared --enable-static

make &&make install

2.9、 # 安装freetype

cd/lamp/freetype-2.3.5

./configure--prefix=/usr/local/freetype/ && make && make install

2.10、# 安装ncurses

yum -y install ncurses-devel

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

cd/lamp/ncurses-5.9

./configure--with-shared --without-debug --without-ada --enable-overwrite

make &&  make install

2、重量级源码包

2.11、# 安装Apache

configure: error: Bundled APR requested but not found at ./srclib/.Download and unpack the corresponding apr and apr-util packages to ./srclib/.

#如果报错,则:

tar  zxvf  apr-1.4.6.tar.gz

tar  zxvf apr-util-1.4.1.tar.gz  解压过

cp  -r  /lamp/apr-1.4.6 /lamp/httpd-2.4.7/srclib/apr

cp  -r  /lamp/apr-util-1.4.1 /lamp/httpd-2.4.7/srclib/apr-util

#解压apr和apr-util,复制并取消版本号

configure: error: pcre-config for libpcre not found. PCRE isrequired and available from

#如果报错,则:

tar zxvf pcre-8.34.tar.gz

cd /lamp/pcre-8.34

./configure && make&& make install

checking whether to enablemod_ssl... configure: error: mod_ssl has been requested but can not be builtdue to prerequisite failures

#如果报错,则:

yum install openssl-devel

安装apache

cd /lamp/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

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

启动Apache测试:

/usr/local/apache2/bin/apachectlstart

ps  aux| grep httpd

netstat –antp | grep :80

可以使用脚本将apache像httpd一样启动

cat apache.sh

#!/bin/bash

#chkconfig管理apache服务

#chkconfig:- 82 15

#discription:

path=/usr/local/apache2/bin/apachectl

case $1 in

start)

$path start

;;

stop)

$path stop

;;

restart)

$path stop

sleep 3s

$path start

;;

configtest)

$path -t

;;

*)

echo"pleas input start |stop | restart |configtest ."

;;

esac

mv apache.sh  /etc/init.d/httpd

chmod 755 httpd

service  httpd start

* 若启动时提示/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系统引导时启动:开机自启动

echo "/usr/local/apache2/bin/apachectlstart" >> /etc/rc.d/rc.local

注:安装完成后,先启动apache进行服务验证,是否安装成功,并且主页是否可以访问。

注:发现启动服务报错:AH00558: httpd: Could not reliably determine the server‘s fullyqualified domain name, using localhost.localdomain. Set the ‘ServerName‘ directiveglobally to suppress this message

解决办法:打开主配置文件 /usr/local/apache/etc/httpd.conf

搜索ServerName     (约在200行左右)

修改为 ServerName localhost:80(并且去掉前面的#注释)

2.12、# 安装MySQL

useradd  -r -s /sbin/nologin  mysql

mkdir /usr/lo cal/mysql -p

* 创建系统用户mysql

cd /lamp/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

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

make

make install

makeclean

rmCMakeCache.txt

#如果报错,清除缓存,请使用以上命令

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

#创建数据库授权表,初始化数据库

启动MySQL服务:

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

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

2.重启以后还要生效:

vim /etc/rc.local

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

3.设定mysql密码

/usr/local/mysql/bin/mysqladmin -urootpassword 123456

清空历史命令  history -c

* 给mysql用户root加密码123

*  注意密码不能写成太简单,做实验随便

/usr/local/mysql/bin/mysql -u root -p

mysql>show databases;

mysql>use test;

mysql>show tables;

mysql>\s         #查看字符集是否改为utf8

* 进入mysql以后用set来改密码

mysql> exit

* 登录MySQL客户端控制台设置指定root密码

2.13、# 安装PHP

编译前确保系统已经安装了libtool和libtool-ltdl软件包,安装:

yum -yinstall "libtool*"

mkdir/usr/local/php/etc/ -p

cd/lamp/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

l  若前面配置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-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需要连接互联网。

make

make install

生成php.ini

cp /lamp/php-7.0.7/php.ini-production /usr/local/php/etc/php.ini

测试Apache与PHP的连通性,看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源文件进行语法高亮显示

重启Apache服务:/usr/local/apache2/bin/apachectl stop

/usr/local/apache2/bin/apachectl start

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

测试:vim /usr/local/apache2/htdocs/test.php

<?php

phpinfo();

?>

通过浏览器输入地址访问:http://Apache服务器地址/test.php

Rpm包安装的网页默认目录    /var/www/html/

* 有时第一次浏览器测试会失败,关闭浏览器重启再尝试即可,非编译错误

2.14、# 安装openssl

OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。

yum-y install openssl-devel   必须安装

cd/lamp/php-7.0.7/ext/openssl

mvconfig0.m4 config.m4                否则报错:找不到config.m4

PATH=$PATH:/usr/local/php/bin/(临时)  vi /etc/profile

cd/lamp/php-7.0.7/

./configure--with-openssl --with-php-config=/usr/local/php/bin/php-config

make

makeinstall

2.15、# 编译安装pecl

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

https://github.com/websupport-sk/pecl-memcache/archive/php7.zip

unzip  pecl-memcache-php7.zip

cd  pecl-memcache-php7

/usr/local/php/bin/phpize   这是一个命令 ,用于生成一个配置目录

./configure--with-php-config=/usr/local/php/bin/php-config

make && make install

修改/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中可以找到这个模块

2.16、#安装memcache源代码

首先安装依赖包libevent

yum -yinstall  libevent-devel

#在CentOS 6.3第二张光盘中,请换盘

umount/mnt/cdrom

#放入CentOS 6.3第二张光盘

#mount/dev/sr0 /mnt/cdrom

mkdir /usr/local/memcache

cd/lamp/memcached-1.4.17

./configure--prefix=/usr/local/memcache

make && makeinstall

useradd memcache

#添加memcache用户,此用户不用登录,不设置密码

/usr/local/memcache/bin/memcached-umemcache &

netstat -an | grep:11211

写入自启动:

vi/etc/rc.d/rc.local

/usr/local/memcache/bin/memcached-umemcache &

第三步、项目迁移

1、把php项目拷贝到网站默认目录下:       /usr/local/apache2/htdocs/

2、手工建立数据库表结构

第四步、安装phpMyAdmin (给php管理添加用户)

cp -r /lamp/phpMyAdmin-4.1.4-all-languages/usr/local/apache2/htdocs/phpmyadmin

cd/usr/local/apache2/htdocs/phpmyadmin

cpconfig.sample.inc.php  config.inc.php

vim config.inc.php

$cfg[‘Servers‘][$i][‘auth_type‘]= ‘cookie‘;

$cfg[‘Servers‘][$i][‘auth_type‘]= ‘http‘;

以上两行都有

* 设置auth_type为http ,即设置为HTTP身份认证模式

通过浏览器输入地址访问:http://Apache服务器地址/phpmyadmin/index.php

用户名为root ,密码为MySQL设置时指定的root密码123456(lampbrother)

时间: 2024-08-15 13:09:33

源码包搭建LAMP环境的相关文章

源码包搭建lamp

lamp环境搭建 1.apahce安装 (1)安装相关的依赖包 [[email protected]~]#yum–y install gcc make openssl-devel c++ libxml2-devel (2).编译安装apahce [[email protected]]# tar -zxf httpd-2.2.25 [[email protected]]#cd httpd-2.2.25 [[email protected] src]# ./configure--prefix=/us

源码编译搭建LAMP环境&#160;

源码编译搭建LAMP环境  一.将 LAMP 相关软件包上传刡 linux 上 [[email protected] ~]# ls anaconda-ks.cfg      install.log         mysql-5.5.30.tar.gz  公共的  视频  文档  音乐 httpd-2.2.25.tar.gz  install.log.syslog  php-5.4.14.tar.bz2   模板    图片  下载  桌面 1. 安装apache [[email protect

CentOS7最小化安装下源码编译搭建LAMP环境

CentOS7最小化安装 CentOS7官网下载:http://www.centos.org 1.为了方便与主机交换文件建立共享文件夹:点击对话框顶部"选项",选择"共享文件夹",右侧点击"总是启用"点击"添加"按提示添加自己想要添加的目录,然后点击"确认",完成虚拟机设置. 2.按"Enter"建,选择"install CentOS 7".选择"中文 Ch

源码包搭建LNMP环境

1.将LNMP.ISO镜像文件下载到 /root 下 2.挂载光盘镜像,并将LNMP.ISO内容拷贝到 /soft 里面 mkdir  /soft mount  -o  loop LNMP.ISO  /media cd  /media cp   –a  * /soft 3.安装 3.1.解压所有的软件 tar -xvf nginx-1.0.8.tar.gz tar -xvf ncurses-5.9.tar.gz tar -xvf mysql-5.5.23.tar.gz tar -xvf php-

cenos6.5源码包安装lnmp环境

虽然centos6可以用yum安装nginx,但是我还是写个教程用源码包安装用于线上环境. 一:在nginx官网下载nginx,并安装 我下载的是nginx-1.6.0 #./configure --prefix=/usr/local/nginx make&& make install 卸载已存在的apache服务和php [[email protected] Desktop]# yum remove httpd php* 安装development Tools [[email prote

CentOS 7.0源码包搭建LNMP 实际环境搭建

Centos7+Nginx1.11.7+MySQL5.7.16+PHP7.1.0+openssl-1.1.0c 一.linux 系统限制配置 1.关闭系统防火墙 systemctl stop firewalld.service 关闭防火墙 systemctl disable firewalld.service  禁用防火墙 2.关闭SElinux sed -i 's/SELINUX=.*/SELINUX=disabled/g' /etc/selinux/config  setenforce 0 

CentOS 7.0源码包搭建LNMP方法分享(实际环境下)

CentOS 7.0编译安装Nginx1.6.0+MySQL5.6.19+PHP5.5.14 一.配置防火墙,开启80端口.3306端口 CentOS 7.0默认使用的是firewall作为防火墙,这里改为iptables防火墙. 1.关闭firewall: systemctl stop firewalld.service #停止firewall systemctl disable firewalld.service #禁止firewall开机启动 2.安装iptables防火墙 yum ins

源码编译搭建LAMP架构

前述: 本次源码编译安装LAMP平台架构在一台CentOs 7虚拟机完成(穿插叙述叙述mariadb在另一台主机上配置方法),php5以模块形式编译安装到httpd服务器上,httpd服务器Apace多路处理模块(MPM)采用prefork机制. 下面为安装所用的的以下软件叙述: CentOS  7 IP:172.16.49.2:Kernel:3.10.0-229.el7.x86_64 MariaDB 通用二进制格式mariadb-5.5.46-linux-x86_64.tar httpd 编译

2-24-源码编译搭建LAMP环境-作业 ( By 小甘丶 )

安装上课的内容要求: 实验环境: VMware Virtual Machine : System Version: CentOS6.8 ( Gan35 ) IP Address : 192.168.31.35 ( Birdege ) 1.用rpm包安装方式搭建一个LAMP环境,并测试是否能够解析PHP页面 安装LAMP环境 检查安装包是否已安装 rpm -qa | grep httpd rpm -qa | grep mysql* rpm -qa | grep php* yum -y instal