centos 6 编译安装LAMP

搭建环境:Centos 6.8,httpd2.4.18,mysql 5.6.23,php 5.6.17

一、前期准备

请参考LNMP前期准备和mysql安装请参考:http://www.jb51.cc/article/p-mdoljzgl-ou.html

二、httpd安装

安装apr

tarxfapr-1.5.2.tar.gz
cdapr-1.5.2
./configure--prefix=/usr/local/apr
make&&makeinstall

安装apr-util

tarxfapr-util-1.5.4.tar.gz
cdapr-util-1.5.4
./configure--prefix=/usr/local/apr-util--with-apr=/usr/local/apr
make&&makeinstall

安装httpd

cdhttpd-2.4.18
./configure--prefix=/usr/local/apache--sysconfdir=/etc/httpd--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&&makeinstall

编译安装部分参数说明

--enable-so#支持DSO动态装载模块
--enable-ssl#要编译启用ssl模块(前提是需要安装openssl-devel)
--enable-cgi#启用CGI模块(默认就启用)
--enable-rewrite#URL重写(支持URL重写)
--with-zlib#这是一个压缩库(专用于网络传输)
--with-pcre#使用增强的perl正则表达式分析工具(使用这项需要安装pcre-devel,pcre:正则表达式分析器)
--with-apr=/usr/local/apr#指明apr的目录(若apr在特殊路径下)
--with-apr-util=/usr/local/apr-util/#指明apr-util路径(若apr-util在特殊路径下
)
--enable-mpms-shared=all#把所有的mpm模块都编译进来而且是共享模块
--with-mpm=work#默认使用的mpm模块
--enable-modules=most(all)#还有很多其他模块,其他的动态可装载模块需要

测试httpd配置是否正常

/usr/local/apache/bin/apachectl-t

设置httpd服务和开机启动项

cp/usr/local/apache/bin/apachectl/etc/rc.d/init.d/httpd
vim/etc/rc.d/init.d/httpd
#chkconfig:356161
#description:Apache
chkconfig--addhttpd
chkconfighttpdon

三、php编译安装

前期准备(补充安装,--with-xsl使用)

yuminstalllibxslt-devel

安装php

tarxfphp-5.6.17.tar.gz
cdphp-5.6.17
./configure--prefix=/usr/local/php--with-mysql=/usr/local/mysql--with-apxs2=/usr/local/apache/bin/apxs--with-mysqli=/usr/local/mysql/bin/mysql_config--with-iconv-dir=/usr/local--with-openssl--enable-mbstring--with-freetype-dir--with-jpeg-dir--with-png-dir--with-zlib--with-libxml-dir=/usr--enable-xml--disable-rpath--enable-bcmath--enable-shmop--enable-sysvsem-disable-inline-optimization--enable-mbregex--enable-mbstring--with-gd--enable-gd-native-ttf--with-mhash--enable-pcntl--enable-sockets--with-mcrypt--with-ldap--with-ldap-sasl--with-xmlrpc--enable-zip--enable-soap--with-bz2--with-config-file-path=/etc--with-config-file-scan-dir=/etc/php.d--enable-maintainer-zts--with-xmlrpc=shared--with-xsl
makeZEND_EXTRA_LIBS='-liconv'
makeinstall

编译安装部分参数说明(很多加载项用途不明,从别处抄袭,前几位参数还是特别重要的,比如--with-apsx2,httpd和php整合用使用)

--with-mysql=/usr/local/mysql#MySQL安装目录,对mysql的支持
--with-mysqli=/usr/local/mysql/bin/mysql_config#mysqli扩展技术不仅可以调用MySQL的存储过程、处理MySQL事务,而且还可以使访问数据库工作变得更加稳定。
--with-apxs2=/usr/local/apache/bin/apxs#整合apache,apxs功能是使用mod_so中的LoadModule指令,加载指定模块到apache,要求apache要打开SO模块
--with-iconv-dir=/usr/local#选项指令,用于PHP编译时指定iconv在系统里的路径,否则会扫描默认路径(与ZEND_EXTRA_LIBS='-liconv')。
--enable-maintainer-zts#编译成zts模块,event,worker模式使用
--with-freetype-dir#打开对freetype字体库的支持
--with-jpeg-dir#打开对jpeg图片的支持
--with-png-dir#打开对png图片的支持
--with-zlib-dir#打开zlib库的支持,用于http压缩传输
--with-libxml-dir#打开libxml2库的支持
--disable-rpath#关闭额外的运行库文件
--enable-bcmath#打开图片大小调整,用到zabbix监控的时候用到了这个模块
--enable-sysvsem#这样就使得你的PHP系统可以处理相关的IPC函数了。
--enable-inline-optimization#优化线程
--with-curl#打开curl浏览工具的支持
--with-curlwrappers#运用curl工具打开url流
--enable-mbregex
--enable-fpm#支持PHP-fpm,早期版本需要补丁后才有这个参数,CGI方式安装的启动程序
--enable-mbstring#多字节,字符串的支持
--with-mcrypt#mcrypt算法扩展
--with-mhash#mhash算法扩展
--with-gd#打开gd库的支持
--enable-gd-native-ttf#支持TrueType字符串函数库
--with-openssl#openssl的支持,加密传输https时用到的
--enable-pcntl#freeTDS需要用到的,可能是链接mssql才用到
--enable-sockets#打开sockets支持
--with-xmlrpc#打开xml-rpc的c语言
--enable-zip#打开对zip的支持
--enable-ftp#打开ftp的支持
--with-bz2#打开对bz2文件的支持
--without-iconv#关闭iconv函数,字符集间的转换
--with-ttf#打开freetype1.*的支持,可以不加了
--with-xsl#打开XSLT文件支持,扩展了libXML2库,需要libxslt软件
--with-gettext#打开gnu的gettext支持,编码库用到
--with-pear#打开pear命令的支持,PHP扩展用的
--enable-calendar#打开日历扩展功能
--enable-exif#图片的元数据支持
--enable-magic-quotes#魔术引用的支持
--disable-debug#关闭调试模式
--with-mime-magic=/usr/share/file/magic.mime#魔术头文件位置
#CGI方式安装才用的参数
--enable-fastCGI#支持fastcgi方式启动PHP
--enable-force-CGI-redirect#重定向方式启动PHP
--with-ncurses#支持ncurses屏幕绘制以及基于文本终端的图形互动功能的动态库
--with-gmp#应该是支持一种规范
--enable-dbase#建立DBA作为共享模块
--with-pcre-dir=/usr/local/bin/pcre-config#perl的正则库案安装位置
--disable-dmalloc
--with-gdbm#dba的gdbm支持
--enable-sigchild
--enable-sysvshm
--enable-zend-multibyte#支持zend的多字节
--enable-wddx
--enable-soap

提供php配置文件

cpphp.ini-production/etc/php.ini

修改httpd.conf,使其支持php,并且可以识别index.php结尾作为首页

AddTypeapplication/x-httpd-php.php
AddTypeapplication/x-httpd-php-source.phps
DirectoryIndexindex.phpindex.html

四、PHP扩展

libevent编译安装(libevent是一个基于事件触发的网络库,memcached底层也是使用libevent库。)

tarxflibevent-2.0.22-stable.tar.gz
cdlibevent-2.0.22-stable
./configure--prefix=/usr/local/libevent
make&&makeinstall
echo"/usr/local/libevent/lib">/etc/ld.so.conf.d/libevent.conf
ldconfig

memcached编译安装

tarxfmemcached-1.4.25.tar.gz
cdmemcached-1.4.25
/configure--prefix=/usr/local/memcached--with-libevent=/usr/local/libevent/
make&&makeinstall

编译memcached开机启动项(部分设置均在服务脚本中)

vim/etc/rc.d/init.d/memcached
#!/bin/bash
#
#Initfileformemcached
#
#chkconfig:-8614
#description:Distributedmemorycachingdaemon
#
#processname:memcached
#config:/etc/sysconfig/memcached

./etc/rc.d/init.d/functions

##Defaultvariables
PORT="11211"
USER="root"
MAXCONN="1024"
CACHESIZE="64"
OPTIONS=""

RETVAL=0
prog="/usr/local/memcached/bin/memcached"
desc="Distributedmemorycaching"
lockfile="/var/lock/subsys/memcached"

start(){
echo-n$"Starting$desc(memcached):"
daemon$prog-d-p$PORT-u$USER-c$MAXCONN-m$CACHESIZE
RETVAL=$?
echo
[$RETVAL-eq0]&&touch$lockfile
return$RETVAL
}

stop(){
echo-n$"Shuttingdown$desc(memcached):"
killproc$prog
RETVAL=$?
echo
[$RETVAL-eq0]&&rm-f$lockfile
return$RETVAL
}

restart(){
stop
start
}

reload(){
echo-n$"Reloading$desc($prog):"
killproc$prog-HUP
RETVAL=$?
echo
return$RETVAL
}

case"$1"in
start)
start
;;
stop)
stop
;;
restart)
restart
;;
condrestart)
[-e$lockfile]&&restart
RETVAL=$?
;;
reload)
reload
;;
status)
status$prog
RETVAL=$?
;;
*)
echo$"Usage:$0{start|stop|restart|condrestart|status}"
RETVAL=1
esac

exit$RETVAL
chmod+x/etc/rc.d/init.d/memcached
chkconfig--addmemcached
servicememcachedstart

memcached部分参数说明

-l<ip_addr>:指定进程监听的地址;
-d:以服务模式运行;
-u<username>:以指定的用户身份运行memcached进程;
-m<num>:用于缓存数据的最大内存空间,单位为MB,默认为64MB;
-c<num>:最大支持的并发连接数,默认为1024;
-p<num>:指定监听的TCP端口,默认为11211;
-U<num>:指定监听的UDP端口,默认为11211,0表示关闭UDP端口;
-t<threads>:用于处理入站请求的最大线程数,仅在memcached编译时开启了支持线程才有效;
-f<num>:设定SlabAllocator定义预先分配内存空间大小固定的块时使用的增长因子;
-M:当内存空间不够使用时返回错误信息,而不是按LRU算法利用空间;
-n:指定最小的slabchunk大小;单位是字节;
-S:启用sasl进行用户认证;

freetds编译安装(用于php连接mssql)

tarxffreetds-1.00.11.tar.gz
cdfreetds-1.00.11
./configure--prefix=/usr/local/freetds--with-tdsver=7.3--enable-msdblib--with-gnu-ld--enable-shared--enable-static
make&&makeinstall
cd/usr/local/src/php-5.6.17/ext/mssql/
/usr/local/php/bin/phpize
./configure--with-php-config=/usr/local/php/bin/php-config--with-mssql=/usr/local/freetds/
make&&makeinstall

--with-tdsver=7.3说明,具体说明参照:

http://www.freetds.org/userguide/choosingtdsprotocol.htm#TAB.PROTOCOL.BY.PRODUCT

wKiom1eXNBrCzsr4AAB2YE_enNA904.png

安装php支持memcache扩展模块

tarzxvfmemcache-2.2.7.tgz
cdmemcache-2.2.7
/usr/local/php/bin/phpize
./configure--enable-memcache--with-php-config=/usr/local/php/bin/php-config--with-zib-dir
make&&makeinstall

修改php.ini,增加freetds和memcache功能

extension_dir="/usr/local/php/lib/php/extensions/no-debug-zts-20131226/"
extension=mssql.so
extension="GBK"
extension=memcache.so

重启httpd使生效

servicehttpdrestart

编写php测试页面

<?php
$link=mysql_connect('ipaddress','user','passwd');
if($link)
echo"MySQLSuccess...";
else
echo"MySQLFailure...";
mysql_close();
$conn=mssql_connect('ipaddress','passwd');
if($conn)
echo"MSSQLSucess...";
else
echo"MSSQLFailure...";
mssql_close();
phpinfo();
?>

测试可正常使用

wKioL1eXO0jwle8ZAABZSzaWqTU342.png

wKioL1eXNzKAOJluAAAnwnABSMA265.png

wKioL1eXNzLTOjf5AAAyHfm3lQw710.png

五、后记

本篇博文拖了好久才写出来,其实LAMP编译安装还是挺简单的,只是httpd和php的模块化整合搞了好久(./configure具体配置不知何用),计划用于公司的IPOS系统测试使用,后面几篇博文计划httpd.conf,php.ini,nginx.conf配置说明。web服务器的搭建还是得熟练点,毕竟Linux使用最多的东西。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


文章浏览阅读903次。4.清除缓存目录(/var/cache/yum)下的软件包及旧的headers。11.列出所有已安裝但不在 Yum Repository 內的软件包信息。3.清除缓存目录(/var/cache/yum)下旧的 headers。2.清除缓存目录(/var/cache/yum)下的 headers。5.列出所有已安装但不在 Yum Repository 內的软件包。1.清除缓存目录(/var/cache/yum)下的软件包。9.列出所有可更新的软件包信息。3.列出所有可更新的软件包。_centos yum update
文章浏览阅读1.5k次。Python 是一种高级解释性编程语言,已被用于各种应用程序开发,并在近年来获得了巨大的流行。Python 可用于编写广泛的应用程序,包括 Web 开发、数据分析、科学计算、人工智能、游戏等。由于其简单易用,它是初学者的理想语言。Python广泛应用于金融、医疗保健和科技等行业,并且由于其丰富的数据分析和可视化库和工具集而受到数据科学家和研究人员的欢迎。创建本内容时 Python 的最新稳定版本是 Python 3.11。_linux安装python3.11
文章浏览阅读2.6k次。打开终端或控制台,以root或具有sudo权限的用户身份登录。根据你的Linux发行版和网络管理工具的不同,相应的命令可能略有不同。使用以下命令编辑网络配置文件,例如eth0网卡的配置文件:注意:ifcfg-eth0 可能会有不同的命名,根据实机情况确认。在编辑器中,找到以"IPADDR"开头的行,然后修改IP地址。例如,将IP地址更改为192.168.1.100_银河麒麟修改ip地址
文章浏览阅读744次,点赞24次,收藏26次。目标:通过AppSrv为InsideCli客户端网络分配地址,地址池范围:192.168.0.110-192.168.0.190/24。另外一个虚拟网卡改为192.168.0.1给Rserver服务器,添加多一个网卡,用于连接不同的网段分别选刚才选好的两个网段之后,开启各虚拟机,配置IP地址ip addr查看网卡vi /etc/sysconfig/network-scripts/ifcfg-ens33新网卡没有UUID,要生成一个uuidgen然后记下进入文件夹cd /etc/sysconfig/netwo
文章浏览阅读1.1w次,点赞8次,收藏26次。chmod命令来自于英文词组“change mode”的缩写,其功能适用于改变文件或者目录权限的命令。默认只有文件的所有者和管理员可以设置文件权限,普通用户只能管理自己的文件的权限属性。设置权限时可以使用数字法,亦可使用字母表达式,对于目录文件建议加入-R参数进行递归操作,意味着不仅对于目录本身,也对目录内的子文件/目录进行新权限的设定。_chmod修改权限
文章浏览阅读1.2k次。yum源的URL地址,本例中是文件系统的路径,以“file:///”开头。其中,是要安装的软件包的名称。:本节的名称,可以是任何名称,但是必须以“[ ]”括起来。如果能够看到光盘的设备信息,则说明系统已经检测到了光盘。注意:baseurl的值必须是光盘挂载的目录路径。:GPG公钥文件的路径,用于yum包的安全性检查。:yum源是否启用,1表示启用,0表示禁用。:是否进行GPG校验,1表示是,0表示否。打开终端,使用root用户登录。:yum源的名称,可以自定义。_centos挂载光盘
文章浏览阅读1.4k次。这会在系统中安装新的 OpenSSL 版本。如果输出结果中的版本号为 1.1.1 或更高版本,则说明 OpenSSL 已成功升级。然后将新安装的OpenSSL做软连接到这个路径。4.初始化并编译、安装。_centos 升级 openssl
文章浏览阅读4.9k次,点赞5次,收藏11次。[Linux下的软连接、软链接的方式]][[Linux使用的filesystem库来自于c++17提供的新特性]][[Linux下centos查看 GCC 、G++版本]][[Linux 下centos 查看 -std 是否支持 C17 ]]_gcc c++17
文章浏览阅读3.2k次,点赞3次,收藏9次。Linux (centos) 安装Python3.9(保姆级别)_centos安装python3.9
文章浏览阅读5.9k次,点赞4次,收藏4次。进入国内的阿里云的,这里CentOS 7提供了三种ISO镜像文件的下载:DVD ISO、Everything ISO、Minimal ISO。阿里云下载链接: http://mirrors.aliyun.com/centos/点击进入下载页面,随便选择一个下载即可(不推荐,推荐阿里云下载,见下文)阿里云下载站点(速度非常快推荐)_centos7 iso
文章浏览阅读3.9k次。运行报错_inconsistency detected by ld.so: dl-call-libc-early-init.c: 37: _dl_call_lib
文章浏览阅读782次,点赞22次,收藏24次。通过查看INSTALL文件我们可以知道安装glibc2.31的要求,需要binutils版本2.25以上,texinfo版本4.7以上,bison版本2.7以上,sed版本3.02以上,gettext0.10.36以上,Python3.4以上,GDB7.8以上,make版本4.0以上,GCC版本6.2 以上。isl-0.18版本: http://www.mirrorservice.org/sites/sourceware.org/pub/gcc/infrastructure。_rpm 更新glibc2.31
文章浏览阅读905次,点赞19次,收藏16次。操作系统运维相关操作,实用而全面_centos 共享磁盘
文章浏览阅读1.5k次。CentOS Stream的位置提到RHEL上游,解决了“孤儿”的问题。红帽在RHEL上开发的所有功能都已经在CentOS Stream上完成,生态伙伴所添加的内容都将返回到CentOS Stream中,这些新功能会在未来RHEL发布出来,避免了生态伙伴创新消失不见情况的发生,从而保护投资,保护创新。为什么强调位置的变化?红帽的创新得到了CentOS创造者Gregory Kurtzer的肯定,他曾在公开场合表示,红帽做了正确的事情,CentOS Stream的场景比CentOS更好,更适合社区的发展。_dnf: command not found
文章浏览阅读1k次,点赞3次,收藏6次。sysconf:keepalived核心配置文件所在位置,固定位置,改成其他位置则keepalived启动不了,/var/log/messages中会报错。注意:如果在第5步执行 make && make install 时,报如下错误,则可能是keepalived版本号不对,可以试试 2.1.0 以前的版本。4. 进入到解压后的文件夹内,里面会看到 configure 文件,接下来就可以使用 configure 命令进行配置了。2. 通过 ftp工具上传到 linux:/home/software/_服务器双机热备
文章浏览阅读3k次。配置iptables规则,限制用户的出口IP,这里是根据用户的uid去限制的,比如user001用户的uid是1000,配置user001用户的出口IP就是172.17.22.1,以下是示例,根据自己情况修改uid和出口IP。找到auth的配置,默认是注释了的,先放开注释(就是把首行的#去掉),然后把Authentication这列改为u,以下是修改后的截图。打开后是空文件,在这里面添加自己的代理账号和密码,格式:账号+英文空格+密码,以下是例子,自己配置自己的账号。至此恭喜你,完成了所有配置!_站群搭建socks5
文章浏览阅读815次。下载链接:https://github.com/PowerShell/PowerShell/releases。下载链接:https://github.com/PowerShell/PowerShell/_linux中pwsh安装
文章浏览阅读877次,点赞10次,收藏5次。在CentOS系统中,Apache服务器是一个常用的Web服务器软件,它可以高效地提供静态HTTP服务。现在,您已经成功地在CentOS系统中配置了Apache服务器提供静态HTTP服务。启用默认站点:确保在配置文件中启用了默认的站点配置。此外,根据您的需求,您可能还需要进一步配置Apache的其他功能和模块。在配置文件中,您可以进行各种设置以定义您的静态HTTP服务的行为。指令,以定义适当的权限和设置。例如,确保目录的权限设置为适当的读/写/执行权限。指令设置为包含您的静态文件的目录路径。_centos还能用服务器吗
文章浏览阅读676次,点赞71次,收藏64次。简单几步实现在Linux centos环境下安装部署sql server数据库,并结合cpolar内网穿透工具,创建安全隧道将其映射到公网上,获取公网地址,实现在外异地远程连接家里/公司的sqlserver数据库,而无需公网IP,无需设置路由器,亦无需云服务器。
文章浏览阅读5.5k次。在 CentOS 7 中,可以通过以下步骤来开放指定端口号:1、使用 root 或具有管理员权限的用户登录到 CentOS 7 服务器。2、使用防火墙管理工具 firewalld 进行端口开放。 firewalld 是 CentOS 7 默认的防火墙管理工具。3、检查当前防火墙的状态,确保 firewalld 服务已经运行并且正常工作。可以使用以下命令来检查:_centos7开放端口