在Ubuntu 14.04上安装和使用Memcache的方法
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。
简介
随着您的网站的增长和流量的增加,最快显示压力的组件之一是后端数据库。如果您的数据库没有分布式和配置来处理高负载,它很容易就会被相对较小的流量增加所压倒。
处理这个问题的一种方法是利用内存对象缓存系统,比如 memcached。Memcached 是一种缓存系统,通过临时将通常从数据库中检索的信息存储在内存中。然后对内存中的信息的下一个请求将变得非常快,而不会给后端数据库带来压力。
在本指南中,我们将讨论如何在 Ubuntu 14.04 服务器上安装和使用 memcached。
先决条件
在开始之前,您应该在服务器上拥有一个常规的非根用户,该用户具有 sudo
权限。如果您还没有创建这样的用户,可以按照我们的 Ubuntu 14.04 初始设置指南中的步骤 1-4 进行创建。
当您配置好常规用户后,可以继续进行本指南。
安装 Memcached 和相关组件
要开始,我们应该从 Ubuntu 的存储库中获取我们需要的所有组件。幸运的是,我们需要的一切都是可用的。
由于这是我们在本次会话中使用 apt
的第一个操作,我们应该更新本地软件包索引。然后我们可以安装我们的程序。
我们将安装 memcached 以及一个 MySQL 数据库后端和 PHP 来处理交互。我们还将安装处理 memcached 交互的 PHP 扩展。您可以通过输入以下命令获取所需的所有内容:
sudo apt-get update
sudo apt-get install mysql-server php5-mysql php5 php5-memcached memcached
请注意,有两个 PHP memcache 扩展可用。一个称为 php5-memcache
,另一个称为 php5-memcached
(请注意第二个示例末尾的 “d”)。我们使用后者,因为它是稳定的并实现了更广泛的功能范围。
如果您还没有安装 MySQL,安装过程将提示您选择并确认管理员密码。
这应该安装并配置您所需的一切。
检查安装
信不信由你,memcached 已经完全安装并准备就绪。我们可以通过多种方式来测试这一点。
第一种方式非常简单。我们可以询问 PHP 是否知道我们的 memcached 扩展以及它是否已启用。我们可以通过创建普遍存在的 PHP 信息页面来实现这一点。
这很容易通过在我们的文档根目录中创建一个名为 info.php
的文件来实现。在 Ubuntu 14.04 上的 Apache 中,我们的默认文档根目录是 /var/www/html
。以 root 权限在此处打开文件:
sudo nano /var/www/html/info.php
在此文件中,输入以下内容。这基本上只是调用一个 PHP 函数,该函数会收集并以网页友好的布局打印有关我们服务器的信息。
<?php
phpinfo();
?>
现在,您可以访问您服务器的域名或公共 IP 地址,后面跟着 /info.php
,您应该会看到一个信息页面。
http://<span class="highlight">server_domain_name_or_IP</span>/info.php
如果您向下滚动或搜索 “memcached” 部分标题,您应该会找到类似以下内容的内容:
!Memcache PHP info section
这意味着 memcached 扩展已启用并被 Web 服务器找到。
我们还可以通过输入以下命令来检查 memcached 服务是否正在运行:
ps aux | grep memcached
memcache 6584 0.0 0.0 327448 3004 ? Sl 14:07 0:00 /usr/bin/memcached -m 64 -p 11211 -u memcache -l 127.0.0.1
demouser 6636 0.0 0.0 11744 904 pts/0 S+ 14:29 0:00 grep --color=auto memcached
您可以通过输入以下命令查询服务的统计信息:
echo "stats settings" | nc localhost 11211
如果您需要停止、启动或重新启动 memcached 服务,可以通过输入以下类似的命令来执行:
sudo service memcached <span class="highlight">restart</span>
测试 Memcached 是否可以缓存数据
现在我们已经验证了 memcached 是否正在运行,并且我们的 PHP 扩展是否已启用,我们可以尝试让它存储数据。
我们将通过创建另一个 PHP 脚本来实现这一点。这次,它将更加复杂。
在我们的文档根目录中打开一个名为 cache_test.php
的文件:
sudo nano /var/www/html/cache_test.php
在文件中,首先创建 PHP 包装标签:
<?php
?>
在其中,我们将创建一个 PHP Memcached 对象的新实例,并将其存储在一个变量中。我们将定义此 PHP 对象可以连接到运行在我们服务器上的实际 memcached 服务的位置。Memcached 默认运行在端口 11211
上:
<?php
<span class="highlight">$mem = new Memcached();</span>
<span class="highlight">$mem->addServer("127.0.0.1", 11211);</span>
?>
接下来,我们将告诉我们的 Memcached 实例从我们的缓存中查询一个键。这个键可以被称为任何东西,因为我们还没有创建它。我们将使用 “blah”。此请求的结果将存储在一个 $result
变量中:
<?php
$mem = new Memcached();
$mem->addServer("127.0.0.1", 11211);<span class="highlight">$result = $mem->get("blah");</span>
?>
接下来,我们只需要测试是否返回了任何内容。如果 memcached 找到一个名为 “blah” 的键,我们希望它打印与该键关联的值。如果 memcached 无法找到匹配的键,我们应该打印出一条消息说明情况。
然后,我们应该设置一个带有值的键,这样下次我们请求该值时,memcached 将找到我们给它的值:
<?php
$mem = new Memcached();
$mem->addServer("127.0.0.1", 11211);$result = $mem->get("blah");<span class="highlight">if ($result) {</span><span class="highlight">echo $result;</span>
<span class="highlight">} else {</span><span class="highlight">echo "No matching key found. I'll add that now!";</span><span class="highlight">$mem->set("blah", "I am data! I am held in memcached!") or die("Couldn't save anything to memcached...");</span>
<span class="highlight">}</span>
?>
此时,我们的脚本已经完成。如果我们在 Web 浏览器中访问此页面,我们可以看到它是如何工作的:
http://<span class="highlight">server_domain_name_or_IP</span>/cache_test.php
您应该最初会看到一个如下的页面:
!Memcached uncached message
然而,如果我们刷新页面,我们应该会看到一个不同的消息:
!Memcached cached message
正如您所看到的,我们的 memcached 服务现在正在缓存我们的脚本设置的数据。
测试临时缓存数据库值
现在我们已经测试了在 memcached 中存储数据的能力,我们可以演示一个更加现实的场景:临时缓存数据库查询结果。
在 MySQL 中创建示例数据
首先,我们需要在数据库中存储一些信息。
通过以下命令以管理员用户身份连接到 MySQL 实例。您需要输入在安装过程中设置的 MySQL root 密码:
mysql -u root -p
之后,您将进入 MySQL 提示符。
首先,我们要创建一个用于测试的数据库。然后选择该数据库:
CREATE DATABASE mem_test;
USE mem_test;
让我们创建一个名为 test
,密码为 testing123
的用户,并赋予其对我们创建的数据库的访问权限:
GRANT ALL ON mem_test.* TO test@localhost IDENTIFIED BY 'testing123';
现在,我们将创建一个非常基本的表,并向其中插入一条记录。该表将被命名为 sample_data
,并且只包含一个索引和一个字符串字段:
CREATE TABLE sample_data (id int, name varchar(30));
INSERT INTO sample_data VALUES (1, "some_data");
现在,我们已经创建了结构并插入了数据。我们可以退出 MySQL:
exit
创建用于缓存 MySQL 数据的 PHP 脚本
现在我们的数据已经存储在 MySQL 中,我们可以创建另一个 PHP 脚本,其操作方式类似于生产环境中的 PHP 应用程序。
它将在 memcached 中查找数据,如果找到数据,则返回数据。如果没有找到数据,则将从数据库中查询,然后将结果存储在 memcached 中以供将来查询使用。
首先,在我们的文档根目录中创建另一个 PHP 脚本。我们将这个脚本命名为 database_test.php
:
sudo nano /var/www/html/database_test.php
从我们上一个脚本开始。我们将创建一个 PHP memcached 实例,然后告诉它我们服务器上运行的 memcached 服务的位置,就像我们上次做的那样:
<?php
$mem = new Memcached();
$mem->addServer("127.0.0.1", 11211);
?>
接下来,与我们上一个脚本有所不同,我们需要定义 PHP 如何连接到我们的 MySQL 数据库。我们需要指定我们创建的用户的登录凭据,然后告诉它要使用哪个数据库:
<?php
$mem = new Memcached();
$mem->addServer("127.0.0.1", 11211);mysql_connect("localhost", "test", "testing123") or die(mysql_error());
mysql_select_db("mem_test") or die(mysql_error());
?>
接下来,我们需要设计查询,以获取我们插入到表中的数据。我们将把这个查询存储到一个 $query
变量中。
然后,我们将创建一个 $querykey
变量,用于存储 memcached 将用来引用我们信息的键。
我们通过使用字符串 “KEY”,然后将我们查询的 md5(一种哈希方法)校验和附加到末尾来创建此键。这将确保如果我们在更大的数据集上使用此技术,每个键都是唯一的。它还确保匹配的查询将为后续请求产生相同的键。
<?php
$mem = new Memcached();
$mem->addServer("127.0.0.1", 11211);mysql_connect("localhost", "test", "testing123") or die(mysql_error());
mysql_select_db("mem_test") or die(mysql_error());$query = "SELECT ID FROM sample_data WHERE name = 'some_data'";
$querykey = "KEY" . md5($query);
?>
接下来,我们将创建一个 $result
变量,就像我们上一个脚本一样。这将保存我们的 memcached 查询结果,就像以前一样。我们要求 memcached 返回我们生成的查询键,以查看它是否在其系统中标识了一个记录。
<?php
$mem = new Memcached();
$mem->addServer("127.0.0.1", 11211);mysql_connect("localhost", "test", "testing123") or die(mysql_error());
mysql_select_db("mem_test") or die(mysql_error());$query = "SELECT name FROM sample_data WHERE id = 1";
$querykey = "KEY" . md5($query);$result = $mem->get($querykey);
?>
现在,我们准备进行实际的测试逻辑,以确定在 memcached 中找到结果时会发生什么。如果找到结果,我们希望打印我们提取的数据,并告诉用户我们能够直接从 memcached 中检索到它:
<?php
$mem = new Memcached();
$mem->addServer("127.0.0.1", 11211);mysql_connect("localhost", "test", "testing123") or die(mysql_error());
mysql_select_db("mem_test") or die(mysql_error());$query = "SELECT name FROM sample_data WHERE id = 1";
$querykey = "KEY" . md5($query);$result = $mem->get($querykey);if ($result) {print "<p>Data was: " . $result[0] . "</p>";print "<p>Caching success!</p><p>Retrieved data from memcached!</p>";
}
?>
现在,让我们为另一种情况添加逻辑。如果未找到结果,我们希望使用我们创建的查询来直接向 MySQL 请求数据。我们将把这个结果存储到我们创建的 $result
变量中,这将是一个数组形式的结果。
在获得查询结果后,我们需要将该结果添加到 memcached 中,以便下次使用。我们可以通过向 memcached 提供我们要用来引用数据的键(我们已经使用 $querykey
变量创建了这个键)、来自 MySQL 查询的数据本身(存储在 $result
变量中),以及以秒为单位的缓存数据的时间。
我们将缓存我们的内容 10 秒。在现实世界中,缓存内容更长可能更有益。也许如果您的内容不经常更改,那么更接近 10 分钟(600 秒)的时间会更好。对于测试来说,较小的值让我们更快地看到发生的事情,而无需重新启动我们的 memcached 服务。
之后,我们将打印出一个类似的消息与查询结果,并告诉用户发生了什么。我们应该将整个块作为前面 if
的 else
添加:
<?php
$mem = new Memcached();
$mem->addServer("127.0.0.1", 11211);mysql_connect("localhost", "test", "testing123") or die(mysql_error());
mysql_select_db("mem_test") or die(mysql_error());$query = "SELECT name FROM sample_data WHERE id = 1";
$querykey = "KEY" . md5($query);$result = $mem->get($querykey);if ($result) {print "<p>Data was: " . $result[0] . "</p>";print "<p>Caching success!</p><p>Retrieved data from memcached!</p>";
} else {$result = mysql_fetch_array(mysql_query($query)) or die(mysql_error());$mem->set($querykey, $result, 10);print "<p>Data was: " . $result[0] . "</p>";print "<p>Data not found in memcached.</p><p>Data retrieved from MySQL and stored in memcached for next time.</p>";
}
?>
这是我们完成的脚本。它将尝试从 memcached 获取数据并返回它。如果失败,它将直接从 MySQL 查询并将结果缓存 10 秒。
测试脚本
现在我们已经编写了脚本,可以通过在网页浏览器中转到文件位置来运行它:
http://<span class="highlight">server_domain_name_or_IP</span>/database_test.php
第一次访问页面时,我们应该看到以下输出:
Memcached uncached database query
如果我们在上次访问后的 10 秒内刷新页面,现在页面应该显示不同的消息:
Memcached cached database query
如果再等一会儿,缓存的内容将会过期并从 memcached 中移除。此时我们可以刷新页面以再次获得第一条消息,因为服务器必须重新访问数据库以获取适当的值。
结论
到目前为止,您应该已经对 memcached 的工作原理有了相当好的理解,以及如何利用它来避免 Web 服务器重复访问数据库以获取相同的内容。
虽然本指南中创建的 PHP 脚本只是示例,但它们应该让您对系统的工作原理有了很好的了解。它还应该让您对如何构建代码结构有了很好的理解,以便您可以检查 memcached,并在必要时返回数据库。
相关文章:

在Ubuntu 14.04上安装和使用Memcache的方法
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。 简介 随着您的网站的增长和流量的增加,最快显示压力的组件之一是后端数据库。如果您的数据库没有分布式和配置来处理高负载…...

PCDN技术如何降低运营成本?
PCDN技术通过以下几种方式降低运营商的运营成本: 1.利用用户设备作为缓存节点: PCDN技术将用户设备纳入内容分发网络,利用这些设备的闲置带宽和存储资源来缓存和分发内容。这种方式不需要运营商投入大量的高成本服务器和带宽资源,从而降低了硬件和带宽…...

服务器数据恢复—V7000存储硬盘故障脱机的数据恢复案例
服务器存储数据恢复环境: 某品牌P740小型机AIXSybaseV7000磁盘阵列柜,磁盘阵列柜中有12块SAS机械硬盘(其中包括一块热备盘)。 服务器存储故障: 磁盘阵列柜中有一块磁盘出现故障,运维人员用新硬盘替换掉故障…...

BSV区块链在人工智能时代的数字化转型中的角色
发表时间:2024年6月13日 企业数字化转型已有约30年的历史,而人工智能(以下简称AI)将这种转型提升到了一个全新的高度。这并不难理解,因为AI终于使企业能够发挥其潜力,实现更宏大的目标。然而࿰…...

android audio 相机按键音:(二)加载与修改
相机按键音资源,加载文件路径: frameworks/av/services/camera/libcameraservice/CameraService.cpp 按键音,加载函数: void CameraService::loadSoundLocked(sound_kind kind) { ATRACE_CALL(); LOG1("Cam…...

Linux grep技巧 提取log中的json数据
目录 一. 前提1.1 数据准备1.2 需求1.3 分析 二. 数据提取2.1 提取所有的json数据2.2 提取子项目的全部json数据2.3 提取指定项目的json数据 一. 前提 1.1 数据准备 545-1 2024/07/20 18:20:21 [ERROR] MPX001 eventControlleraupay transactionIdA545 {"event":&q…...

HDShredder 7 企业版案例分享: 依照国际权威标准,安全清除企业数据
HDShredder 7 企业版用户案例 天津鸿萌科贸发展有限公司是德国 Miray 公司 HDShredder 数据清除软件的授权代理商。近日,上海某网络科技有限公司采购 HDShredder 7 企业版x4,为公司数据存储资产的安全清除工作流程配备高效的执行工具。HDShredder 7 企业…...

centos系统使用mysqldump数据备份与恢复
文章目录 使用mysqldump备份数据库一、数据库备份1. 基础备份2. 额外选项(一般组合使用) 二、数据库恢复 使用mysqldump备份数据库 一、数据库备份 1. 基础备份 #备份单个数据库 mysqldump -u 用户名 -p 数据库名 > 备份文件.sql#备份多个数据库 mysqldump -u 用户名 -p …...

【element ui】input输入控件绑定粘贴事件,从 Excel 复制的数据粘贴到输入框(el-input)时自动转换为逗号分隔的数据
目录 1、需求2、实现思路:3、控件绑定粘贴事件事件修饰符说明: 4、代码实现🚀写在最后 1、需求 在 Vue 2 和 Element UI 中,要实现从 Excel 复制空格分隔的数据,并在粘贴到输入框(el-input)时自动转换为逗号分隔的数据…...

Chapter18 基于物理的渲染——Shader入门精要学习
Chapter18 基于物理的渲染 一、PBS理论和数学基础1.光是什么微表面模型 2.渲染方程3.精确光源4.双向反射分布函数 BRDF5.漫反射项(Lambert 模型)Lambertian BRDF为:Disney BRDF中漫反射项 6.高光反射项微面元理论BRDF的高光反射项①菲涅尔反射…...

DolphinScheduler学习
1.查看文档 点击访问:https://dolphinscheduler.apache.org/zh-cn/docs 我们可以看到相关的文档简介里有 介绍 DolphinScheduler是Apache DolphinScheduler 是一个分布式易扩展的可视化DAG工作流任务调度开源系统。适用于企业级场景,提供了一个可视化…...

我用Tauri开发的待办效率工具开源了!
开源仓库地址 gitee Git仓库地址:https://gitee.com/zhanhongzhu/zhanhongzhu.git 应用地址 windows应用地址下载 https://kestrel-task.cn 具体内容 也可以看🎉使用Taurivitekoa2mysql开发了一款待办效率应用 这篇文章。 💻技术栈 Tauri: Tauri…...

【黑科技】:Laravel 项目性能提升 20 倍
令人激动的黑科技:Laravel 项目性能提升 20 倍 这个项目能够在无需修改任何代码且无需第三方扩展的前提下,将你的 Laravel 项目性能提高 20 倍。它仅依赖于 PHP 原生的 pcntl、posix、fiber 和 sockets。 项目灵感 起因是看到官方发布的 PHP 8.1 更新…...

User Allocation In MEC: A DRL Approach 论文笔记
论文:ICWS 2021 移动边缘计算中的用户分配:一种深度强化学习方法 代码地址:使用强化学习在移动边缘计算环境中进行用户分配 目录 Ⅰ.Introduction II. MOTIVATION-A.验证假设的观察结果 II. MOTIVATION-A Motivating Example 数据驱动…...

leetcode 69. x 的平方根
可以使用二分查找法或牛顿迭代法来实现 LeetCode 问题 69. x 的平方根。下面是使用二分查找法和牛顿迭代法的 C 实现。 二分查找法 #include <iostream>class Solution { public:int mySqrt(int x) {if (x 0) return 0;int left 1, right x, ans 0;while (left <…...

基于词级ngram的词袋模型对twitter数据进行情感分析
按照阿光的项目做出了学习笔记,pytorch深度学习实战项目100例 基于词级ngram的词袋模型对twitter数据进行情感分析 什么是 N 符? N 格是指给定文本或语音样本中 n 个项目的连续序列。这些项目可以是音素、音节、字母、单词或碱基对,具体取…...

Linux-Centos-改密码(单用户登陆)
笔记一: centos7单用户修改root密码 在CentOS 7中,如果您是唯一的用户或者您确信其他用户不会登录,您可以按照以下步骤来修改root密码: 1.重启系统。 2.启动时出现引导界面时,按任意键进入GRUB菜单。 3.选择要启动的内…...

java实现OCR图片识别,RapidOcr开源免费
先看一下识别效果(自我感觉很牛逼),比Tess4J Tesseract省事,这个还需要训练,安装软件、下载语言包什么的 很费事,关键识别率不高 RapidOcr不管文字的横竖,还是斜的都能识别(代码实现…...

PCB工艺边设计准则
在PCB设计时,通常会在电路板的边缘预留一定的空间,这部分空间被称为工艺边。它有助于在生产过程中确保电路板的尺寸和形状的准确性。以使得组装时更加顺畅、便捷。而工艺边的加工,使得线路板上的元件可以精准地与设备对接,从而提高…...

CTF-NSSCTF题单[GKCTF2020]
[GKCTF 2020]CheckIN 这道题目考察:php7-gc-bypass漏洞 打开这道题目,开始以为考察反序列化,但实际并不是,这里直接用$_REQUEST传入了参数便可以利用了。这里出现了一个eval()函数,猜测考察命…...

redis的分片集群(仅供自己参考)
前言:为什么使用分片集群:因为redis的主从和哨兵机制主要是用来解决redis的高并发读的问题,还有redis的高并发的写的问题没有解决。使用分片集群就可以很好的解决redis写的问题,有多个master就可以实现并发的写。同时,…...

自动驾驶-机器人-slam-定位面经和面试知识系列01之常考公式推导(01)
李群李代数扰动bundle adjustment 这个博客系列会分为C STL-面经、常考公式推导和SLAM面经面试题等三个系列进行更新,基本涵盖了自己秋招历程被问过的面试内容(除了实习和学校项目相关的具体细节)。在知乎和牛客也会同步更新,全网…...

netty入门-5 ServerBootstrap与Bootstarp
前言 本来这篇应该紧接着说明Future和Promise。 但是考虑前文第三篇即用到了ServerBootstrap来启动一个服务器,并且我读的闪电侠netty,先写的服务器与客户端启动这部分。索性就先写出来了。主要内容来自闪电侠netty ServerBootstrap ServerBootstrap就…...

JavaEE - Spring Boot 简介
1.Maven 1.1 什么是Maven 翻译过来就是: Maven是⼀个项⽬管理⼯具。基于POM(Project Object Model,项⽬对象模型)的概念,Maven可以通 过⼀⼩段描述信息来管理项⽬的构建,报告和⽂档的项⽬管理⼯具软件。 可以理解为:Maven是一个项目管理工具…...

SwiftUI革新:Xcode UI开发的新纪元
SwiftUI革新:Xcode UI开发的新纪元 SwiftUI作为Apple推出的声明式UI框架,彻底改变了在Xcode中构建用户界面的方式。它不仅简化了代码,还提高了开发效率,并且使得UI设计更加直观和灵活。本文将深入探讨如何在Xcode中使用SwiftUI进…...

22、基于共享内存的数据结构——用十个块来提高并发性
初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github:codetoys,所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的,可以在任何平台上使用。 为了提高并发性,把…...

【ffmpeg命令入门】实现画中画
文章目录 前言画中画是什么画中画的外观描述效果展示为什么要用画中画应用场景示例 使用FFmpeg添加画中画示例命令参数解释调整嵌入视频的位置调整嵌入视频的大小处理音频 总结 前言 FFmpeg 是一款强大的多媒体处理工具,广泛用于音视频的录制、转换和流处理。它不仅…...

基于 LangChain+LangGraph 来实现一个翻译项目
相信大家在看文档的时候,有时会比较苦恼,比如 AI 相关的文档都是外文,中文文档比较少,看起来会比较吃力,有的时候会看不懂,翻译软件又翻得很乱,完全看不了,今天就基于 LangChain 和 …...

javascript 如何将 json 格式数组转为 excel 表格| sheetJS
案例 // https://unpkg.com/xlsx0.18.5/dist/xlsx.full.min.js function exportXlsx(jsonData, fileName , mine null) {const workbook XLSX.utils.book_new();// 将JSON数组转换成工作表const worksheet XLSX.utils.json_to_sheet(jsonData);// 向工作簿添加工作表XLSX.…...

网页制作技术在未来会如何影响人们的生活?
网页制作技术在未来会如何影响人们的生活? 李升伟 网页制作技术在未来可能会从以下几个方面显著影响人们的生活: 1. 工作与学习方式的变革:远程办公和在线教育将更加普及和高效。通过精心制作的网页,人们能够实现更便捷的协作…...