翻译自:https://www.howtoforge.com/tutorial/install-apache-with-php-and-mysql-on-ubuntu-16-04-lamp/php
昨天在虚拟机里面安装ubuntu server ,而后配置php开发环境,参考了这篇文章,一次性把全部的东西都安装配置好了,因此想把这篇文章记录下来。但愿可以帮助到初学者一次性搞定这些配置(避免纠结),而后就能够愉快地编程了,嘿嘿。html
如下是我翻译的内容,彻底对照原文,没有本身改动的部分(由于原文已经很完美了):mysql
LAMP 是 Linux,Apache,MySQL,PHP的缩写。本文教你如何在 ubuntu 16.04(Xenial Xerus) server 上安装 Apache2,PHP7(mod_php)和MySQL。此外,还将安装 PHPMyAdmin 工具用于管理 MySQL。web
本文中,我使用 server1.example.com 做为主机名,IP为:192.168.1.100。你若是跟我不一样,在相应的地方替换就好了。sql
我推荐使用 minimal Ubuntu server 做为本文操做的基础。shell
我在root权限下运行全部的命令,因此确保你使用的是root帐户:数据库
sudo su
我安装的是 MariaDB 而不是 MySQL。MariaDB 是 MySQL 的做者 Monty Widenius 所维护的 MySQL 分支版本。MariaDB 兼容 MySQL,而且增长了功能,提升了性能。运行下面的命令来安装 MariaDB-server 和 client:apache
apt-get install mariadb-server mariadb-client
而后设置 MariaDB 的 root 密码:编程
mysql_secure_installation
而后,出现一些提示,按照红色提示来操做就好了:ubuntu
Enter current password for root (enter for none): <-- press enter Set root password? [Y/n] <-- y New password: <-- Enter the new MariaDB root password here Re-enter new password: <-- Repeat the password Remove anonymous users? [Y/n] <-- y Disallow root login remotely? [Y/n] <-- y Reload privilege tables now? [Y/n] <-- y
使用 mysql 命令测试是否能登陆 MariaDB:
mysql -u root -p
再输入上面设置 root 密码,就会出现以下所示:
要离开 MariaDB shell,输入 quit 和 回车键就好了。
Apache 2 能够直接从 Ubuntu 包中获取,只要这样:
apt-get install apache2
如今打开浏览器,输入 http://192.168.1.100,就能看到 Apache 2 默认页面:
apache 默认文章根目录是 /var/www/html,其主要配置文件为:/etc/apache2/apache2.conf。其配置系统的说明文档在 /usr/share/doc/apache2/README.Debian.gz.
安装 PHP 7 和 Apache PHP 模块:
apt-get install php7.0 libapache2-mod-php7.0
而后重启 Apache
systemctl restart apache2
默认web站点的文档根目录是 /var/www/html ,我在该目录建立一个info.php文件,而后在浏览器中访问它。这个文件可以显示有关PHP安装的详细信息。
vim /var/www/html/info.php
输入文件内容:
<?php
phpinfo();
改变info.php文件的全部者为 www-data 用户和组
chown www-data:www-data /var/www/html/info.php
如今咱们能够在浏览器中访问 http://192.168.1.100/info.php,结果以下图所示:
如你所看到的,PHP7.0 正在运行,从 Server API 行能够看出,它是经过 Apache 2.0 Handler 运行的,继续向下滚动页面,你就看见全部已经启用的模块。MySQL并不在其中,这是由于咱们尚未对PHP添加MySQL/MariaDB支持。
为了使 PHP 支持 MySQL,能够安装 php7.0-mysql 包。同时也能够安装其余所须要的 PHP 模块,使用下面命令来搜索可用的 PHP 模块:
apt-cache search php7.0
选择一些模块,安装之:
apt-get -y install php7.0-mysql php7.0-curl php7.0-gd php7.0-intl php-pear php-imagick php7.0-imap php7.0-mcrypt php-memcache php7.0-pspell php7.0-recode php7.0-sqlite3 php7.0-tidy php7.0-xmlrpc php7.0-xsl php7.0-mbstring php-gettext
重启 Apache2
systemctl restart apache2
如上图所示,PHP已经启用了 MySQL/MariaDB 支持。
APCu 是一个免费的 PHP opcode cacher 用来缓存和优化 PHP 中间代码。推荐安装它来加速PHP速度。
安装:
apt-get install php-apcu
重启 Apache:
systemctl restart apache2
刷新一下 http://192.168.1.100/info.php,看到 apcu 模块:
请删除info.php文件,它会显示你服务器的敏感信息。运行下面的命令来删除:
rm -f /var/www/html/info.php
SSL/TLS 是一个安全层,用于加密浏览器与服务器之间的链接。使用下面的命令以启用 https:// 支持
a2enmod ssl
a2ensite default-ssl
这两行命令启用了 ssl 模块,并在 /etc/apache2/sites-enabled 文件夹中添加了 /etc/apache2/sites-available/default-ssl.conf 的连接,以将其包括到apache 配置之中。而后重启apache来启用新配置:
systemctl restart apache2
如今浏览器打开 https://192.168.1.100,看到:
你看到了一个 SSL 警告:该服务器的 SSL 证书 是 “本身颁发给本身的”,这表示浏览器不信任该证书,因此你必须先接受安全警告,而后才能打开apache 默认页面:
浏览器地址栏URL前面的 “绿色的锁”代表链接是通过加密的。要想解除 SSL 警告,能够从 SSL 证书颁发机构得到一个官方签名的SSL证书,而后替换默认自带的证书:/etc/ssl/certs/ssl-cert-snakeoil.pem。
经过phpMyAdmin能够操做MySQL数据库。安装命令:
apt-get install phpmyadmin
而后看到这些提示,按照红色提示输入就好了:
Web server to configure automatically: <-- Select the option: apache2 Configure database for phpmyadmin with dbconfig-common? <-- Yes MySQL application password for phpmyadmin: <-- Press enter, apt will create a random password automatically.
MariaDB 默认为root用户启用了“unix_socket”插件,这个插件会阻止root用户登陆phpmyadmin和root用户到MySQL的TCP链接。所以,使用命令禁用了它:
echo "update user set plugin='' where User='root'; flush privileges;" | mysql -u root -p mysql
而后输入 MariaDB root 密码。
以后,你就能够经过 http://192.168.1.100/phpmyadmin/ 来访问:
另外,说明一些操做过程当中可能会遇到的问题以及解决办法。
(1)安装完访问 phpmyadmin 时,出现错误:The reqeusted URL /phpmyadmin was not found on this server
个人解决办法在这里:连接
(2)成功打开phpmyadmin 以后,输入用户名和密码