LEMP 指的是 Linux + Nginx (发音 engine x 所以这里是 E 而不是 N) + MySQL + PHP 的简称,国内有些地方叫做 LNMP (因为 LNMP 没法读出来,而 LEMP 可以直接发音,所以今后本站教程一律都会写 LEMP)
以下操作推荐在 root 用户下完成,请使用 sudo -i
切换到 root 用户进行操作
一、安装 Nginx 1.10.x 或 1.12.x
由于 Nginx 更新频繁,而 Ubuntu Server 长久以来一直更新缓慢没法支持新功能,所以我们有两种方案。
截止 2017 年 5 月 6 日,目前最新的稳定版是 1.12.x 当然次版 1.10.x 也是很稳定的。
1、用 Nginx 官方的 PPA 代替默认的源安装
sudo apt-get install software-properties-common sudo add-apt-repository ppa:Nginx/stable sudo apt-get update sudo apt-get install curl vim wget unzip
如果喜欢体验 Nginx 的新功能,您可以使用 add-apt-repository ppa:Nginx/development
安装 Nginx 的 Mainline 版代替默认的 Stable 版
接着安装 Nginx
sudo apt-get install Nginx
如果您需要 Nginx 更多的功能,您可以使用 sudo apt-get install Nginx-extras
代替默认的 Nginx
PPA 方式更新也未必很及时,如果您希望追求更新的版本,我们可以使用第二种方法
2、使用 Nginx 官方源
首先,下载并导入 Nginx 官方的 Key:
wget http://Nginx.org/keys/Nginx_signing.key sudo apt-key add Nginx_signing.key
修改 /etc/apt/sources.list
文件或新建一个 /etc/apt/sources.list.d/Nginx.list
文件,内容如下:
deb http://Nginx.org/packages/ubuntu/ xenial Nginx deb-src http://Nginx.org/packages/ubuntu/ xenial Nginx
接着就可以更新系统并安装和官网同步的最新版本 Nginx:
sudo apt-get update sudo apt-get install Nginx
需要注意的是,官网的这个版本,安装的插件和 Nginx 配置文件写法和 Ubuntu Server 默认安装以及 PPA 安装的 Nginx 稍有区别,不过足够日常使用。
二、安装 PHP 7.0.x 或 PHP 7.1.x 或 PHP 5.6.x
目前 PHP 官方开发只对这三个版本进行维护。
虽然一些老旧的程序、插件不支持 PHP 7.0.x 或 PHP 7.1.x,但是这货速度确实快不少啊,强烈呼吁开发者渐渐的转移到 PHP 7.0.x 或 PHP 7.1.x 的开发中,至于某些国产程序,就只能呵呵哒。
同样,由于 Ubuntu Server 官方更新实在太慢,导致很多时候没法打上最新的安全补丁,我们这里推荐 Ondřej Surý 的 PPA
sudo add-apt-repository ppa:ondrej/PHP sudo apt-get update
由于 PHP 7.1.x 实在太新,很多程序没办法跟上步伐,但是大多数正常的程序的对 PHP 7.0.x 的支持是很好的,所以本文推荐安装 PHP 7.0.x
如有 PHP 7.1.x 或 PHP 5.6.x 需求的朋友,可以把下面的安装包文件名类似 PHP7.0-fpm
改成 PHP7.1-fpm
或 PHP5.6-fpm
执行完成后,安装一些常见的软件以及 PHP 7.0.x,如果是 wordpress ,那么下面的 PHP 包足够满足大部分你需求:
sudo apt-get install PHP7.0-fpm PHP7.0-MysqL PHP7.0-curl PHP7.0-gd PHP7.0-mbstring PHP7.0-mcrypt PHP7.0-xml PHP7.0-xmlrpc PHP7.0-zip
以上只安装了大部分 wordpress 必须的 PHP 组件,如果您的程序需要额外的 PHP 组件,可以通过 apt-cache search PHP7.0
命令来查找。
showfom@ubuntu:~$ sudo apt-cache search PHP7.0 libapache2-mod-PHP7.0 - server-side,HTML-embedded scripting language (Apache 2 module) PHP-all-dev - package depending on all supported PHP development packages PHP7.0 - server-side,HTML-embedded scripting language (Metapackage) PHP7.0-cgi - server-side,HTML-embedded scripting language (CGI binary) PHP7.0-cli - command-line interpreter for the PHP scripting language PHP7.0-common - documentation,examples and common module for PHP PHP7.0-curl - CURL module for PHP PHP7.0-dev - Files for PHP7.0 module development PHP7.0-gd - GD module for PHP PHP7.0-gmp - GMP module for PHP PHP7.0-json - JSON module for PHP PHP7.0-ldap - LDAP module for PHP PHP7.0-MysqL - MysqL module for PHP PHP7.0-odbc - ODBC module for PHP PHP7.0-opcache - Zend OpCache module for PHP PHP7.0-pgsql - Postgresql module for PHP PHP7.0-pspell - pspell module for PHP PHP7.0-readline - readline module for PHP PHP7.0-recode - recode module for PHP PHP7.0-snmp - SNMP module for PHP PHP7.0-sqlite3 - sqlite3 module for PHP PHP7.0-tidy - tidy module for PHP PHP7.0-xml - DOM,SimpleXML,WDDX,XML,and XSL module for PHP PHP7.0-xmlrpc - XMLRPC-EPI module for PHP libPHP7.0-embed - HTML-embedded scripting language (Embedded SAPI library) PHP7.0-bcmath - Bcmath module for PHP PHP7.0-bz2 - bzip2 module for PHP PHP7.0-enchant - Enchant module for PHP PHP7.0-fpm - server-side,HTML-embedded scripting language (FPM-CGI binary) PHP7.0-imap - IMAP module for PHP PHP7.0-interbase - Interbase module for PHP PHP7.0-intl - Internationalisation module for PHP PHP7.0-mbstring - MBSTRING module for PHP PHP7.0-mcrypt - libmcrypt module for PHP PHP7.0-PHPdbg - server-side,HTML-embedded scripting language (PHPDBG binary) PHP7.0-soap - SOAP module for PHP PHP7.0-sybase - Sybase module for PHP PHP7.0-xsl - XSL module for PHP (dummy) PHP7.0-zip - Zip module for PHP PHP7.0-dba - DBA module for PHP
安装完成后,编辑 /etc/PHP/7.0/fpm/PHP.ini
并替换 ;cgi.fix_pathinfo=1
为 cgi.fix_pathinfo=0
sed -i 's/;cgi.fix_pathinfo=1/cgi.fix_pathinfo=0/' /etc/PHP/7.0/fpm/PHP.ini
然后重启 PHP7.0-fpm
systemctl restart PHP7.0-fpm
三、更新 Nginx 配置
下面开始,我们假设您的域名是 example.com
您的服务器 IP 是 192.0.2.2
(RFC 5737),并且您已经解析 example.com
的 A 记录到您的服务器 IP 192.0.2.2
无论用哪种方法安装 Nginx 他们默认的 Nginx.conf 都指定了加载 /etc/Nginx/conf.d/ 目录下的 *.conf 文件,所以我们直接新建立一个 /etc/Nginx/conf.d/example.conf 并增加一些基本的配置
直接把下面一整行命令复制粘贴到你的终端
sudo cat >> /etc/Nginx/conf.d/example.conf << EOF server { listen 80; listen [::]:80; # 指定网站目录,可根据自己情况更换,建议放在 /var/www 目录下 root /var/www/example.com; index index.PHP index.html index.htm; # 默认第一个域名,替换 example.com 为您的域名 server_name example.com; location / { try_files $uri $uri/ =404; } # 开启 PHP7.0-fpm 模式 location ~ \.PHP$ { include snippets/fastcgi-PHP.conf; fastcgi_pass unix:/run/PHP/PHP7.0-fpm.sock; } } EOF
然后重启 Nginx
sudo Nginx -t && sudo Nginx -s reload
我们的目录在 /var/www/example.com
, 创建一个 PHPinfo.PHP
并输入 PHPinfo()
函数
sudo cat >> /var/www/example.com/PHPinfo.PHP << EOF <?PHP PHPinfo(); ?> EOF
好了,此时在浏览器输入 http://example.com/phpinfo.php
,如果看到经典的 PHPinfo 页面则说明安装成功,如果不成功,请仔细对比步骤查找哪里出错
四、安装 MysqL 5.7.x
经过多年生产环境的测试,我们推荐使用 Percona Server 代替原生的 MysqL
wget https://repo.percona.com/apt/percona-release_0.1-4.$(lsb_release -sc)_all.deb sudo dpkg -i percona-release_0.1-4.$(lsb_release -sc)_all.deb
此时会在 /etc/apt/sources.list.d/percona-release.list
文件加入官方源,在安装之前可以先检查是否存在
更新系统并安装 Percona Server 5.7
sudo apt-get update sudo apt-get install percona-server-server-5.7
安装成功后系统会让您输入两次 MysqL 的 root 密码,请切记一定要使用随机的、不可被人猜测的密码
我亲眼目测过很多新手第一次安装用了弱密码,后来服务器就被人日,所以这里强烈推荐安装完 MysqL 后,执行一次安全设置,很简单的一条命令
MysqL_secure_installation
执行后会让您选择密码强度,一般情况下选择 1 或者 2
root@demo:~# MysqL_secure_installation Securing the MysqL server deployment. Enter password for user root: VALIDATE PASSWORD PLUGIN can be used to test passwords and improve security. It checks the strength of password and allows the users to set only those passwords which are secure enough. Would you like to setup VALIDATE PASSWORD plugin? Press y|Y for Yes,any other key for No:y 请输入 y 进行初始安全设置 There are three levels of password validation policy: LOW Length >= 8 MEDIUM Length >= 8,numeric,mixed case,and special characters STRONG Length >= 8,special characters and dictionary file Please enter 0 = LOW,1 = MEDIUM and 2 = STRONG: 2 最强大的密码当然要输入 2 Using existing password for root. Estimated strength of the password: 100 Change the password for root ? ((Press y|Y for Yes,any other key for No) : n 如果之前设置了强密码,则不需要重新更改 root 密码,反之则按 y 回车后输入两次重置 By default,a MysqL installation has an anonymous user,allowing anyone to log into MysqL without having to have a user account created for them. This is intended only for testing,and to make the installation go a bit smoother. You should remove them before moving into a production environment. Remove anonymous users? (Press y|Y for Yes,any other key for No) : y 移除匿名用户,没啥鸟用就直接移除吧 Normally,root should only be allowed to connect from 'localhost'. This ensures that someone cannot guess at the root password from the network. Disallow root login remotely? (Press y|Y for Yes,any other key for No) : y 关闭 root 远程登录,不需要进行远程登录的话就关了吧 Success. By default,MysqL comes with a database named 'test' that anyone can access. This is also intended only for testing,and should be removed before moving into a production environment. Remove test database and access to it? (Press y|Y for Yes,any other key for No) :y 移除 test 数据库 Reloading the privilege tables will ensure that all changes made so far will take effect immediately. Reload privilege tables now? (Press y|Y for Yes,any other key for No) : y 重置数据库权限
再次提醒,密码一定要随机、不可猜测,使用弱密码而导致服务器被日的例子实在是数不清楚
做好初始安全设置后,我们就可以进行创建数据库操作,首先使用 root 登录 MysqL
MysqL -u root -p
会提示让您输入密码,输入密码登陆后,创建一个名为 example 的数据库
CREATE DATABASE example DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
由于手机端的流行,我们已经不再使用 utf-8
编码,而改用 utf8mb4
这样我们就可以在 MysqL 数据库里储存 emoji 表情了,比如这样