源码编译搭建LAMP环境

  1. 云栖社区>
  2. 博客>
  3. 正文

源码编译搭建LAMP环境

余二五 2017-11-17 21:10:00 浏览738
展开阅读全文

源码编译搭建LAMP环境

一:实验目标

源码编译LAMP环境 

二:实验环境

xuegod63.cn IP192.168.1.63

 

LAMP环境的概述

    LAMP(Linux- Apache-MySQL-PHP)一般用来做网站架构的,是目前国际流行的Web框架,该框架包括:Linux操作系统,Apache网络服务器,MySQL数据 库,Perl、PHP或者Python编程语言LAMP具有通用、跨平台、高性能、低价格的 优势,因此LAMP无论是性能、质量还是价格都是企业搭建网站的首选平台。

   对于大流量、大并发量的网站系统架构来说,除了硬件上使用高 性能的服务器、负载均衡、CDN等之外,在软件架构上需要重点关注下面几个环节:使用高性能的操作系统(OS)、高性能的网页服务器(Web Server)、高性能的数据库(Database)、高效率的编程语言等。下面我将从这几点对其一一讨论。

 

操作系统

    Linux操作系统有很多个不同的发行版,如Red Hat Enterprise Linux、SUSE Linux Enterprise、Debian、Ubuntu、CentOS等,每一个发行版都有自己的特色,比如RHEL的稳定,Ubuntu的易用,基于稳定性 和性能的考虑,操作系统选择CentOS(Community ENTerprise Operating System)是一个理想的方案。

 

Web服务器、缓存和PHP加速

    Apache是LAMP架构最核心的Web Server,开源、稳定、模块丰富是Apache的优势。但Apache的缺点是有些臃肿,内存和CPU开销大,性能上有损耗,不如一些轻量级的Web 服务器(例如nginx)高效,轻量级的Web服务器对于静态文件的响应能力来说远高于Apache服务器。

 

数据库

    开源的数据库中,MySQL在性能、稳定性和功能上是首选,可以达到百万级别的数据存储,网站初期可以将MySQL和Web服务器放在一起,但是当访问 量达到一定规模后,应该将MySQL数据库从Web Server上独立出来,在单独的服务器上运行,同时保持Web Server和MySQL服务器的稳定连接。

当数据库访问量达到更大的级别,可以考虑使用MySQL Cluster等数据库集群或者库表散列等解决方案。

 

总的来说,LAMP架构的网站性能会远远优于Windows IIS + ASP + Access(例如月光博客)这样的网站,可以负载的访问量也非常大,国内的大量个人网站如果想要支撑大访问量,采用LAMP架构是一个不错的方案。

 

 

三:实验代码

LAMP=Linux+Apache+Mysql+PHP

 

1:安装apache  

Apache源码包:httpd-2.2.25.tar.gz

 

1)解压httpd软件包

[root@xuegod63 ~]# tar -zxvf httpd-2.2.25.tar.gz -C /usr/local/src/

[root@xuegod63 ~]#cd /usr/local/src/httpd-2.2.25 

[root@xuegod63 httpd-2.2.25]# yum install openssl*

2)源码编译安装apache

[root@xuegod63 httpd-2.2.25]# ./configure --prefix=/usr/local/apache2 --enable-so --enable-rewrite --enable-ssl

   配置参数用途:

--prefix=/usr/local/apache2  #存放网站的根目录:

--enable-so # 支持动态加载模块

--enable-rewrite #支持网站地址重写

--enable-ssl # 支持ssl加密

[root@xuegod63 httpd-2.2.25]#make -j 4  #使用4个CPU来编译 。要使用大于你的物理CPU个数

[root@xuegod63 httpd-2.2.25]#make install

[root@xuegod63 apache2]# ls

bin    cgi-bin  error   icons    lib   man     modules

build  conf     htdocs  include  logs  manual

   http配置文件位置 

 [root@xuegod63 httpd-2.2.25]# ls /usr/local/apache2/conf/httpd.conf

/usr/local/apache2/conf/httpd.conf

  存放网站的根目录: 

[root@xuegod63 httpd-2.2.25]# ls /usr/local/apache2/htdocs/

index.html

[root@xuegod63 httpd-2.2.25]# cat /usr/local/apache2/htdocs/index.html

<html><body><h1>It works!</h1></body></html>

 

3)启用apache时,让apache可以开机启动并且可以使用service命令启动apache服务器

[root@xuegod63 httpd-2.2.25]# cp /usr/local/apache2/bin/apachectl  /etc/init.d/

[root@xuegod63 httpd-2.2.25]# /etc/init.d/httpd stop

[root@xuegod63 httpd-2.2.25]# chkconfig httpd off

 

#apache开机启动,还要再在apachectl文件的头部的注释中加两条命令。

[root@xuegod63 httpd-2.2.25]# vim /etc/init.d/apachectl # 添加以下红色内容

[root@xuegod63 httpd-2.2.25]# head !$

head /etc/init.d/apachectl

#!/bin/sh

# chkconfig: 2345 64 36 # 2345系统级别下开些服务 64 启动顺序  36 关闭顺序

# description: Activates/Deactivates all network interfaces configured to \

 

#可以参照:

[root@xuegod63 ~]# vim /etc/init.d/network

 wKiom1gictaRvoRPAAEPpH2e7aE340.jpg

注:启动时,要比network服务启动的晚一些。先让网络服务器启动起来,其它依靠网络相关的服务才可以正常启动。 启动的时候先启动网络,再启动httpd,关闭的时候,先关闭httpd。再关闭网络。

 

4)设置开机自动启动:

[root@xuegod63 apache2]# chkconfig --add apachectl

[root@xuegod63 apache2]# chkconfig --list apachectl

apachectl 0:off 1:off 2:on 3:on 4:on 5:on6:off

 

5)启动apache: 

[root@xuegod63 apache2]# /etc/init.d/apachectl start  #  启动之后80端口就启动了

 

6)测试:

wKiom1gicuyC2z0mAADl13Z6Bpw392.jpg 

 

注释:源码编译安装的apache运行身份是: daemon ;rpm安装的httpd运行身份是:apache

wKioL1gicweBf4eGAAaEHsxXhBc310.jpg

 

注:网站目录权限设置: 

[root@xuegod63 htdocs]# id daemon

uid=2(daemon) gid=2(daemon) groups=2(daemon),1(bin),4(adm),7(lp)

[root@xuegod63 htdocs]# chown daemon:daemon kaixin001/data #这里不需要写============================================================

 

2:Mysql的源码包安装

msyql源码包MySQL-5.5.30-1.el6.src.rpm 

 

1)安装前,如果不存在mysql 用户,则建立

[root@xuegod63 ~]# useradd -s /sbin/nologin  mysql

[root@xuegod63 Desktop]# vim /etc/passwd #不让mysql用户登录系统

改成: mysql:x:501:501::/home/mysql:/sbin/nologin

 

2)解压安装

[root@xuegod63 ~]# tar zxvf mysql-5.5.30.tar.gz -C /usr/local/src/

[root@xuegod63 src]# cd /usr/local/src/mysql-5.5.30/

 

3)Mysql 5.5.15使用了新的cmake编译方式,所以先安装cmake

   cmake是什么?

   CMake是一个跨平台的安装(编译)工具,可以用简单的语句来描述所有平台的安装(编译过程)。他能够输出各种各样的makefile或者project文件,能测试编译器所支持的C++特性,类似UNIX下的automake。

   安装cmake

[root@uplook mysql-5.5.30]# yum install -y cmake

#cmake-2.6.4-5.el6.x86_64.rpm软件包,RHEL系统自带,配置好yum源,

 

4)开始编译:

[root@xuegod63 mysql-5.5.30]#  mkdir /server/

[root@xuegod63 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_CHARSETS=all   -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1   -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1   -DENABLED_LOCAL_INFILE=1 -DMYSQL_DATADIR=/server/mysql/data   -DMYSQL_USER=mysql  

 

cmake 编译选项含意:

-DCMAKE_INSTALL_PREFIX=/server/mysql-5.5

#指定mysql安装的根目录,只要/server目录存在就可以了,mysql-5.5在安装时,会自动创建。这个值可以在服务器启动时,通过--basedir来设置。

-DMYSQL_UNIX_ADDR=/tmp/mysql.sock

#mysql服务器用于监听的套接字,这个必需是一个绝对路径,默认是/tmp/mysql.sock。在服务器启动时,可通过--socket 来改变。

-DDEFAULT_CHARSET=utf8

设置mysql默认使用utf8字符集,不指定,默认使用latin1 西欧字符集。

-DDEFAULT_COLLATION=utf8_general_ci #默认字符校对。 db.opt

DWITH_EXTRA_CHARSETS=all #指定mysql扩展字符集支持所有的字符集默认mysql支持所有字符集

-DWITH_MYISAM_STORAGE_ENGINE=1

-DWITH_INNOBASE_STORAGE_ENGINE=1

-DWITH_MEMORY_STORAGE_ENGINE=1

#静态编译Myisam、Innobase、Memory存储引擎到mysql服务器。这样mysql服务器就支持这三种存储引擎了。

-DWITH_READLINE=1 #支持readline库。

-DENABLED_LOCAL_INFILE=1 #允许从本地导入数据,启用加载本地数据

-DMYSQL_DATADIR=/server/mysql/data#mysql数据库存放数据的目录

-DMYSQL_USER=mysql #指定运行mysql服务的用户

注:具体编译参数参考:

http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.ht ml

最终会像configure一样生成Makefile。 

 

5)安装:

[root@xuegod63 mysql-5.5.30]# make -j 4 

#注:-j 用来指定CPU核心数,可加快编译速度。

[root@xuegod63 mysql-5.5.30]# make install  

 

  在编译时,查看CPU使用情况:

top-》P  查看CPU使用情况:

wKiom1gicyiyLBklAAdnwBhRxc4648.jpg 

cc1plus   #cc1plus是C++编译器程序,用于该软件对C++程序的编译功能

  扩展:

   gccGNU Compiler Collection,它的意思是GNU的编译器集合,而不是GNU C Compiler.gcc就是所谓的front -end -driver, 由它驱动相应的编译器、汇编器、链接器来完成整个由源代码到可执行文件的处理过程。CC程序叫做C Compiler。在linuxCCgcc的一软链接。

[root@xuegod63 mysql-5.5.30]# which cc

/usr/bin/cc

[root@xuegod63 mysql-5.5.30]# ll /usr/bin/cc

lrwxrwxrwx. 1 root root 3 Dec 18  2012 /usr/bin/cc -> gcc

 

6)配置mysql运行环境: 

[root@xuegod63 mysql-5.5.30]# chown -R mysql:mysql /server/mysql-5.5#修改mysql安装目录权限,允许mysql用户对mysql数据库文件夹读写。

复制mysql配置文件

[root@xuegod63 mysql-5.5.30]#  cp /usr/local/src/mysql-5.5.30/support-files/my-large.cnf /etc/my.cnf

 

设置mysqld5.5服务开机启动:

[root@xuegod63~]#cp/usr/local/src/mysql-5.5.30/support-files/mysql.server /etc/init.d/mysqld5.5

[root@xuegod63 ~]# chmod +x /etc/init.d/mysqld5.5

 

7)复制mysql开机启动文件,以后可以使用service命令来启动和关闭mysql

[root@xuegod63 ~]# vim/etc/init.d/mysqld5.5(编辑此文件,查找并修改以下变量内容:)

将原文件中:

basedir=

datadir=

修改成:

basedir=/server/mysql-5.5 #mysql安装目录

datadir=/server/mysql-5.5/data #mysql数据库存放数据的目录

加入开机启动项:

[root@xuegod63 Desktop]# chkconfig mysqld5.5 on

[root@xuegod63 Desktop]# chkconfig --list mysqld5.5

mysqld5.5 0:off 1:off 2:on 3:on 4:on 5:on 6:off

 

8)初始化编译mysql数据库:

[root@xuegod63 scripts]# pwd

/usr/local/src/mysql-5.5.30/scripts

[root@xuegod63 scripts]# chmod +x mysql_install_db

[root@xuegod63 scripts]# ./mysql_install_db --defaults-file=/etc/my.cnf --basedir=/server/mysql-5.5 --datadir=/server/mysql-5.5/data --user=mysql #类似于 rpm包

安装的mysql数据库,第一次启动弹出的消息

........

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@xuegod63 scripts]#

 

9)开启mysql

[root@xuegod63 scripts]# /etc/init.d/mysqld5.5 start

Starting MySQL.... [ OK ]

 

10)测试登录:

[root@xuegod63 scripts]# mysql

wKiom1gic0CCWcOVAAAchf-Miow754.jpg 

11)设置mysqlroot密码:

[root@xuegod63 Desktop]# mysqladmin -uroot password '123456'

[root@xuegod63 Desktop]# mysql -u root -p123456

 

12)设置mysql只允许局域组中的服务器和本地回环口连接3306端口:

[root@xuegod63 Desktop]# iptables -A INPUT -s 192.168.1.0/255.255.255.0 -p tcp --dport 3306 -j ACCEPT 

[root@xuegod63 Desktop]# iptables -A INPUT -s 127.0.0.1 -p tcp --dport 3306 -j ACCEPT

[root@xuegod63 Desktop]# iptables -A INPUT ! -s 127.0.0.1 -p tcp --dport 3306 -j DROP 

保存规则:

[root@wt1 mysql-5.5.24]# /etc/init.d/iptables save

LAMP 都运行在一台机器上

 

============================================================

 

3:安装PHP

PHP软件包:php-5.4.14.tar.bz2

 

1)解压 php-5.4.14.tar.bz2 软件包

[root@xuegod63 ~]# tar -jxvf php-5.4.14.tar.bz2 -C /usr/local/src/

[root@xuegod63 ~]# cd /usr/local/src/php-5.4.14/

 

2)源码编译安装

[root@xuegod63 php-5.4.14]# ./configure    --prefix=/server/php-5.4 --with-mysql=/server/mysql-5.5  --with-apxs2=/usr/local/apache2/bin/apxs  --with-config-file-path=/server/php-5.4

#弹出以一信息,说明php环境检查通过

。。。

Thank you for using PHP.

注解:

--prefix=/server/php-5.4  #安装PHP的目录

--with-apxs2=/usr/local/apache2/bin/apxs:用apache的apxs工具把php编译成apache的一个模块

--with-mysql=/usr/local/mysql:与mysql结合

--with-config-file-path=/usr/local/php#指定php配置文件路径

查看服务器原先参数:

[root@xuegod63 ~]# /server/php-5.4/bin/php -i | grep configure

Configure Command => './configure' '--prefix=/server/php-5.4' '--with-mysql=/server/mysql-5.5' '--with-apxs2=/usr/local/apache2/bin/apxs' '--with-config-file-path=/server/php-5.4'

PHP Warning: Unknown: It is not safe to rely on the system's timezone settings. You are *required* to use the date.timezone setting or the date_def

 

[root@xuegod63 ~]#make -j 4

[root@xuegod63 ~]#make install

 

扩展: 释放cache : 建意这样做。 

[root@xuegod63 vm]# free -m

total used free shared buffers cached

Mem: 2297 1642 654 0 29 1183

-/+ buffers/cache: 429 1867

Swap: 999 0 999

[root@xuegod63 vm]# sync #把内存中没有保存的数据,写到磁盘上。

[root@xuegod63 vm]# echo 3 > /proc/sys/vm/drop_caches

[root@xuegod63 vm]# free -m

total used free shared buffers cached

Mem: 2297 1642 654 0 29 64

-/+ buffers/cache: 429 1867

Swap: 999 0 999

 

3:)生成php配置文档:php.ini

[root@xuegod63 Desktop]# cp /usr/local/src/php-5.4.14/php.ini-production /server/php-5.4/php.ini

 

4)如果一切顺利,会成功一个模块:

[root@xuegod63 ~]# ls /usr/local/apache2/modules/

httpd.exp libphp5.so

 

apache支持PHP模块:

 

 

[root@xuegod63 Desktop]# vim /usr/local/apache2/conf/httpd.conf

<IfModule dir_module>

DirectoryIndex index.html index.php #默认首页支持index.php

</IfModule>

wKioL1gic16ReHiGAADMWeMHN1c745.jpg 

在此文件311行下,添加: 

AddType application/x-httpd-php .php

wKiom1gic3KT30JpAABUXye28_o371.jpg 

 

5)服务,测试Apache及php支持  

[root@xuegod63 Desktop]# cd /usr/local/apache2/htdocs/

[root@xuegod63 htdocs]# ls

index.html

[root@xuegod63 htdocs]# mv index.html index.html.back

[root@xuegod63 htdocs]# vim index.php

[root@xuegod63 htdocs]# cat index.php

<?php

phpinfo();

?>

[root@xuegod63 htdocs]# /etc/init.d/apachectl stop

[root@xuegod63 htdocs]# /etc/init.d/apachectl start

wKiom1gic4fhKmK4AACgo8LwVDI186.jpg 










本文转自 于学康 51CTO博客,原文链接:http://blog.51cto.com/blxueyuan/1870900,如需转载请自行联系原作者

网友评论

登录后评论
0/500
评论
余二五
+ 关注