使用PHP5和MySQL支持安装Apache2 Fedora 20(LAMP)

使用PHP5和MySQL支持安装Apache2 Fedora 20(LAMP) LAMP是Linux,Apache,MySQL,PHP的缩写。本教程将介绍如何使用

使用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