在CentOS 7(LAMP)上安装Apache,PHP和MySQL

本教程介绍如何在具有PHP5支持(mod_php)和MySQL支持的CentOS 7.0服务器上安装Apache2 Web服务器。 LAMP是L的缩写...

在CentOS 7(LAMP)上安装Apache,PHP和MySQL

本教程将介绍如何在具有PHP5支持(mod_php)和MySQL支持的CentOS 7.0服务器上安装Apache2 Web服务器。 LAMP是L inux, A pache, M ySQL, P HP的缩写。

1初步说明

在本教程中,我使用IP地址为192.168.0.100的hostname server1.example.com 。 这些设置可能会有所不同,因此您必须在适当的情况下更换它们。

我会在这里添加EPEL repo来安装最新的phpMyAdmin,如下所示:

rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY*
yum -y install epel-release

2安装MySQL / MariaDB

MariaDB是原始MySQL开发人员Monty Widenius的MySQL分支。 MariaDB与MySQL兼容,我选择使用MariaDB而不是MySQL。 要安装MySQL,我们这样安装MariaDB:

yum -y install mariadb-server mariadb

然后,我们为MySQL创建系统启动链接(以便每当系统启动时,MySQL自动启动)并启动MySQL服务器:

systemctl start mariadb.service
systemctl enable mariadb.service

设置MySQL根帐户的密码:

mysql_secure_installation

[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密码? [是/否]
新密码: < - yourmariadbpassword
重新输入新密码: < - yourmariadbpassword
密码更新成功!
重新载入特权表..
...成功!


默认情况下,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

CentOS 7附带apache 2.4。 Apache2可以直接作为CentOS 7.0软件包使用,因此我们可以这样安装:

yum -y install httpd

[root @ server1〜]#yum install httpd
加载插件:fastestmirror,langpacks
从缓存的主机文件加载镜像速度
* base:ftp.plusline.de
* extras:mirror.23media.de
*更新:mirror.23media.de
软件包httpd-2.4.6-17.el7.centos.1.x86_64已经安装和最新版本
没事做
[root @ server1〜]#

默认情况下会安装apache,如果没有,请安装如上所示

现在配置您的系统启动Apache启动时...

systemctl start httpd.service

systemctl enable httpd.service

在CentOS 7.0中使用Firewall-cmd,因此我将自定义它以允许外部访问端口80 (http)和443 (https)。

firewall-cmd --permanent --zone=public --add-service=http
firewall-cmd --permanent --zone=public --add-service=https
firewall-cmd --reload

现在直接浏览器到http://192.168.0.100 ,你应该看到Apache2占位符页面:

4安装PHP5

我们可以安装PHP5和Apache PHP5模块,如下所示:

yum -y 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 -y install php-mysql

在下一步中,我将安装CMS系统所需的一些常见PHP模块,例如Wordpress,Joomla和Drupal:

yum -y install php-gd php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-snmp php-soap curl curl-devel

现在重新启动Apache2:

 systemctl restart httpd.service

现在在您的浏览器中重新加载http://192.168.0.100/info.php并再次向下滚动到模块部分。 你现在应该找到很多新的模块,如Curl等。

7 phpMyAdmin安装

phpMyAdmin是一个Web界面,您可以通过它来管理MySQL数据库。
phpMyAdmin现在可以安装如下:

yum install phpMyAdmin

现在我们配置phpMyAdmin。 我们更改Apache配置,以便phpMyAdmin允许连接不仅来自localhost(通过注释<Directory“ / usr / share / phpmyadmin ”>节):

vi /etc/httpd/conf.d/phpMyAdmin.conf

[...]
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> #</Directory> <Directory /usr/share/phpMyAdmin/> Options none AllowOverride Limit Require all granted </Directory>

[...]

接下来,我们将phpMyAdmin中的身份验证从cookie更改为http

vi /etc/phpMyAdmin/config.inc.php

[...]
$cfg['Servers'][$i]['auth_type']     = 'http';    // Authentication method (config, http or cookie based)?
[...]

重新启动Apache:

systemctl restart  httpd.service

之后,您可以访问http://192.168.0.100/phpmyadmin/下的phpMyAdmin


Apache: http : //httpd.apache.org/
PHP: http : //www.php.net/
MySQL: http : //www.mysql.com/
CentOS: http : //www.centos.org/
phpMyAdmin: http : //www.phpmyadmin.net/