如何使用树莓派管理大型酒店

想在空闲时间重新思考如何管理您的酒店或汽车旅馆吗?
140 位读者喜欢这篇文章。
All Things Open speaker support 'office hours' start today

Alan Levine. CC0 1.0

带有 Raspbian Lite 的树莓派在安装许多有用的服务方面非常通用(另请参阅我的 树莓派项目文章)。通过搜索开源软件并使用这个神奇的设备进行测试,可以实现一些令人着迷的功能。一个有趣的例子是使用树莓派和 Qloapps 安装一个完整的开源酒店预订系统。

什么是 Qloapps?

QloApps 是一个开源软件,具有许多 功能,可以帮助简化酒店业务管理。这些功能包括:

  • 启动酒店预订网站
  • 管理线下预订
  • 部分付款预订
  • 集成支付网关
  • 单个订单中的多间客房/多家酒店预订
  • 管理退款规则

它由一个 Web 前端(客户可以从互联网访问的页面)和一个 Web 后端(酒店所有者可以在其中管理酒店、房间、价格和许多其他可自定义的选项)组成。

逐步步骤

这个项目非常简单,并且仅安装远程 Web 服务意味着我们只需要一些廉价的零件:

  • 树莓派 3 B 型*,带电源
  • 一张 micro SD 卡(建议至少 16GB)

*我将使用树莓派 3 B 型,但它也应该与树莓派 3 A+ 或更新的板卡一起使用。

您还需要一台带有 SFTP 软件的台式电脑(例如,免费的 Filezilla)来将安装包传输到您的 RPI 中。

我们将首先设置一个经典的 LAMP 服务器,然后我们将设置数据库用户并安装 Qloapps。

1. 安装 Raspbian Buster Lite 操作系统

对于此步骤,请参阅我的 在你的树莓派上安装 Raspbian Buster Lite 文章。

确保您的系统是最新的。通过 ssh 终端连接并键入以下命令

sudo apt-get update
sudo apt-get upgrade

2. 安装 LAMP 服务器

LAMP(Linux、Apache、MySQL、PHP)服务器通常附带 MySQL 数据库。在我们的项目中,我们将使用 MariaDB 代替,因为它更轻巧,并且可以很好地与树莓派配合使用。这第一部分将很快,因为互联网上有大量关于安装 LAMP 服务器的优秀说明。

3. 安装 Apache 服务器

sudo apt-get install apache2 -y

现在,您应该能够通过浏览 http://<<YouRpiIPAddress>> 来检查 Apache 安装是否正确。

Apache default page

4. 安装 PHP

sudo apt-get install php -y

5. 安装 MariaDB 服务器和 PHP 连接器

sudo apt-get install mariadb-server php-mysql -y

6. 安装 PHPMyAdmin

sudo apt-get install phpmyadmin

在 PHPMyAdmin 设置屏幕中,请按照以下说明操作

  • 使用空格选择 Apache(强制性)并按 OK。
  • 选择 Yes 以使用 dbconfig-common 为 PHPMyAdmin 配置数据库。
  • 插入您最喜欢的 PHPMyAdmin 密码,然后按 OK。
  • 再次插入您的 PHPMyAdmin 密码以确认并按 OK。

7. 授予 PHPMyAdmin 用户数据库管理数据库的权限

我们将使用 root 用户(默认密码为空)连接到 MariaDB 以授予权限。请记住在每条命令行的末尾使用分号,如下所示:

sudo mysql -uroot -p
grant all privileges on *.* to 'phpmyadmin'@'localhost';
flush privileges;

最后,重启 Apache 服务

sudo systemctl restart apache2.service

并通过浏览“http://<<YouRpiIPAddress>>/phpmyadmin/.”检查 PHPMyAdmin 是否正在工作。

PHPMyAdmin default page

默认的 PHPMyAdmin 登录凭据是

  • 用户:phpmyadmin
  • 密码:在 phpmyadmin 安装步骤中设置的密码

安装其他 Qloapps 所需的软件包并设置 PHP

我们需要为 Qloapp 安装检查做好准备。因此,我们必须安装 PHP Soap 连接器

sudo apt-get install php-soap

通过合规性检查的另一个要求是将 PHP 最大上传文件大小编辑为 16 MB

sudo nano /etc/php/7.3/apache2/php.ini

查找具有 upload_max_filesize 参数的行并将其设置为如下所示

upload_max_filesize = 16M

Qloapps 还建议以下更改

max_execution_time = 500

保存并退出。再次重启 Apache

sudo systemctl restart apache2.service

安装 Qloapps

我们将遵循官方的 Qloapps 安装指南,但会进行一些小的更改以拥有专用的数据库应用程序用户。

创建数据库并设置用户。返回到 PHPMyAdmin 网页(浏览“http://<<YourRpiIPAddress>>/phpmyadmin/”)并登录

  • 用户:phpmyadmin
  • 密码:在 PHPMyAdmin 安装步骤中设置的密码

单击 Database 选项卡

Database 1

创建一个数据库并记下数据库名称,因为在进一步的安装过程中需要相同的名称

Database 2

现在是为 Qloapps 创建数据库用户的时候了。在此示例中,我将使用以下凭据;您可以使用自己选择的登录名。

  • 用户:qloapps_db_user
  • 密码:qloapps_db_password

因此,终端命令将是:

sudo mysql -uroot -p
CREATE USER ‘qloapps_db_user’@‘localhost’ IDENTIFIED BY ‘qloapps_db_password’;
GRANT ALL PRIVILEGES ON qloapps_.* TO 'qloapps_db_user' @ 'localhost';
flush privileges;
quit

(如果之前没有更改,则 root 密码仍然为空)

安装 Qloapps 软件

从您本地 PC 上的 Qloapps 下载页面下载 Qloapps 安装 zip 文件。在撰写本文时,此文件名为“HotelCommerce-1.4.0.zip”。

使用您最喜欢的 SFTP 软件,将整个 zip 文件传输到树莓派中路径“/home/pi/download”下的一个新文件夹中。常见的(默认)SFP 连接参数是

  • 主机:您的树莓派 IP 地址
  • 用户:pi
  • 密码:raspberry(如果您没有更改 pi 默认密码)
  • 端口:22

返回终端

cd /home/pi/download/ #Enter directory where Qloapps installation files have been transferred
unzip HotelCommerce-1.4.0.zip #Extracts all files from zip
cd /var/www/html/ #Enter Apache web directory
sudo rm index.html #Removes Apache default page - we'll use Qloapps one
sudo cp -R /home/pi/download/HotelCommerce-1.4.0/hotelcommerce/* ./ #Copy installation files to web directory
sudo chown -R www-data:www-data ./

浏览 http://<<YourRpiIPAddress>> 开始安装

Qloapps installation

选择您喜欢的语言,然后按 Next。

Qloapps installation

阅读许可协议。如果您同意,请勾选对面的标志,然后按 Next。

Qloapps installation

在此步骤中,您将需要输入您的商店详细信息以及您将用来访问您的商店的凭据。最后,按 OK。

Qloapps installation

根据前面段落中定义的编辑数据库连接参数。使用本指南中使用的参数,我将编辑

  • 数据库名称:qloapps_(添加了最后的下划线)
  • 数据库登录名:qloapps_db_user
  • 数据库密码:qloapps_db_password

测试数据库连接,它应该没问题。单击 Next。

Qloapps installation

安装似乎已正确完成,但是我们必须在进入 Qloapps 网页之前删除 install 文件夹。从终端输入

sudo rm -R install/

使用终端中的“ls”命令,找到名称以“admin”开头的文件夹。在我的例子中,输出如下

Qloapps installation

但 admin 文件夹名称可能因安装而异。

现在您的预订 Web 服务器已准备就绪,页面将是

  • 前端(针对客户):http://<<YourRpiIPAddress>>
  • 后端(针对管理员):http://<<YourRpiIPAddress>>/<<AdminFolderName>>

首先,对后端的访问进入演示模式。可以使用页面右侧标有“演示模式”的切换按钮禁用此功能。

要自定义,请使用 Qloapps 用户指南

接下来阅读什么
标签
User profile image.
幸运的丈夫,对开源充满热情。天生好奇。为我的根感到自豪,很高兴混合并学习不同的根

10 条评论

这只是成功运营酒店所需的一部分,需要与其他系统集成。

这是一个在线预订引擎,换句话说,酒店版的 Magento/Shopify 等,而不是实际运行酒店的后端部分。

对于日常工作,您需要能够处理入住/退房、客房清洁、收入管理、物业维护、行李员(可选)、第三方费用(电话、迷你吧、餐厅费用、电视/视频等)、团体管理(包括团体预订和账单)、会计以及拼图的许多其他部分。

完全正确,我同意。
即使您是一家小型酒店或汽车旅馆也是如此。
如果您是注册企业,您还需要处理 GDPR 法律,即在网站上处理客户数据,这将导致需要一些强大的加密。
树莓派 3 无论如何都无法处理这一点。
对于 IT 学生来说,这是一个非常酷的模拟项目,可以理解基础知识。
我自己在进行 IT 研究,可能会向我的老师提出这个建议,这样我们就可以进行小规模的练习。

喜欢这篇文章,但是用这个来运营一家酒店实在是牵强附会。

回复 作者 Nathan

大家好。
当然,酒店管理是一项工作,树莓派是小型计算机,适用于小型项目,更接近计算机技术爱好者或实现概念验证。我尝试了这个测试来探索树莓派的功能,并将这些项目视为尝试(和评估)开源产品的一种方式。同样从 IT 方面来说,业务级平台应考虑备份、访问安全、连续性和其他应考虑并添加到真实业务中的要求。

回复 作者:G.v.M (未验证)

这样的平台是否能够支持像 "aes-cbc-essiv:sha256" 这样的体面加密? 这应该足够了。

回复 作者:G.v.M (未验证)

有多少用户可以访问这样的网站而不会出现明显的性能问题? 可以达到100个同时访问网页的用户吗?

你好 Vzhik,
这是一个很好的问题。 即使每个人都希望得到一个简单的数字答案,性能问题也更加复杂。 这在很大程度上取决于您认为可接受的性能是什么以及您要公开什么样的服务。
例如,一个用作简单 Web 服务器的 Raspberry PI,提供静态 HTML 页面,可以正确处理缓存和队列,从而能够处理 100 个同时连接。 但响应时间可能不会让您满意(Raspberry PI 的网络能力有限)。 在这种配置中,使用外部 CDN 可以帮助提高性能。 但我们描述的是静态页面的示例,没有日志/预订服务,这与 QloApps 的情况完全不同。
请考虑 100 个同时访问是一个非常大的流量。 如果您有如此多的访问,您应该考虑使用企业级服务。

回复 作者:Vzhik (未验证)

哇! 非常喜欢这篇文章,我必须发表评论 - 我刚刚在我的汽车旅馆上做了! 谢谢你。 让我们看看结果如何..

我还想找到一种管理 Raspberry Pi 本身的方法,获取警报并更改需要的代码/包。 我找到了一个免费平台(对于我们的规模),它为此提供了一个非常好的解决方案 - https://www.upswift.io/

感谢分享 :)

你好 Jason,
很高兴您进行测试。 请记住,对于实际使用情况,需要评估所有需要的注意事项。 最重要的是,请记住经常备份您的数据并测试您的恢复程序。
我刚刚看了您发布的 upswift 链接,发现它真的很有趣。 希望在不久的将来能够对其进行测试。

回复 作者:JasonMotelGo (未验证)

你好 Giuseppe,

很棒的文章。 我一直在按照步骤操作,但在输入“sudo mysql -uroot -p
grant all privileges on . to 'phpmyadmin' @ 'localhost';
flush privileges;”进入终端的步骤时卡住了。 第一个命令执行完毕,当我输入 grant all 时,它给了我一个语法错误。 我做了一些调查,发现一些来源显示授予特定数据库的权限,但不是像这样特别的。 您能帮忙吗?

谢谢,
David

Creative Commons License本作品根据 Creative Commons Attribution-Share Alike 4.0 International License 获得许可。
© . All rights reserved.