【ECS生长万物之开源】手动搭建Magento电子商务网站

简介: Magento是一款开源电商网站框架,其丰富的模块化架构体系及拓展功能可为大中型站点提供解决方案。Magento使用PHP开发,支持版本范围从PHP 5.6到PHP 7.1,并使用MySQL存储数据。本教程主要介绍如何在CentOS 7操作系统的ECS实例上搭建Magento电子商务网站。

Magento是一款开源电商网站框架,其丰富的模块化架构体系及拓展功能可为大中型站点提供解决方案。Magento使用PHP开发,支持版本范围从PHP 5.6到PHP 7.1,并使用MySQL存储数据。本教程主要介绍如何在CentOS 7操作系统的ECS实例上搭建Magento电子商务网站。

前提条件

  • 已注册阿里云账号。如还未注册,请先完成账号注册
  • 已完成实名认证。如还未认证,请先完成实名认证
  • 已在ECS实例安全组的入方向已添加规则并放行端口80和3306。具体操作,请参见添加安全组规则

说明: 大多数客户端位于局域网中,IP地址是经过转换的,因此ipconfigifconfig命令返回的IP不一定是客户端的真实公网IP地址。若后续客户端无法访问Magento网站,请重新确认其公网IP地址。

规则方向 授权策略 协议类型 端口范围 授权类型 授权对象
入方向 允许 HTTP(80) 80/80 IPv4地址段访问 所有要访问Magento站点的客户端公网IP地址,多个地址之间用逗号隔开。

允许所有客户端访问时,授权对象为0.0.0.0/0。

入方向 允许 MySQL(3306) 3306/3306 IPv4地址段访问 所有要访问MySQL数据库服务的客户端公网IP地址,多个地址之间用逗号隔开。

允许所有客户端访问时,授权对象为0.0.0.0/0。

背景信息

本教程使用的ECS实例硬件配置如下:

  • 实例规格:ecs.c6.large
  • 操作系统:公共镜像CentOS 7.2 64位
  • CPU:2 vCPU
  • 内存:4 GiB
  • 网络类型:VPC
  • IP地址:公网IP

说明: 搭建Magento服务器,所选实例规格内存不能小于2GiB。

示例步骤使用以下软件版本:

  • Apache:2.4.6
  • MySQL:5.7
  • PHP:7.0
  • Composer:1.8.5
  • Magento:2.1

当您使用不同软件版本时,可能需要根据实际情况调整命令和参数配置。

操作流程

在阿里云ECS实例上搭建Magento电子商务网站的操作流程如下:

  • 步骤一:安装并配置Apache
  • 步骤二:安装并配置MySQL
  • 步骤三:安装并配置PHP
  • 步骤四:创建Magento数据库
  • 步骤五:安装并配置Composer
  • 步骤六:安装配置Magento
  • 步骤七:配置Magento客户端
  • 步骤八:添加cron作业

步骤一:安装并配置Apache

1.安装Apache。

a.运行以下命令安装Apache。

yum install httpd -y

b.运行以下命令查看Apache是否安装成功。

httpd -v

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

2.配置Apache。

a.运行以下命令打开Apache配置文件。

vim /etc/httpd/conf/httpd.conf

b.在Include conf.modules.d/*.conf的下一行,添加LoadModule rewrite_module modules/mod_rewrite.so。具体步骤如下:

i)移动光标到Include conf.modules.d/*.conf下一行的行首。

ii)按下i键进入编辑模式。

iii)输入LoadModule rewrite_module modules/mod_rewrite.so

添加后的内容,如下图所示。

c.将下列内容中的AllowOverride None更改为AllowOverride All

# AllowOverride controls what directives may be placed in .htaccess files.
# It can be "All", "None", or any combination of the keywords:
# Options FileInfo AuthConfig Limit
#
#在行首添加#注释掉本行内容
#AllowOverride None
#添加下列内容
AllowOverride All

修改后的内容,如下图所示。

d.按下Esc键后,输入:wq并回车以保存并关闭配置文件。

3.运行以下命令启动Apache服务。

systemctl start httpd

4.运行以下命令添加Apache服务开机自启动。

systemctl enable httpd

步骤二:安装并配置MySQL

1.安装MySQL。

a.运行以下命令添加MySQL YUM源。

rpm -Uvh https://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.rpm

b.运行以下命令安装MySQL。

yum -y install mysql-community-server --nogpgcheck

2.运行以下命令启动MySQL服务。

systemctl start mysqld

3.运行以下命令设置MySQL服务开机自启动。

systemctl enable mysqld

4.配置MySQL。

a.运行以下命令查看/var/log/mysqld.log文件,获取并记录root用户的初始密码。

grep 'temporary password' /var/log/mysqld.log

  命令的返回结果如下:

2016-12-13T14:57:47.535748Z 1 [Note] A temporary password is generated for root@localhost: p0/G28g>lsHD


说明: 下一步重置root用户密码时,会使用该初始密码。

b.运行下列命令配置MySQL的安全性。

mysql_secure_installation

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

i)设置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

ii)输入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.

iii)输入Y禁止root账号远程登录。

Disallow root login remotely? (Press y|Y for Yes, any other key for No) : Y #禁止root远程登录,输入Y
Success.

iv)输入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.

v)输入Y重新加载授权表。

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

更多详情,请参见MySQL文档

步骤三:安装并配置PHP

1.安装PHP。

a.运行以下命令添加ius源。

yum install \
https://repo.ius.io/ius-release-el7.rpm \
https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

b.运行以下命令添加Webtatic源。

rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

c.运行以下命令安装PHP7及所需扩展。

yum -y install php70w php70w-pdo php70w-mysqlnd php70w-opcache php70w-xml php70w-gd php70w-mcrypt php70w-devel php70w-intl php70w-mbstring php70w-bcmath php70w-json php70w-iconv

d.运行以下命令查看PHP版本。

php -v

  返回结果如下所示,说明PHP安装成功。

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

2.配置PHP。

a.运行以下命令打开PHP配置文件。

vim /etc/php.ini

b.移动光标至最后一行的行尾。具体操作步骤如下:

i)输入:$并回车,光标将移动至文件最后一行。

ii)按下$移动光标至行尾。

c.按下i键进入编辑模式。

d.在文件最后添加关于内存限制和时区的配置。

; 允许为PHP脚本分配的最大内存值。您可根据实际情况增加或减少内存限制
memory_limit = 1024M
; 设置时区为上海
date.timezone = Asia/Shanghai

  添加后如下图所示。

e.按下Esc键后,输入:wq并回车以保存并关闭文件。

f.重启Apache服务。

systemctl restart httpd

步骤四:创建Magento数据库

1.运行以下命令使用root用户和密码登录MySQL。

mysql -u root -p

2.运行以下命令创建magento数据库。

mysql> CREATE DATABASE magento; #根据实际情况将magento替换为您需要创建的数据库名称

3.依次运行以下命令为magento数据库创建用户。

mysql> GRANT ALL ON magento.* TO <YourUser>@localhost IDENTIFIED BY '<YourPass>'; #替换<YourUser>和<YourPass>为您需要创建的账号和密码
mysql> FLUSH PRIVILEGES;

  例如,创建账号为magentoUser、密码为magentoUser1@3的用户,运行的命令为:

mysql> GRANT ALL ON magento.* TO magentoUser@localhost IDENTIFIED BY 'magentoUser1@3';
mysql> FLUSH PRIVILEGES;

4.输入exit并回车以退出MySQL。

5.可选:验证新建的Magento数据库和用户是否可用。具体步骤如下:

a.运行以下命令使用新建账号和密码登录MySQL。

mysql -u <YourUser> -p   #替换<YourUser>为您创建的账号

b.运行以下命令查看新建的magento数据库。

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| magento            |
+--------------------+
2 rows in set (0.00 sec)

c.运行以下命令并回车以退出MySQL。

mysql> exit

步骤五:安装并配置Composer

Composer是PHP的一个依赖管理工具。Composer允许您申明项目所依赖的代码库,并帮您在项目中安装依赖的代码库。

1.运行以下命令安装Composer。

curl -sS https://getcomposer.org/installer | php

2.运行以下命令配置Composer全局使用。

mv /root/composer.phar /usr/bin/composer

3.运行命令composer -v查看Composer版本。返回结果如下,表示Composer安装成功。

/ ____/___  ____ ___  ____  ____  ________  _____
 / /   / __ \/ __ `__ \/ __ \/ __ \/ ___/ _ \/ ___/
/ /___/ /_/ / / / / / / /_/ / /_/ (__  )  __/ /
\____/\____/_/ /_/ /_/ .___/\____/____/\___/_/
                    /_/
Composer version 1.8.5 2019-04-09 17:46:47


说明: 因最新版Composer与Magento暂不兼容,所以您需要安装与Magento兼容的Composer版本。你可以使用以下命令来让最新版Composer转换至兼容版本。如Composer 1.8.5版本。

composer self-update 1.8.5

步骤六:安装配置Magento

您可以使用不同的方法安装Magento,可以选择是否安装示例数据。

  • 如果安装Magento仅用于测试,您可以选择安装示例数据。
  • 如果安装Magento用于生产环境,建议您安装全新的Magento,从头开始配置。

本教程介绍使用Git下载Magento,并使用Composer安装Magento的操作步骤。

1.下载Magento。

a.运行以下命令安装Git。

yum -y install git

b.进入Web服务器的默认根目录。

cd /var/www/html/

c.下载Magento。

git clone https://github.com/magento/magento2.git

2.可选:运行以下命令将Magento切换到稳定版本。

cd magento2 &&  git checkout tags/2.1.0 -b 2.1.0

  命令执行后的结果如下:

Switched to a new branch '2.1.0'


  说明: 默认情况下,Git下载安装的Magento是最新的开发版本。如果您在生产环境中使用,建议切换到稳定版本,否则未来将无法升级安装。

3.运行以下命令将安装文件移到Web服务器根目录下。

shopt -s dotglob nullglob && mv /var/www/html/magento2/* /var/www/html/ && cd ..


  说明: 运行此命令后,您可以通过https://<ECS实例公网IP地址>访问您的Magento站点。否则,您只能通过https://<ECS实例公网IP地址>/magento2访问。

4.依次运行下列命令为Magento文件设置适当的权限。

chown -R :apache /var/www/html
find /var/www/html -type f -print0 | xargs -r0 chmod 640
find /var/www/html -type d -print0 | xargs -r0 chmod 750
chmod -R g+w /var/www/html/{pub,var}
chmod -R g+w /var/www/html/{app/etc,vendor}
chmod 750 /var/www/html/bin/magento

5.运行命令composer install安装Magento。

步骤七:配置Magento客户端

1.打开浏览器。

2.在浏览器地址栏中,输入http://<ECS实例公网IP地址>出现如下图所示页面,表示Magento安装成功。


3.单击Agree and Setup Magento开始配置Magento。具体步骤如下:

a.准备性检查。

i)单击Start Readiness Check

ii)检查完成后,单击Next

b.添加数据库。

i)输入之前创建的数据库用户的账号和密码。本教程中创建的示例用户账号为magentoUser、密码为magentoUser1@3

ii)输入之前创建的数据库的名字。本教程中创建的示例数据库名字为magento

iii)单击Next

c.填写Web访问设置,并单击Next

d.填写定制商店,并单击Next

e.填写管理员账号信息,并单击Next

f.单击Install Now进行安装。

出现如下图所示界面,表示Magento配置完成。

步骤八:添加cron作业

完成以下操作,添加cron作业:

1.运行crontab -u apache -e设置cron运行调度工作。

2.按下i键进入编辑模式。

3.输入下列配置信息。

*/10 * * * * php -c /etc /var/www/html/bin/magento cron:run
*/10 * * * * php -c /etc /var/www/html/update/cron.php
*/10 * * * * php -c /etc /var/www/html/bin/magento setup:cron:run

4.按下Esc键后,输入:wq并回车以保存并退出。

Magento上使用cron作业的更多详情,请参见Magento官方文档

常见问题

输入http://<ECS实例公网IP地址>/admin登录Magento后台,如果界面提示“One or more indexers are invalid. Make sure your Magento cron job is running.”的错误信息,请参考以下步骤解决问题。

1.远程连接Magento服务器。具体操作,请参见连接方式概述

2.运行以下命令,将PHP的安装路径建立软连接至/usr/sbin/php目录下。

ln -s /usr/local/php/bin/php /usr/sbin/php

3.运行以下命令,刷新索引。

cd /var/www/html
php bin/magento indexer:reindex

  回显信息类似如下所示,表示索引已刷新成功。

[root@iZbp1h2mquu8nb0jz99**** wwwroot]# php bin/magento indexer:reindex
Design Config Grid index has been rebuilt successfully in 00:00:00
Customer Grid index has been rebuilt successfully in 00:00:00
Category Products index has been rebuilt successfully in 00:00:00
Product Categories index has been rebuilt successfully in 00:00:00
Product Price index has been rebuilt successfully in 00:00:00
Product EAV index has been rebuilt successfully in 00:00:00
Stock index has been rebuilt successfully in 00:00:00
Catalog Rule Product index has been rebuilt successfully in 00:00:00
Catalog Product Rule index has been rebuilt successfully in 00:00:00
Catalog Search index has been rebuilt successfully in 00:00:00

4.刷新页面后,单击Cache Management

5.选中状态为INVALIDATEDCache Types,并单击Submit当出现类似如下返回信息时,表示问题已经解决。

后续步骤

  • 访问http://<ECS实例公网IP地址>可以看到如下图所示的默认主页。
  • 访问http://<ECS实例公网IP地址>/admin,输入您在安装过程中设置的用户名和密码,成功登录管理面板后可看到如下界面。

相关文档

Magento官方文档

相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情:&nbsp;https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
安全 Linux 应用服务中间件
从零开始启动、配置、保护你的云服务器并搭建一个简单的网站
本文详细介绍了如何准备原料、搭建基础环境、进行安全防护、建设网站、管理证书以及开启BBR优化网络性能。主要内容包括获取健康云服务器、配置SSH登录、创建非root用户、启用密钥认证、安装Nginx、申请TLS证书、配置HTTPS自动跳转及优化网络性能等步骤。通过本文,读者可以掌握从零开始搭建个人网站的全过程。
51 1
从零开始启动、配置、保护你的云服务器并搭建一个简单的网站
|
4天前
|
弹性计算 运维 Ubuntu
使用阿里云服务器自动搭建WordPress网站流程,超简单by系统运维管理OOS
本教程介绍如何使用阿里云服务器(ECS)和系统运维管理OOS自动搭建WordPress网站,支持Ubuntu、CentOS及Alibaba Cloud Linux等操作系统。前提条件包括ECS实例处于运行中、有公网IP且安全组已开启80端口。安装步骤简单:进入ECS快速购买控制台选择预装WordPress,确认下单后通过管理控制台查看实例详情并开放安全组端口。最后,通过实例公网IP访问,出现WordPress登录页即表示安装成功。
|
1月前
|
开发框架 .NET PHP
网站应用项目如何选择阿里云服务器实例规格+内存+CPU+带宽+操作系统等配置
对于使用阿里云服务器的搭建网站的用户来说,面对众多可选的实例规格和配置选项,我们应该如何做出最佳选择,以最大化业务效益并控制成本,成为大家比较关注的问题,如果实例、内存、CPU、带宽等配置选择不合适,可能会影响到自己业务在云服务器上的计算性能及后期运营状况,本文将详细解析企业在搭建网站应用项目时选购阿里云服务器应考虑的一些因素,以供参考。
|
2月前
|
运维 监控 Linux
服务器管理面板大盘点: 8款开源面板助你轻松管理Linux服务器
在数字化时代,服务器作为数据存储和计算的核心设备,其管理效率与安全性直接关系到业务的稳定性和可持续发展。随着技术的不断进步,开源社区涌现出众多服务器管理面板,这些工具以其强大的功能、灵活的配置和友好的用户界面,极大地简化了Linux服务器的管理工作。本文将详细介绍8款开源的服务器管理面板,包括Websoft9、宝塔、cPanel、1Panel等,旨在帮助运维人员更好地选择和使用这些工具,提升服务器管理效率。
|
2月前
|
运维 安全 Linux
2024 主流的开源服务器面板推荐
随着云计算和虚拟专用服务器(VPS)的普及,服务器面板工具成为了企业和个人管理服务器的得力助手。一个优秀的服务器面板不仅可以简化服务器管理任务,还可以提升工作效率和安全性。本文将为您介绍并测评几款2024年全网热门的服务器面板,包括Websoft9、宝塔、cPanel、1Panel等,帮助您找到最适合自己的管理工具。
2024 主流的开源服务器面板推荐
|
3月前
|
关系型数据库 MySQL Linux
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
608 3
|
2月前
|
安全 数据挖掘 网络安全
网站建站如何选择合适的服务器配置
建站初期应进行长期数据分析与预测,合理选择服务器配置。主要依据同时在线人数、CPU性能、内存大小及带宽类型,同时考虑安全防护,如选择带防火墙的高防服务器,确保网站稳定运行与良好用户体验。
55 0
|
7天前
|
机器学习/深度学习 人工智能 PyTorch
阿里云GPU云服务器怎么样?产品优势、应用场景介绍与最新活动价格参考
阿里云GPU云服务器怎么样?阿里云GPU结合了GPU计算力与CPU计算力,主要应用于于深度学习、科学计算、图形可视化、视频处理多种应用场景,本文为您详细介绍阿里云GPU云服务器产品优势、应用场景以及最新活动价格。
阿里云GPU云服务器怎么样?产品优势、应用场景介绍与最新活动价格参考
|
6天前
|
存储 运维 安全
阿里云弹性裸金属服务器是什么?产品规格及适用场景介绍
阿里云服务器ECS包括众多产品,其中弹性裸金属服务器(ECS Bare Metal Server)是一种可弹性伸缩的高性能计算服务,计算性能与传统物理机无差别,具有安全物理隔离的特点。分钟级的交付周期将提供给您实时的业务响应能力,助力您的核心业务飞速成长。本文为大家详细介绍弹性裸金属服务器的特点、优势以及与云服务器的对比等内容。
|
13天前
|
人工智能 JSON Linux
利用阿里云GPU加速服务器实现pdf转换为markdown格式
随着AI模型的发展,GPU需求日益增长,尤其是个人学习和研究。直接购置硬件成本高且更新快,建议选择阿里云等提供的GPU加速型服务器。
利用阿里云GPU加速服务器实现pdf转换为markdown格式

相关产品

  • 云服务器 ECS