apache配置php linux centos7安装php环境
linux下配置apache同时支持 php cgi
安装LINUX时如果安装了PERL那么装上LINUX立刻可以执行CGI只要在HTTPD.CONF里面允许了CGI一般默认安装都可以
PHP你到php.net下载PHP编译安装后修改HTTPD.CONF添加相关扩展就可以了
------------------------------------------------------------
说得比较不详细转一个帖
------------------------------------------------------------
Linux+Apache+Mysql+PHP典型配置
版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本声明
关键字:apache+mysql+php apache mysql php配置 lamp服务器 web
Linux+Apache+Mysql+PHP典型配置
调试环境:Redhat9.0 Apache1.3.29 Mysql3.23.58 PHP4.3.4
Linux系统的安装我就不讲了,这是基本功,其实这篇文章在类似Redhat的其他linux也应该通用,大家只要掌握我提供的方法就行。记得安装Redhat9。0的时候不要安装系统默认的apache,mysql和php以及相关的软件。已经安装的请用rpm-e*删除已经安装的包。
1.安装Mysql3.23.58
其实老实说直接安装Mysql官方网站提供的rpm包也是一个比较可行的办法,他的官方网站的rpm包的提供基本跟tar包发行是同步的,这点我比较喜欢,至少安装rpm包的在后面的调试中不会出现mysql库文件找不到的情况。但这里还是有必要讲一下自定义安装的步骤,毕竟网友自定义安装的还说挺多的。
软件获取:
安装步骤:
tar zxvf mysql-3.23.58.tar.gz
cd mysql-3.23.58
./configure--prefix=/usr/local/mysql--sysconfdir=/etc--localstatedir=/var/lib/mysql
make
make install
#prefix=/usr/local/mysql mysql安装的目标目录
#sysconfdir=/etc my.ini配置文件的路径
#localstatedir=/var/lib/mysql数据库存放的路径
安装完以后要初始化数据库,当然你是升级的话不用做这步;
/usr/local/mysql/bin/mysql_install_db
如果系统没有mysql这个用户的话,最好做以下这步:
useradd-M-o-r-d/var/lib/mysql-s/bin/bash-c"MySQL Server"-u 27 mysql
然后我启动mysql
/usr/local/mysql/bin/safe_mysqld&
ok,先看看mysql能否正常工作
mysql-uroot mysql
一般情况下都是不能正常链接数据库,错误提示一般为:
ERROR 2002: Can't connect to local MySQL server through socket'/var/lib/mysql/mysql.sock'(2)
其实网上大家问的最多的都是整个问题,说什么链接不到mysqld.sock,其实大家不妨看看mysql的错误日志就明白怎么回事,我这里的错误日志是在
/var/lib/mysql/*.err你会发现mysql只所以不能启动,是因为/var/lib/mysql的权限不允许mysql服务访问,英文mysql默认是调用mysql用户来启动服务的,好了,既然知道是什么原因找到不能启动,那就简单了。我们只要
chown-R mysql:mysql/var/lib/mysql就行,如果还是启动不了,再慢慢调试权限,反正一般启动不了都是权限的问题。
如果大家还是不能启动不了的话,那就用我的比较繁琐的权限的设置,反正我每次都是这么做的,一般不会有问题,见下:
chown-R root/usr/local/mysql
chgrp-R mysql/usr/local/mysql
chown-R root/usr/local/mysql/bin
chgrp-R mysql/usr/local/mysql/bin
chgrp-R mysql/var/lib/mysql
chmod 777/var/lib/mysql
chown-R root/var/lib/mysql/mysql
chgrp-R mysql/var/lib/mysql/mysql
chmod 777/var/lib/mysql/mysql
chown-R root/var/lib/mysql/mysql/*
chgrp-R mysql/var/lib/mysql/mysql/*
chmod 777/var/lib/mysql/mysql/*
chmod 777/usr/local/mysql/lib/mysql/libmysqlclient.a
做完上面的步骤,然后把你编译目录的一个脚本COPY过去
cp support-files/mysql.server/etc/rc.d/init.d/mysqld
chkconfig--add mysqld
用ntsysv设置使mysql每次启动都能自动运行。
好了,至此mysql安装完毕,你可以这样起动你的mysql服务
/etc/rc.d/init.d/mysqld start
下面这步比较关键,
ln-s/usr/local/mysql/lib/mysql/usr/lib/mysql
ln-s/usr/local/mysql/include/mysql/usr/include/mysql
大家可以不做这步,大可以在编译其他软件的时候自定义myslq的库文件路径,但我还是喜欢把库文件链接到默认的位置,这样你在编译类似PHP,Vpopmail等软件时可以不用指定mysql的库文件地址。
2.安装Apache1.3.29。我没有选择安装Apache2.0是我对他还是不放心,因为网上最新公布的apache的漏洞基本上是针对2.0,当然大家可以自己选择安装相应的版本。我这里讲的都是采用DSO动态编译的方法编译Apache.
至于有关apache的编译方法,可以参考我以前的文章《apache的静态/动态编译在apache+php+mysql的应用》
软件获取:
tar zvxf apache_1.3.29.tar.gz
cd apache_1.3.29
修改src/include/httpd.h增大最大线程数
#define HARD_SERVER_LIMIT 256
改成
#define HARD_SERVER_LIMIT 2560
保存退出编译apache
./configure--prefix=/usr/local/apache--enable-module=so--enable-module=rewrite--enable-shared=max--htdocsdir=/var/www&&
make&&
make install
#这里我们通过enable-module参数告诉设置脚本,我们需要启动so和rewrite模块,so模块是用来提DSO支持的apache核心模块,而rewrite模块则是用意实现地址重写的模块,由于rewrite模块需要DBM支持,如果在初次安装时没有编译进apache,以后需要用到时需要重新编译整个apache才可以实现。为此除非你可以确定以后不会用到rewrite模块,否则还是建议你在第一次编译的时候把rewrite模块编译好。
enable-shared=max这个参数的作用时编译apache时,把除了so以外的所有apache的标准模块都编译成DSO模块。而不是编译进apache核心内。
好了安装apache很简单的哦,启动apache看看
/usr/local/apache/bin/apachectl start
然后用ie看http://你的服务器地址。应该能看到熟悉的apache羽毛标志。
3.安装PHP4.3.4
软件获取:
tar zvxf php-4.3.4.tar.gz
cd php-4.3.4
./configure\
--prefix=/usr/local/php\
--with-mysql=/usr/local/mysql\
--enable-force-cgi-redirect\
--with-freetype-dir=/usr\
--with-png-dir=/usr\
--with-gd--enable-gd-native-ttf\
--with-ttf\
--with-gdbm\
--with-gettext\
--with-iconv\
--with-jpeg-dir=/usr\
--with-png\
--with-zlib\
--with-xml\
--enable-calendar\
--with-apxs=/usr/local/apache/bin/apxs
make
make install
#我这里由于服务器需要用到GD库,所以加了一些支持GD的编译参数,GD直接用了redhat自带的GD库,大家没有安装的话可以从安装盘安装,注意除了安装GD以外,还要安装libjpeg,libpng等库文件。另外--with-mysql=/usr/local/mysql指向你安装mysql的路径。--with-apxs指向apache的apxs文件的路径。
vi/usr/local/apache/conf/httpd.conf
查找
在此范围添加
AddType application/x-httpd-php.php
AddType application/x-httpd-php-source.phps
然CPOPY PHP的配置文件
cp../php4.3.4/php.ini.dist/usr/local/php/lib/php.ini
修改php.ini文件
register_globals= On
ok!重新启动一下apache服务器
/usr/local/apache/bin/apachectl restart
然后写个php测试页info.php:内容如下
<?php
phpinfo();
?>
正常的话,应该能看到php的信息了,恭喜你的Apche+Mysql+PHP安装成功。
好了写了这么多,希望对大家有所帮助!!!
apache如何配置phpapache如何配置php
+apache如何部署php
将你的apache的网站发布到你本机网卡的地址上,然后让处于同一网段内的另一台电脑访问你作为服务器这个电脑的ip即可
注意端口号
1、保证你的apache能正常启动,然后打开httpd.conf那个配置文件,检查一下Listen服务器端口,默认监听端口为80,不是就改成80
2、配置服务器根目录权限
Directoryc:/www/>
OptionsIndexesFollowSymLinks
AllowOverrideall
OrderDeny,Allow
Allowfromall
/Directory>
注意“c:/www/”为你网站根目录。重点是Allowfromall,否则访问不进去
3、配置虚拟主机
VirtualHost192.168.11.108>
ServerName192.168.11.108
DocumentRootc:/www/test/
/VirtualHost>
注意VirtualHost与ServerName一致,除非你有DNS主机。这个ip是我本机的,你要改成你机器的ip,如果不会查IP另
如何搭建php服务器?
你应该是想问wampserver吧,wamp软件是个统称,代表Windows下的Apache+Mysql+PHP,称为
WAMP
。
属于WAMP环境的集成软件有很多,比如wampserver、PHPWAMP、apmserv、xampp等等
推荐你使用功能更加强大的
纯绿色集成环境PHPWAMP
(集成了VC,而且所集成组件未阉割,完整版适合本地也适合服务器),
700个PHP版本随时切换,能自定义任何版本
,可以多个PHP版本同时使用,要是你有时候因为某些原因非得使用非80端口搭建网站,还能一键去除域名端口号!一键能强制修改任意环境的mysql数据库,功能太多了,我不说了,你自己看看吧
php服务器配置都需要什么?
是指服务器软件还是配置文件?常用服务器环境配置:Apache+php+MySQL基本设置(需修改配置文件)假设你安装的都是官方提供的版本,且版本都正确的前提下:
1、在Apache配置文件httpd.conf里加载php模块即可。
2、设置php里的php.ini文件,基本上设置下扩展的路径即可。
3、MySQL安装好之后通过向导一步步完成设置即可,这里有一个密码设置,不要忘记了。如果安装了MySQL,可以下载一个工具NavicatLite,很好用,提供了一个可视化的界面来操作数据库。
详解配置Apache服务器支持PHP文件的解析?
没有加载PHP模块或者是MIME类型没填对,PHP文件被当成了纯文本文件提供下载而不执行里面的代码。
Apache本身是不具备执行PHP代码的能力的,需要把PHP当成Apache的一个模块来加载来解析PHP文件。
你看看apache的配置文件httpd.conf是否有类似的内容,C:/php-5.3.5是我电脑上的PHP安装目录,你要改成自己电脑的路径#添加PHP模块LoadModulephp5_moduleC:/php-5.3.5/php5apache2_2.dll#指定PHP程序的根目录PHPIniDirC:/php-5.3.5#添加MIME映射,让apache把PHP文件当成代码文件来执行AddTypeapplication/x-httpd-php.php.phtml感觉LZ是初学者,不会配置PHP运行环境的话,建议你搜一下XAMPP,这个是Linux下的PHP傻瓜包,直接把Apache,PHP,MYSQL等全部自动部署好了。
如何集成Linux、Apache、PHP4、FastCGI、Oracle、MySQL环境
一.准备工作要实现将Linux/Apache/PHP4/FastCGI/Oracle/MySQL环境集成,必需先准备好以下软件包:(一)数据库的Perl接口 1.perl5的Oracle数据库DBI驱动程序:DBD-Oracle-1.03.tar.gz 2.perl5的通用数据库接口程序:DBI-1.13.tar.gz 3.perl5的MySQL数据库DBI驱
一.准备工作
要实现将Linux/Apache/PHP4/FastCGI/Oracle/MySQL环境集成,必需先准备好以下软件包:
(一)数据库的Perl接口
1.perl5的Oracle数据库DBI驱动程序:DBD-Oracle-1.03.tar.gz
2.perl5的通用数据库接口程序:DBI-1.13.tar.gz
3.perl5的MySQL数据库DBI驱动程序:Msql-Mysql-modules-1.2209.tar.gz
(二)Oracle数据库
4.Oracle 8iR2(8.1.6) for Linux安装盘:oracle8161.tar.gz
(三)MySQL数据库
5.MySQL 3.22.32服务器程序包:MySQL-3.22.32-1.i386.rpm
6.MySQL客户端程序包:MySQL-client-3.22.32-1.i386.rpm
7.MySQL开发包(头文件/库文件):MySQL-devel-3.22.32-1.i386.rpm
8.MySQL共享库程序包:MySQL-shared-3.22.32-1.i386.rpm
(四)Apache服务器
9.Apache 1.3.12源码包:apache_1.3.12.tar.gz
(五)PHP模块
10.PHP 4.0.0源码包:php-4.0.0.tar.gz
(六)FastCGI模块
11.FastCGI模块源码包:mod_fastcgi_2.2.4.tar.gz
12.FastCGI的perl开发模块:FCGI-0.53.tar.gz共5页。
二.安装Oracle客户端
由于Oracle 8.1.6是在XWindows下安装的,所以必须是事先配置好XWindow,如果你的显卡不支持XWindow,也可以用exceed进行远程安装(这里不提远程如何安装)。
在此简单列出操作过程:
(一)设置环境变量:
在/etc/profile中加入:
export ORACLE_HOME=/opt/oracle8i/u01
export ORACLE_BASE=/opt/oracle8i
export ORACLE_OWNER=oracle
export ORACLE_SID=ORCL
export ORACLE_TERM=ansi
export PATH=$PATH:$ORACLE_HOME/bin
export LD_LIBRARY_PATH=$ORACLE_HOME/lib
export ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data
export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16CGB231280"
(二)建立oracle组和用户
#/usr/sbin/groupadd dba
#/usr/sbin/useradd-g dba oracle
#/usr/bin/passwd oracle
(三)创建$ORACLE_HOME目录
#mkdir/opt
#mkdir/opt/oracle8i
#mkdir/opt/oracle8i/u01
#chown-R oracle.dba/opt
(四)安装reacle 8iR2
以oracle用户登录,解开Oracle安装包:
$tar zxvf oracle8161.tar.gz
$startx启动XWindow界面,并打开一个rxvt终端窗口
$cd Oracle8iR2
$./runInstaller
此时出现Oracle安装界面,在安装时选择安装client/Application User(如果Oracle服务器不在本机上运行,另有专用机器),安装完毕后配置SQL*Net8并测试连接远程服务器通过即可。共5页。
三.安装MySQL服务器和客户端
以root身分进入,安装MySQL各个包:
#rpm-ivh MySQL-3.22.32-1.i386.rpm
#rpm-ivh MySQL-client-3.22.32-1.i386.rpm
#rpm-ivh MySQL-devel-3.22.32-1.i386.rpm
#rpm-ivh MySQL-shared-3.22.32-1.i386.rpm
四.安装Perl的数据库接口模块
以root身分进入,然后执行:
#tar zxvf DBI-1.13.tar.gz
#cd DBI-1.13
#perl Makefile.PL
#make
#make test
#make install
#cd..
#rm-rf DBI-1.13
#
#tar zxvf DBD-Oracle-1.03.tar.gz
#cd DBD-Oracle-1.03
#perl Makefile.PL
#make
#make test
#make install
#cd..
#rm-rf DBD-Oracle-1.03
#
#tar zxvf Msql-Mysql-modules-1.2209.tar.gz
#cd Msql-Mysql-modules-1.2209
#perl Makefile.PL
选择1(MySQL)和y(支持Mysql.pm)
#make
#make test
#make install
#
五.安装Apache+PHP+FastCGI
(一)解开Apache/PHP/FastCGI包:
#tar zxvf apache_1.3.12.tar.gz
#tar zxvf php-4.0.0.tar.gz
#tar mod_fastcgi_2.2.4.tar.gz
(二)编译PHP4
配置apache编译参数
#cd apache_1.3.12
#./configure--prefix=/usr/local/apache
配置PHP编译参数
#cd../php-4.0.0
#./configure--with-apache=../apache_1.3.12
>--with-mysql
>--with-oracle=$ORACLE_HOME
>--with-oci8=$ORACLE_HOME
>--enable-track-vars
编译PHP模块:
#make
#make install
创建php.ini参数文件
#cp php.ini-dist/usr/local/lib/php.ini
#cd..
(三)添加FastCGI模块:
#mv mod_fastcgi_2.2.4 apache_1.3.12/src/modules/fastcgi
(四)编译安装Apache
#cd apache_1.3.12
配置编译参数
#./configure--prefix=/usr/local/apache
>--activate-module=src/modules/php4/libphp4.a
>--activate-module=src/modules/fastcgi/libfastcgi.a
编译Apache
#make
安装Apache
#make install
(五)关闭原有系统自带的Apache
#/etc/rc.d/init.d/httpd stop共5页。
(六)配置Apache自身参数:
1.编辑/usr/local/apache/conf/httpd.conf文件,修改以下参数:
ServerName host.mydomain.name
DocumentRoot"/home/httpd/html"
Options Indexes FollowSymLinks MultiViews Includes
AllowOverride None
Order allow,deny
Allow from all
ScriptAlias/cgi-bin/"/home/httpd/cgi-bin/"
AllowOverride None
Options None
Order allow,deny
Allow from all
DirectoryIndex index.html index.phtml index.php index.htm index.shtml index.fcgi
2.修改自启动链接
#cd/etc/rc.d/init.d
#ln-fs/usr/local/apache/bin/apachectl httpd
(七)配置PHP4.0参数:
1.修改/usr/local/apache/conf/httpd.conf文件,,修改以下参数:
增加一行:AddType application/x-httpd-php.php.phtml.php3
2.修改/usr/local/apache/bin/apachectl脚本,使启动支持中文ORACLE环境:
在文件中66行("start)")下面加入几行:
export ORACLE_HOME=/opt/oracle8i/u01
export ORACLE_BASE=/opt/oracle8i
export ORACLE_SID=ORCL
export LD_LIBRARY_PATH=$ORACLE_HOME/lib
export ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data
export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16CGB231280"
3.修改/usr/local/apache/conf/srm.conf以在CGI程序中使用环境变量:
PassEnv ORACLE_HOME
PassEnv ORACLE_BASE
PassEnv LD_LIBRARY_PATH
PassEnv NLS_LANG
PassEnv ORACLE_SID
PassEnv PATH
(八)配置FastCGI执行环境:
1.修改/usr/local/apache/conf/httpd.conf文件,修改以下参数:
增加几行:
############ FastCGI Configures Begin##########################
AddHandler fastcgi-script.fcg.fcgi.fpl
SetHandler fastcgi-script
Order deny,allow
Allow from all
Options ExecCGI Indexes Includes
############### FastCGI Configure End###########################
2.创建fcgi的执行目录
#mkdir/home/httpd/html/fcgi
3.安装FCGI的Perl运行模块:
#tar zxvf FCGI-0.53.tar.gz
#cd FCGI-0.53
#perl Makefile.PL
#make
#make install共5页。
六.启运并测试
1.启动Apache服务器:
#/etc/rc.d/init.d/httpd start
2.编写PHP测试程序:
第一个测试程序:/home/httpd/html/t1.php;
第二个测试PHP与Oracle连接的PHP程序(表已经建好):查看是否为中文输出;
第三个测试PHP与MySQL连接的PHP程序(表已经建好)。
3.编写FastCGI的测试代码:/home/httpd/html/fcgi/test.fcgi
#!/usr/bin/perl
use FCGI;
use DBI;
$dbname="oracle";
$user="user";
$passwd="password";
$dbh="";
while(FCGI::accept()>=0){
&parse_form();
$id=$FORM;
$para=$FORM;
print"Content-type: text/html";
print"";
if(!$dbh){
print"no oracle, need to connect";
$dbh= DBI->connect("dbi:Oracle:$dbname",$user,$passwd);
}else{
print"OK, oracle aleady connected";
}
$sth=$dbh->prepare("select name from testtable where id=15");
$sth->execute;
@recs=$sth->fetchrow_array;
$sth->finish;
print"参数id=".$id." and my name is@recs[0]";
print"参数para=".$para."";
}
####传入参数处理部分#######
sub parse_form{
my($buffer);
my($pairs);
my(@pairs);
my($name);
my($value);
my$meth=$ENV;
if($meth eq"GET"||$meth eq"HEAD"){
$buffer=$ENV;
}
elsif($meth eq"POST"){
read(STDIN,$buffer,$ENV);
}
undef%FORM;
@pairs= split(/&/,$buffer);
foreach$pair(@pairs){
($name,$value)= split(/=/,$pair);
$value=~ tr/+//;
$value=~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C", hex())/eg;
$value=~ s///g;
if($allow_html!= 1){
$value=~ s/]|)*>//g;
}
$FORM=$value;
}
}
测试看看FastCGI是否正常执行了。