雨巷博客丨一个温馨有爱的网站

Debian 9 / Debian 8 使用源安装 LEMP 教程

1.安装完linux时,运行以下安装:

  • 安装常用命令
apt-get install curl vim wget sudo unzip apt-transport-https lsb-release ca-certificates

2.安装完linux时如果要使用远程登陆,记得打开ssh远程登陆

  • 当xshell拒绝连接时。大多数为密码错误,不行时。则需要查看ssh是否禁止远程登录。
vim /etc/ssh/sshd_config
  • 把#permitRootLogin这段改成permitRootLogin yes
  • 去掉注释 yes为允许远程登录。

 

  • 重启linux

 

3.更新系统并安装部分必要软件

  • 这一步是更新你的源列表和软件更新
sudo apt-get update && apt-get upgrade

4.当然您也可以加入 Backports 源或中科大的源,方便安装更新的软件

  • Backports 源
sudo cat >> /etc/apt/sources.list.d/backports.list << EOF
deb http://deb.debian.org/debian $(lsb_release -sc)-backports main
deb-src http://deb.debian.org/debian $(lsb_release -sc)-backports main
EOF
  • 国内的机器可以用中科大的源
sudo cat >> /etc/apt/sources.list.d/backports.list << EOF
deb https://mirrors.ustc.edu.cn/debian $(lsb_release -sc)-backports main
deb-src https://mirrors.ustc.edu.cn/debian $(lsb_release -sc)-backports main
EOF
  • 然后在进行升级
sudo apt-get -t stretch-backports update && apt-get -t stretch-backports upgrade

5.增加 Ondřej Surý 大神打包的 Nginx 源并安装

  • 首先增加 Key
sudo wget -O /etc/apt/trusted.gpg.d/nginx-mainline.gpg https://packages.sury.org/nginx-mainline/apt.gpg
  1. 然后增加 Nginx 源或xTom的香港源
  • Nginx 源
sudo cat >> /etc/apt/sources.list.d/nginx.list << EOF
deb https://packages.sury.org/nginx-mainline/ $(lsb_release -sc) main
EOF
  • 国内机器可以用 xTom 的香港源
sudo cat >> /etc/apt/sources.list.d/nginx.list << EOF
deb https://mirror.xtom.com.hk/sury/nginx-mainline/ $(lsb_release -sc) main
EOF

6.更新并接安装 Nginx

sudo apt-get update
sudo apt-get install nginx-extras
  • 安装完毕后,我们可以使用 nginx -v 命令看到 Nginx 已经是最新的主线版了
  • nginx默认没有设置系统启动,需要我们手工加入
sudo systemctl enable nginx

7.增加 Ondřej Surý 大神打包的 PHP 源并安装 PHP 7.x

  • 增加大神的 PGP
sudo wget -O /etc/apt/trusted.gpg.d/php.gpg https://packages.sury.org/php/apt.gpg
  • 加入大神做好的源
sudo sh -c 'echo "deb https://packages.sury.org/php/ $(lsb_release -sc) main" > /etc/apt/sources.list.d/php.list'
  • 国内机器可以用 xTom 的香港源
sudo sh -c 'echo "deb https://mirror.xtom.com.hk/sury/php/ $(lsb_release -sc) main" > /etc/apt/sources.list.d/php.list'

8.更新系统

sudo apt-get update

9.安装自己需要的 PHP 版本

这个源目前默认的 PHP 是 7.1.x ,如果您需要 7.2.x 或 7.0.x 或 5.6.x 那么请修改对应的 PHP 版本号(注意配置文件哦)

这里举例 WordPress 需要的部分 PHP 包

安装 PHP 7.2.x ( PHP 7.2 开始已经不支持 mcrypt 组件 )

sudo apt-get install php7.2-fpm php7.2-mysql php7.2-curl php7.2-gd php7.2-mbstring php7.2-xml php7.2-xmlrpc php7.2-zip php7.2-opcache
  • 对应 PHP 7.1.x 就是
sudo apt-get install php7.1-fpm php7.1-mysql php7.1-curl php7.1-gd php7.1-mbstring php7.1-mcrypt php7.1-xml php7.1-xmlrpc php7.1-zip php7.1-opcache
  • 对应 PHP 7.0.x 就是
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 php7.0-opcache
  • 对应 PHP 5.6.x 就是
sudo apt-get install php5.6-fpm php5.6-mysql php5.6-curl php5.6-gd php5.6-mbstring php5.6-mcrypt php5.6-xml php5.6-xmlrpc php5.6-zip php5.6-opcache

如果希望安装其他组件,可以通过搜索看看有没有对应的包

sudo apt-cache search php7.2* | grep php

修改 php.ini 防止跨目录攻击,如果安装的 PHP 7.1.x 请相应修改 /etc/php/7.1/fpm/php.ini PHP 7.0.x 请相应修改 /etc/php/7.0/fpm/php.ini PHP 5.6.x 请修改 /etc/php/5.6/fpm/php.ini

sudo sed -i 's/;cgi.fix_pathinfo=1/cgi.fix_pathinfo=0/' /etc/php/7.2/fpm/php.ini

10.安装完成后重启 PHP 和 Nginx

sudo systemctl restart php7.2-fpm

**这里"php7.2"请根据自己的php版本修改

11.Nginx 参考配置文件如下,新建立个 /etc/nginx/conf.d/example.com.conf

sudo cat >> /etc/nginx/conf.d/example.com.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.2-fpm 模式,如需要安装 PHP 7.1.x 请修改为 fastcgi_pass unix:/run/php/php7.1-fpm.sock;
        location ~ \.php$ {
            include snippets/fastcgi-php.conf;
            fastcgi_pass unix:/run/php/php7.2-fpm.sock;
        }
}
EOF

12.到这里基本没有问题,可以直接重启 Nginx

sudo systemctl restart nginx

我们在/var/www/example.com创建一个目录 example.com 并且创建一个 phpinfo.php 并输入 phpinfo() 函数

sudo mkdir -p /var/www/example.com && cat >> /var/www/example.com/phpinfo.php << EOF
<?php phpinfo(); ?>
EOF

好了,此时在浏览器输入 http://example.com/phpinfo.php,如果看到经典的 phpinfo 页面则说明安装成功,如果不成功,请仔细对比步骤查找哪里出错.

 

13.安装 MySQL 5.7.x / Percona Server 5.7.x

  • 安装 MySQL 5.7.x / Percona Server 5.7.x
    Debian 9.x Stretch 默认已经使用 Mariadb ,所以这里我们推荐 Percona Server, 这货已经发布了 Debian 9.x Stretch 版本
  • 首先,导入 Percona Server 的官方源
    按照官方的教程导入即可
sudo wget https://repo.percona.com/apt/percona-release_0.1-5.$(lsb_release -sc)_all.deb
sudo dpkg -i percona-release_0.1-5.$(lsb_release -sc)_all.deb
  • 然后查看一下对应的 /etc/apt/sources.list.d/percona-release.list 文件是否正确
root@debian9 ~ # cat /etc/apt/sources.list.d/percona-release.list

#
# Percona releases, stable
#
deb http://repo.percona.com/apt stretch main
deb-src http://repo.percona.com/apt stretch main
  • 国内机器可以用 xTom 的香港源
sudo sed -i 's/repo.percona.com/mirror.xtom.com.hk\/percona/' /etc/apt/sources.list.d/percona-release.list
  • 也可以用清华大学的源
sudo sed -i 's/repo.percona.com/mirrors.tuna.tsinghua.edu.cn\/percona/' /etc/apt/sources.list.d/percona-release.list
  •  接着更新一下系统
sudo apt-get update
  • 然后直接安装最新版 MySQL 5.7.x / Percona Server 5.7.x
sudo apt-get install percona-server-server-5.7
  • 在弹出的界面里输入两次随机并且强大的 MySQL root 密码即可,安装成功后检查一下版本
root@debian9 ~ # mysql -V

14.测试MySQL

  • 使用 MySQL root 用户登陆
sudo mysql -u root -p
  • 创建数据库
CREATE DATABASE example_database DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
  • 创建用户名 example_user 并赋予权限
GRANT ALL ON example_database.* TO 'example_user'@'localhost' IDENTIFIED BY '这里改成你要设置的强大的没人能猜出来的随机的密码';
  • 刷新 MySQL 权限
FLUSH PRIVILEGES;
  • 没问题之后可退出
EXIT;
  • 新建立一个 /var/www/example.com/mysql-test.php 文件并测试
sudo cat >> /var/www/example.com/mysql-test.php << EOF
<?php
\$dbname = 'example_database'; //MySQL 数据库名
$dbuser = 'example_user'; //MySQL 用户名
\$dbpass = '你的强大的没人可以猜出来的密码';
\$dbhost = 'localhost'; //安装在本地就用 localhost
\$link = mysqli_connect(\$dbhost, \$dbuser, \$dbpass) or die("Unable to Connect to '\$dbhost'");
mysqli_select_db(\$link, \$dbname) or die("Could not open the db '\$dbname'");
\$test_query = "SHOW TABLES FROM \$dbname";
\$result = mysqli_query(\$link, \$test_query);
\$tblCnt = 0;
while(\$tbl = mysqli_fetch_array(\$result)) {
\$tblCnt++;
#echo \$tbl[0]."&lt;br /&gt;\n";
}
if (!\$tblCnt) {
echo "MySQL is working fine. There are no tables. More information on https://sb.sb/tag/mysql/";
} else {
echo "MySQL is working fine. There are \$tblCnt tables. More information on https://sb.sb/tag/mysql/";
}
?>
EOF

创建完毕后访问 http://example.com/mysql-test.php 如果出现 MySQL is working fine. There are no tables. 则说明 MySQL 工作正常。

赞(0) 1元也是爱
未经允许不得转载:雨巷博客 » Debian 9 / Debian 8 使用源安装
分享到: 更多 (0)

评论 2

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
  1. #-29

    三天两头过来看一看,每次看完都有新体验!

    9483个月前 (08-26)回复
  2. #-28

    不错!

    郭论mp31个月前 (10-12)回复

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏