LAMP环境搭建

本教程介绍如何使用云服务器ECS实例搭建LAMP平台,其中LAMP分别代表Linux、Apache、MySQL和PHP。

前提条件

  • 已注册阿里云账号。如还未注册,请先完成账号注册

  • 已完成实名认证。如还未认证,请先完成实名认证

  • 已创建ECS实例并为实例分配公网IP地址,具体操作请参见创建方式导航

    本篇教程使用以下配置的ECS实例:

    • 实例规格:ecs.c6.large
    • 操作系统:公共镜像CentOS 7.8 64位
    • 网络类型:专有网络VPC
    • IP地址:公网IP
  • 已在实例安全组的入方向添加安全组规则并放行22、80端口。具体操作请参见添加安全组规则

背景信息

本篇教程适用于熟悉Linux操作系统,初次使用阿里云进行建站的个人用户。在示例步骤中使用了以下版本的软件。操作时,请您以实际软件版本为准。

  • Apache:2.4.6
  • MySQL:5.7.31
  • PHP:7.0.33
  • phpMyAdmin:4.0.10.20

本篇教程主要说明手动安装LAMP平台的操作步骤,您也可以在云市场购买LAMP镜像直接启动ECS,以便快速建站。

点我去体验

步骤一:准备工作

  1. 使用向导创建实例

  2. 通过Workbench远程连接Linux实例

  3. 运行命令cat /etc/redhat-release查看系统版本。

  4. 关闭防火墙。

    1. 运行systemctl status firewalld命令查看当前防火墙的状态。

      • 如果防火墙的状态参数是inactive,则防火墙为关闭状态。
      • 如果防火墙的状态参数是active,则防火墙为开启状态。本示例中防火墙为开启状态,因此需要关闭防火墙。
    2. 关闭防火墙。如果防火墙为关闭状态,请忽略此步骤。

      • 如果您想临时关闭防火墙,运行命令systemctl stop firewalld。

        说明 这只是暂时关闭防火墙,下次重启Linux后,防火墙还会开启。

      • 如果您想永久关闭防火墙,运行命令systemctl disable firewalld。

        说明 如果您想重新开启防火墙,请参见firewalld官网信息

  5. 关闭SELinux。

    1. 运行getenforce命令查看SELinux的当前状态。

      • 如果SELinux状态参数是Disabled, 则SELinux为关闭状态。
      • 如果SELinux状态参数是Enforcing,则SELinux为开启状态。本示例中SELinux为开启状态,因此需要关闭SELinux。
    2. 关闭SELinux。如果SELinux为关闭状态,请忽略此步骤。

      • 如果您想临时关闭SELinux,运行命令setenforce 0

        说明 这只是暂时关闭SELinux,下次重启Linux后,SELinux还会开启。

      • 如果您想永久关闭SELinux,运行命令vi /etc/selinux/config编辑SELinux配置文件。回车后,把光标移动到SELINUX=enforcing这一行,按i键,将其修改为SELINUX=disabled, 按Esc键,然后输入:wq并回车以保存并关闭SELinux配置文件。 最后重启系统使设置生效。

        说明 如果您想重新开启SELinux,请参见SELinux的官方文档

步骤二:安装Apache

  1. 运行以下命令安装Apache服务及扩展包。

    yum -y install httpd httpd-manual mod_ssl mod_perl mod_auth_mysql
    
  2. 运行httpd -v命令可查看Apache的版本号。

  3. 依次运行以下命令启动Apache服务并设置服务开机自启动。

    1. systemctl start httpd
      
    2. systemctl enable httpd
      
  4. 查看安装结果。

    1. 登录ECS管理控制台

    2. 在左侧导航栏,单击实例与镜像 > 实例。

    3. 在实例列表中找到正在部署环境的实例,从该实例的IP地址中复制公网IP。

    4. 在本地机器的浏览器地址栏中,输入http://实例公网IP并按Enter键。

      若返回页面如下图所示,说明Apache服务启动成功。

步骤三:安装并配置MySQL

  1. 运行以下命令更新YUM源。

    rpm -Uvh  http://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm
    
  2. 运行以下命令安装MySQL。

    说明 如果您使用的操作系统内核版本为el8,可能会提示报错信息No match for argument。您需要先运行命令yum module disable mysql禁用默认的mysql模块,再安装MySQL。

    yum -y install mysql-community-server
    
  3. 运行以下命令查看MySQL版本号。

    mysql -V
    

    返回结果如下所示,表示MySQL安装成功。

    mysql  Ver 14.14 Distrib 5.7.31, for Linux (x86_64) using  EditLine wrapper
    
  4. 运行以下命令启动MySQL。

    systemctl start mysqld
    
  5. 运行以下命令设置开机启动MySQL。

    systemctl enable mysqld
    systemctl daemon-reload
    
  6. 运行以下命令查看MySQL的初始密码。

    grep "password" /var/log/mysqld.log
    

    返回结果示例如下,本示例中初始密码为+47,uijcojcU

    2020-08-28T03:01:49.848762Z 1 [Note] A temporary password is generated for root@localhost: +47,uijcojcU
    
  7. 运行以下命令配置MySQL的安全性。

    mysql_secure_installation
    

    安全性的配置包含以下五个方面:

    1. 重置root账号的密码。

      说明 请您安全保管root账号的密码信息。

      Enter password for user root: #输入上一步获取的root用户初始密码
      The 'validate_password' plugin is installed on the server.
      The subsequent steps will run with the existing configuration of the plugin.
      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) : Y #是否更改root用户密码,输入Y
      New password: #输入新密码,长度为8至30个字符,必须同时包含大小写英文字母、数字和特殊符号。特殊符号可以是()` ~!@#$%^&*-+=|{}[]:;‘<>,.?/
      Re-enter new password: #再次输入新密码
      Estimated strength of the password: 100 
      Do you wish to continue with the password provided?(Press y|Y for Yes, any other key for No) : Y
      
    2. 输入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  #是否删除匿名用户,输入Y
      Success.
      
    3. 输入Y禁止root账号远程登录。

      Disallow root login remotely? (Press y|Y for Yes, any other key for No) : Y #禁止root远程登录,输入Y
      Success.
      
    4. 输入Y删除test库以及对test库的访问权限。

      Remove test database and access to it? (Press y|Y for Yes, any other key for No) : Y #是否删除test库和对它的访问权限,输入Y
      - Dropping test database...
      Success.
      
    5. 输入Y重新加载授权表。

      Reload privilege tables now? (Press y|Y for Yes, any other key for No) : Y #是否重新加载授权表,输入Y
      Success.
      All done!
      

步骤四:安装PHP

  1. 更新YUM源。

    1. 运行以下命令添加epel源。

      yum install -y \
      https://repo.ius.io/ius-release-el7.rpm \
      https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
      
    2. 运行以下命令添加Webtatic源。

      rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
      
  2. 运行以下命令安装PHP,可根据需要版本调整命令。

    yum -y install php70w-devel php70w.x86_64 php70w-cli.x86_64 php70w-common.x86_64 php70w-gd.x86_64 php70w-ldap.x86_64 php70w-mbstring.x86_64 php70w-mcrypt.x86_64  php70w-pdo.x86_64   php70w-mysqlnd  php70w-fpm php70w-opcache php70w-pecl-redis php70w-pecl-mongodb
    
  3. 运行以下命令查看PHP版本。

    php -v
    

    返回结果如下所示,表示安装成功。

    PHP 7.0.33 (cli) (built: Dec  6 2018 22:30:44) ( NTS )
    Copyright (c) 1997-2017 The PHP Group
    Zend Engine v3.0.0, Copyright (c) 1998-2017 Zend Technologies
        with Zend OPcache v7.0.33, Copyright (c) 1999-2017, by Zend Technologies                
    
  4. 运行以下命令,在Apache网站根目录创建测试文件。

    echo "<?php phpinfo(); ?>" > /var/www/html/phpinfo.php
    
  5. 运行以下命令重启Apache服务。

    systemctl restart httpd
    
  6. 在本地机器的浏览器地址栏中,输入http://实例公网IP/phpinfo.php并按Enter键。

    显示如下页面表示安装成功。

    PHP

步骤五:安装phpMyAdmin

phpMyAdmin是一个MySQL数据库管理工具,通过Web接口管理数据库方便快捷。

  1. 运行以下命令准备phpMyAdmin数据存放目录。

    mkdir -p /var/www/html/phpmyadmin
    
  2. 运行以下命令下载phpMyAdmin压缩包并解压。

    1. 下载phpMyAdmin压缩包。

      cd
      wget https://files.phpmyadmin.net/phpMyAdmin/4.0.10.20/phpMyAdmin-4.0.10.20-all-languages.zip
      
    2. 解压phpMyAdmin压缩包。

      yum install -y unzip
      unzip phpMyAdmin-4.0.10.20-all-languages.zip
      
  3. 运行以下命令复制phpMyAdmin文件到准备好的数据存放目录。

    mv phpMyAdmin-4.0.10.20-all-languages/*  /var/www/html/phpmyadmin
    
  4. 在本地机器浏览器地址栏,输入http://实例公网 IP/phpmyadmin并按Enter键,访问phpMyAdmin登录页面。

    若返回页面如下图所示,说明phpMyAdmin安装成功。

  5. 输入MySQL的用户名和密码,单击执行。

    如果出现以下页面,说明MySQL连接成功。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容