编译安装LAMP环境

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介:

LAMP环境配置:
httpd-2.4.23 + mysql-5.5.51 +php-5.5.38编译安装过程
编译前先准备系统的开发环境:

1
# yum groupinstall "Development tools" "Server Platform Development"


一、编译安装apache

1、解决依赖关系
httpd-2.4.23需要较新版本的apr和apr-util,因此需要事先对其进行升级。升级方式有两种,一种是通过源代码编译安装,一种是直接升级rpm包。这里采用源码编译方式;
(1) 编译安装apr

1
2
3
4
# tar zxf apr-1.5.2.tar.gz
# cd apr-1.5.2
# ./configure --prefix=/usr/local/apr
# make && make install

(2) 编译安装apr-util

1
2
3
4
# tar xf apr-util-1.5.4.tar.gz
# cd apr-util-1.5.4
# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
# make && make install

(3)httpd-2.4.23编译过程也要依赖于pcre-devel软件包,需要事先安装。此软件包系统光盘自带,因此,找到并安装即可。

1
# yum install -y pcre-devel


(4)创建用户,组


1
2
# groupadd -r apache
# useradd -r -g apache apache


2.编译安装httpd-2.4.23

首先下载httpd-2.4.23到本地:httpd-2.4.23.tar.gz

1
2
3
4
# tar xf httpd-2.4.23.tar.gz
# cd httpd-2.4.23
# ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd24 --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --enable-modules=most --enable-mpms-shared=all --with-mpm=event
# make -j 4 && make install

提供SysV服务脚本/etc/rc.d/init.d/httpd

1
2
3
4
5
6
7
# cp /etc/rc.d/init.d/httpd /etc/rc.d/init.d/httpd24 #这个httpd服务脚本拷贝系统预装httpd2.2的服务脚本修改下面几行:
     vim  /etc/rc .d /init .d /httpd24
             apachectl= /usr/local/apache/bin/apachectl
             httpd=${HTTPD- /usr/local/apache/bin/httpd }
             prog=httpd
             pidfile=${PIDFILE- /usr/local/apache/logs/httpd .pid} #注意:httpd.pid默认位置
             lockfile=${LOCKFILE- /var/lock/subsys/httpd24 }
1
2
3
加入服务列表:
# chkconfig --add httpd
# chkconfig --list httpd24

测试启动:

1
2
service httpd24 restart
使用浏览器访问当前主机显示It Works 表示成功。

注意:如果用httpd -t 报错找不到指定文件,可以通过软链接的方式将httpd指向指定目录:
# ln -sv /usr/local/apache/bin/httpd /usr/local/sbin/httpd

二、安装mysql-5.5.51

(1)准备数据存放的文件系统

1
2
3
4
5
6
7
8
9
10
11
##创建一个mydata单独的LVM2文件系统
         #fdisk /dev/sda3
         #pvcreate /dev/sda3
         #vgcreate myvg /dev/sda3
         #lvcreate -L 10G -n mydata myvg
         #mke2fs -t ext4 /dev/myvg/mydata
         #mkdir /mydata
         #vim /etc/fstab 添加:/dev/myvg/mydata /mydata ext4 defaults 0 0
         #mount -a 
         #cd /mydata;mkdir data
         #chown mysql:mysql data

            
(2)创建用户,组            

1
2
3
# groupadd -r mysql
# useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql
# chown -R mysql:mysql /mydata/data

    
(3)安装mysql-5.5.51

1
2
3
4
# tar zxf mysql-5.5.51-linux2.6-i686.tar.gz -C /usr/local/
# cd /usr/local/
# ln -sv mysql-5.5.51-linux2.6-i686/ mysql
# cd mysql


(4)安装并初始化mysql-5.5.51

1
2
3
# chown -R mysql:mysql .
# scripts/mysql_install_db --user=mysql --datadir=/mydata/data
# chown -R root .


(5)为mysql提供主配置文件:

1
2
3
4
5
6
# cd /usr/local/mysql
# cp support-files/my-large.cnf  /etc/my.cnf
#并修改此文件中thread_concurrency的值为你的CPU个数乘以2,比如这里使用如下行:
thread_concurrency = 2
另外还需要添加如下行指定mysql数据文件的存放位置:
datadir =  /mydata/data


(6)拷贝服务脚本

1
2
3
# cd /usr/local/mysql
# cp support-files/mysql.server /etc/rc.d/init.d/mysqld
# chmod +x /etc/rc.d/init.d/mysqld


(7)添加服务列表

1
2
3
# chkconfig --add mysqld
# chkconfig mysqld on
# chkconfig --list mysqld

(8)添加系统环境变量

1
2
3
4
5
6
# vim /etc/profile.d/mysql.sh
     #!/bin/bash
     #
     export  PATH= /usr/local/mysql/bin :$PATH
# source /etc/profile.d/mysql.sh
测试启动:service mysqld restart
1
2
3
4
5
6
7
使用mysql命令登陆本地数据库,并给数据库创建密码
     mysql> use mysql
     mysql> update user  set  password=password( 'root' ) where user= 'root' ;
     mysql>  select  user,host,password from user;
     mysql> drop user  '' @ 'localhost' ; #删除匿名用户
     mysql> drop user  '' @ 'liu'
     mysql> flush privileges;

注意:额外配置

1
2
3
4
5
6
7
8
9
10
1、输出mysql的 man 手册至 man 命令的查找路径:
编辑 /etc/man .config,添加如下行即可:
MANPATH   /usr/local/mysql/man
2、输出mysql的头文件至系统头文件路径 /usr/include
这可以通过简单的创建链接实现:
# ln -sv /usr/local/mysql/include  /usr/include/mysql
3、输出mysql的库文件给系统库查找路径:
# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf
而后让系统重新载入系统库:
# ldconfig

三、编译安装php-5.5.38
1、解决依赖关系:

1
2
3
4
请配置好yum源(系统安装源及epel源)后执行如下命令:
# yum -y groupinstall "Desktop Platform Development" 
# yum -y install bzip2-devel libmcrypt-devel libxml2-devel
libmcrypt-devel 需要epel yum源进行安装。

2.安装php-5.5.38

1
2
3
# tar zxf php-5.5.38.tar.gz
# cd php-5.5.38
# ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql --with-openssl --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml  --enable-sockets --with-apxs2=/usr/local/apache/bin/apxs --with-mcrypt  --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2  --enable-maintainer-zts

说明:
1、这里为了支持apache的worker或event这两个MPM,编译时使用了--enable-maintainer-zts选项。
2、如果使用PHP5.3以上版本,为了链接MySQL数据库,可以指定mysqlnd,这样在本机就不需要先安装MySQL或MySQL开发包了。mysqlnd从php 5.3开始可用,可以编译时绑定到它(而不用和具体的MySQL客户端库绑定形成依赖),但从PHP 5.4开始它就是默认设置了。
# ./configure --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd

1
# make -j 4 && make install
1
2
为php提供配置文件:
# cp php.ini-production /etc/php.ini


3、 编辑apache配置文件httpd.conf,以apache支持php

1
2
3
4
5
6
7
  # vim /etc/httpd/httpd.conf
  1、添加如下二行
    AddType application /x-httpd-php   .php
    AddType application /x-httpd-php-source   .phps
  2、定位至DirectoryIndex index.html 
    修改为:
     DirectoryIndex  index.php  index.html

而后重新启动httpd,或让其重新载入配置文件即可测试php是否已经可以正常使用。

4、测试php安装是否成功:

测试页面index.php示例如下:
    <?php
      $link = mysql_connect('127.0.0.1','root','root');
      if ($link)
        echo "Success...";
      else
        echo "Failure...";

      mysql_close();
      phpinfo();
    ?>
    
四、LAMP环境测试

        这里使用phpMyAdmin测试
        mv phpMyAdmin-4.4.14.1-all-languages /usr/local/apache/htdocs/pma
        cd /usr/local/apache/htdocs/pma
        cp config.sample.inc.php config.inc.php
        vim config.inc.php
        ab -c 10 -n 100 http://192.168.137.30/pma/index.php #压力测试
        
五、安装xcache,为php加速:

1、安装xcache-3.2.0
# tar zxf xcache-3.2.0.tar.gz
# cd xcache-3.2.0
# /usr/local/php/bin/phpize
# ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config
# make && make install

安装结束时,会出现类似如下行:
Installing shared extensions:     /usr/local/php/lib/php/extensions/no-debug-zts-20121212/

2、编辑php.ini,整合php和xcache:

首先将xcache提供的样例配置导入php.ini
# mkdir /etc/php.d
# cp xcache.ini /etc/php.d

说明:xcache.ini文件在xcache的源码目录中。

接下来编辑/etc/php.d/xcache.ini,找到zend_extension开头的行,修改为如下行:
extension = /usr/local/php/lib/php/extensions/no-debug-zts-20121212/xcache.so

注意:如果php.ini文件中有多条zend_extension指令行,要确保此新增的行排在第一位。
访问测试页,即可看到已安装的xcache模块属性信息
现在即可使用ab命令进行压力测试,速度一般提升在3倍左右。



本文转自 ljohnmail 51CTO博客,原文链接:http://blog.51cto.com/ljohn/1863283,如需转载请自行联系原作者

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
SQL JavaScript 关系型数据库
MySQL Shell 使用指南
MySQL Shell 是一个强大且灵活的工具,它扩展了 MySQL 客户端的功能,使得数据库管理和运维工作更加便捷高效。
1324 0
|
11月前
|
敏捷开发 监控 数据可视化
产品开发为什么需要看板管理?掌握这些技巧提高效率!
在数字化时代,产品开发是企业创新与竞争的关键。本文探讨了产品开发的核心流程、敏捷管理方法及高效工具的应用,如板栗看板,以优化团队协作和资源配置,加速产品上市并提升市场竞争力。核心流程涵盖市场调研、规划设计、研发迭代、测试优化、上线推广及持续改进。敏捷开发强调短周期迭代、跨团队协作和数据驱动决策。可视化工具如板栗看板能有效提升任务透明度和协作效率,确保产品按时高质量交付。
|
缓存 编译器 数据处理
【C/C++ 性能优化】循环展开在C++中的艺术:提升性能的策略与实践
【C/C++ 性能优化】循环展开在C++中的艺术:提升性能的策略与实践
1317 0
|
监控 安全 Linux
如何利用Kali Linux进行网站渗透测试:最常用工具详解
如何利用Kali Linux进行网站渗透测试:最常用工具详解
914 6
|
Java Spring
spring boot 集成websocket与shiro的坑
spring boot 集成websocket与shiro的坑
861 0
|
SQL 关系型数据库 数据库
SqlAlchemy 2.0 中文文档(四十四)(9)
SqlAlchemy 2.0 中文文档(四十四)
290 3
|
网络协议 Java API
如何在Java中实现WebSocket通信
如何在Java中实现WebSocket通信
|
分布式计算 Hadoop 网络安全
|
机器学习/深度学习 人工智能 监控
人工智能在图像识别中的应用:基于深度学习的算法实现
人工智能在图像识别中的应用:基于深度学习的算法实现
895 1
|
SpringCloudAlibaba 算法 Java
Spring Boot项目如何实现分布式日志链路追踪
作为一名后端开发工程师,排查系统问题用得最多的手段之一就是查看系统日志,在当下主要的分布式集群环境中一般使用ELK(Elasticsearch , Logstash, Kibana)来统一收集日志,以便后续查看日志定位追踪相关问题。但是在并发情况下,大量的系统用户即多线程并发访问后端服务导致同一个请求的日志记录不再是连续相邻的,此时多个请求的日志是一起串行输出到文件中,所以我们筛选出指定请求的全部相关日志还是比较麻烦的,同时当后端异步处理功能逻辑以及微服务的下游服务调用日志追踪也有着相同的问题。