使用PHP5和MySQL在Fedora 20(LAMP)上安装Apache2
LAMP是L inux, A pache, M ySQL, P HP的缩写。 本教程将介绍如何在具有PHP5支持(mod_php)和MySQL支持的Fedora 20服务器上安装Apache2 Web服务器。
我不会保证这将为您工作!
1初步说明
在本教程中,我使用IP地址为192.168.0.100
的hostname server1.example.com
。 这些设置可能会有所不同,因此您必须在适当的情况下更换它们。
2安装MySQL / MariaDB 5
要安装MySQL,我们这样做:
yum install mysql mysql-server
然后,我们为MySQL创建系统启动链接(以便每当系统启动时,MySQL自动启动)并启动MySQL服务器:
systemctl enable mysqld.service
注意:如果你收到这样的错误
Failed to issue method call: No such file or directory
然后使用
systemctl enable mariadb.service
进一步启动mysql的服务
systemctl start mysqld.service
跑
mysql_secure_installation
为用户root
设置密码(否则任何人都可以访问您的MySQL数据库!):
[root @ server1〜]#mysql_secure_installation
/ usr / bin / mysql_secure_installation:行379:find_mysql_client:命令未找到
注意:运行本脚本的所有部分都是为所有MariaDB推荐的
服务器生产使用!
请仔细阅读每一步!
为了登录到MariaDB来保护它,我们需要当前的
root用户的密码。
如果你刚刚安装了MariaDB,
您还没有设置root密码,密码将为空,
所以你应该刚刚进入这里。
输入root的当前密码(输入无):
< - ENTER
OK,成功使用密码,移动...
设置root密码确保没有人可以登录到MariaDB
root用户没有正确的授权。
设置root密码?
[Y / n]
< - ENTER
新密码:
< - yourrootsql 密码
重新输入新密码:
< - yourrootsqlpassword
密码更新成功!
重新载入特权表..
...成功!
默认情况下,MariaDB安装有一个匿名用户,允许任何人
登录到MariaDB,而不必创建用户帐户
他们。
这仅适用于测试和进行安装
顺利一点
你应该删除它们,然后再进入
生产环境。
删除匿名用户?
[Y / n]
< - ENTER
...成功!
通常,root只能被允许从'localhost'连接。
这个
确保有人无法从网络的root密码猜测。
禁止root登录远程?
[Y / n]
< - ENTER
...成功!
默认情况下,MariaDB带有一个名为“test”的数据库,任何人都可以
访问。
这也仅用于测试,应该删除
在进入生产环境之前。
删除测试数据库并访问它?
[Y / n]
< - ENTER
- 删除测试数据库...
...成功!
- 删除测试数据库的权限...
...成功!
重新加载权限表将确保所有更改到目前为止
将立即生效。
现在重新加载权限表?
[Y / n]
< - ENTER
...成功!
打扫干净...
全做完了!
如果您已完成上述所有步骤,您的MariaDB
安装应该是安全的。
感谢您使用MariaDB!
[root @ server1〜]#
3安装Apache2
Apache2可以作为Fedora软件包使用,因此我们可以这样安装它:
yum install httpd
现在配置您的系统启动Apache启动时...
systemctl enable httpd.service
...并启动Apache:
systemctl start httpd.service
现在直接浏览器到http://192.168.0.100
,你应该看到Apache2占位符页面:
Apache的默认文件根是Fedora上的/ var / www / html
,配置文件是/etc/httpd/conf/httpd.conf
。 其他配置存储在/etc/httpd/conf.d/
目录中。
4安装PHP5
我们可以安装PHP5和Apache PHP5模块,如下所示:
yum install php
之后我们必须重新启动Apache:
systemctl restart httpd.service
5测试PHP5 /获取有关您的PHP5安装的详细信息
默认网站的文档根目录是/ var / www / html
。 我们现在将在该目录中创建一个小型的PHP文件( info.php
),并在浏览器中调用它。 该文件将显示有关我们的PHP安装的许多有用的细节,例如安装的PHP版本。
vi /var/www/html/info.php
<?php phpinfo(); ?> |
现在我们在浏览器中调用该文件(例如http://192.168.0.100/info.php
):
如您所见,PHP5正在工作,它正在通过Apache 2.0处理程序
,如Server API
行所示。 如果您进一步向下滚动,您将看到在PHP5中已启用的所有模块。 MySQL没有列出,这意味着我们还没有在PHP5中支持MySQL。
6在PHP5中获取MySQL支持
要在PHP中获得MySQL支持,我们可以安装php-mysql
包。 安装一些其他PHP5模块是一个好主意,您可能需要它们用于应用程序。 您可以搜索可用的PHP5模块,如下所示:
yum search php
选择您需要的并安装它们:
yum install php-mysqlnd php-mssql php-opcache
现在重新启动Apache2:
systemctl restart httpd.service
现在在您的浏览器中重新加载http://192.168.0.100/info.php
并再次向下滚动到模块部分。 您现在应该会在那里找到很多新的模块,包括MySQL模块:
7 phpMyAdmin
phpMyAdmin是一个Web界面,您可以通过它来管理MySQL数据库。
phpMyAdmin可以安装如下:
yum install phpmyadmin
现在我们配置phpMyAdmin。 我们更改Apache配置,以便phpMyAdmin不仅允许从localhost连接(通过注释<Directory / usr / share / phpMyAdmin />
节中的所有内容
,并添加所有必需条件
):
vi /etc/httpd/conf.d/phpMyAdmin.conf
# phpMyAdmin - Web based MySQL browser written in php
#
# Allows only localhost by default
#
# But allowing phpMyAdmin to anyone other than localhost should be considered
# dangerous unless properly secured by SSL
Alias /phpMyAdmin /usr/share/phpMyAdmin
Alias /phpmyadmin /usr/share/phpMyAdmin
<Directory /usr/share/phpMyAdmin/>
# <IfModule mod_authz_core.c>
# # Apache 2.4
# <RequireAny>
# Require ip 127.0.0.1
# Require ip ::1
# </RequireAny>
# </IfModule>
# <IfModule !mod_authz_core.c>
# # Apache 2.2
# Order Deny,Allow
# Deny from All
# Allow from 127.0.0.1
# Allow from ::1
# </IfModule>
Require all granted
</Directory>
<Directory /usr/share/phpMyAdmin/setup/>
<IfModule mod_authz_core.c>
# Apache 2.4
<RequireAny>
Require ip 127.0.0.1
Require ip ::1
</RequireAny>
</IfModule>
<IfModule !mod_authz_core.c>
# Apache 2.2
Order Deny,Allow
Deny from All
Allow from 127.0.0.1
Allow from ::1
</IfModule>
</Directory>
# These directories do not require access over HTTP - taken from the original
# phpMyAdmin upstream tarball
#
<Directory /usr/share/phpMyAdmin/libraries/>
Order Deny,Allow
Deny from All
Allow from None
</Directory>
<Directory /usr/share/phpMyAdmin/setup/lib/>
Order Deny,Allow
Deny from All
Allow from None
</Directory>
<Directory /usr/share/phpMyAdmin/setup/frames/>
Order Deny,Allow
Deny from All
Allow from None
</Directory>
# This configuration prevents mod_security at phpMyAdmin directories from
# filtering SQL etc. This may break your mod_security implementation.
#
#<IfModule mod_security.c>
# <Directory /usr/share/phpMyAdmin/>
# SecRuleInheritance Off
# </Directory>
#</IfModule> |
重新启动Apache:
systemctl restart httpd.service
之后,您可以访问http://192.168.0.100/phpmyadmin/下的phpMyAdmin
:
8链接
- Apache: http : //httpd.apache.org/
- PHP: http : //www.php.net/
- MySQL: http : //www.mysql.com/
- Fedora: http : //fedoraproject.org/
- phpMyAdmin: http : //www.phpmyadmin.net/