一.Lua脚本介绍

  Lua 是用标准C语言编写并以源代码形式开放的一种轻量小巧的脚本语言,设计目的是为了嵌入应用程序中,为应用程序提供灵活的扩展和定制功能。由于体积小只有200多kb,可以很容易放入集成在一些软件系统里。可以为一些中间件提供支持功能,比如nginx,redis。 Lua脚本可以很容易的被C/C++ 代码调用,也可以反过来调用C/C++的函数。

  Lua官网 :http://www.lua.org/

  Lua官方文档:http://www.lua.org/manual/5.3/

  Lua安装手册:https://www.php.cn/lua/lua-environment.html

二.Lua脚本安装

  安装lua

curl -R -O http://www.lua.org/ftp/lua-5.3.0.tar.gz
tar zxf lua-5.3..tar.gz
cd lua-5.3.
make linux test
make install
如果在make linux test 这步出现问题    lua.c:80:31: 致命错误:readline/readline.h:没有那个文件或目录
执行以下语句
解决:
yum  install   libreadline-dev  这个我本地不行
yum -y install readline-devel 或者
yum install readline-dev readline-devel 安装完成后 然后在执行
make linux test
make install 安装完成后 查看是否成功安装

说明已经lua已经安装成功

在查看版本

在创建一个脚本试下lua一个程序

创建一个 脚本HelloWorld.lua

里面编写

print("lua Hello World!")

然后执行

 三.Lua脚本和Redis关系

  Reids 2.6 版本中自带Lua 脚本功能, 通过内嵌对 Lua 环境的支持, Redis 解决了长久以来不能高效地处理 CAS (check-and-set)命令的缺点,比如使用Redis原生命令,需要从Redis中获取某个key,然后提取其中的值进行比对,如果相等就不做处理,如果不相等或者key不存在则将key设置成目标值。仅仅一个单点的compare and set操作就需要与Redis通讯两次。此外,这种分散操作无法利用Redis的原子特性,占用多次网络IO。使用Lua脚本就可以通过组合打包使用多个命令, 轻松实现以前很难实现或者不能高效实现的模式。

四.Redis中使用Lua脚本

  redis中通过EVAL命令去调用Lua。

    官网说明地址: http://www.redis.cn/commands/eval.html

    语法:

EVAL script numkeys key [key ...] arg [arg ...]

参数说明:

  • script:     参数是一段 Lua 脚本程序,是一段lua脚本字符串。
  • numkeys: 用于指定键名参数的个数。
  • key [key ...]: 从 EVAL 的第三个参数开始算起,表示在脚本中所用到的那些 Redis 键(key),这些键名参数可以在 Lua 中通过全局变量 KEYS 数组,用 1 为基址的形式访问( KEYS[1] , KEYS[2] ,以此类推)。
  • arg [arg ...]: 附加参数,在 Lua 中通过全局变量 ARGV 数组访问,访问的形式和 KEYS 变量类似( ARGV[1] 、 ARGV[2] )。

具体调用示例

127.0.0.1:> EVAL "redis.call('SET','redis-call-lua-key','redis-call-value')" 0      #redis.call是redis搭建在lua环境中默认加载的类库才有的
(nil)
127.0.0.1:> get redis-call-lua-key      #查看执行成功
"redis-call-value"

上面返回nil是因为lua脚本没有返回值,redis接受不到返回值就返回nil。加上return就可以返回ok。

127.0.0.1:> EVAL "return redis.call('SET','redis-call-lua-key','redis-call-value1')" 
OK
127.0.0.1:> get redis-call-lua-key
"redis-call-value1"

我们也可以在redis中缓存Lua脚本,然后下次使用时候在调用。

先看看如何缓存Lua脚本

127.0.0.1:> SCRIPT LOAD "return redis.call('SET',KEYS[1],ARGV[1])"
"cf63a54c34e159e75e5a3fe4794bb2ea636ee005"

执行缓存的Lua脚本

127.0.0.1:> EVALSHA cf63a54c34e159e75e5a3fe4794bb2ea636ee005  LuaKey1 LuaKey2 LuaValue
OK
127.0.0.1:> get LuaKey1
"LuaValue"

  通过SCRIPT LOAD命令将Lua脚本命令缓存,并生成返回了一个固定长度的hash字符串,不管你的Lua脚本命令由多长,都会返回这个定长的hash字符。这样做的好处是减少网络的传输,因为redis客户端向服务器传输大段的lua脚本命令时候,这回增加网络开销,而将Lua命令缓存在redis中,客户端只需要传递这个固定长度的hash字符串来减少传输的消耗,同时脚本缓存在redis中也可以防止脚本被篡改。


												

【lua】lua安装学习的更多相关文章

  1. lua脚本之lua语言简介以及lua的安装

    本博主不擅于进行文字创作,所以,相当一部分文字皆复制于其他博文.还希望能够得到谅解.  一.Lua语言简介 Lua是一个免费的开源软件,可以免费用于科研及商业.Lua具有一个专家团队在维护和升级,其设 ...

  2. 热更新(一) 之Lua语法的学习

    热更新 如热更新果需要更换UI显示,或者修改游戏的逻辑,这个时候,如果不使用热更新,就需要重新打包,然后让玩家重新下载(浪费流量和时间,体验不好).热更新可以在不重新下载客户端的情况下,更新游戏的内容 ...

  3. lua的corroutine学习

    lua的corroutine学习 function receive (prod) local status, value = coroutine.resume(prod) return value e ...

  4. Mac OS X 上Lua的安装方法

    先在Mac OS的终端查询下本机是否已安装Lua Last login: Thu Jul 10 07:54:48 on ttys000 keshans-Mac-mini:~ keshan$ lua - ...

  5. tengine+lua的安装步骤

    我是在Red Hat 5.8 的虚机上安装的. Nginx的一些模块需要其他第三方库的支持,例如gzip模块需要zlib库,rewrite模块需要pcre库,ssl功能需要openssl库等.建议把这 ...

  6. Lua的安装

      Lua 是一个扩展式程序设计语言,它被设计成支持通用的过程式编程,并有相关数据描述的设施. Lua 也能对面向对象编程,函数式编程,数据驱动式编程提供很好的支持.它可以作为一个强大.轻量的脚本语言 ...

  7. [译] Closures in Lua - Lua中的闭包

    原文:(PDF) . 摘要 一等(first-class)函数是一种非常强大的语言结构,并且是函数式语言的基础特性.少数过程式语言由于其基于栈的实现,也支持一等函数.本文讨论了Lua 5.x用于实现一 ...

  8. [转][译] Closures in Lua - Lua中的闭包

    http://www.cnblogs.com/plodsoft/p/5900270.html?utm_source=tuicool&utm_medium=referral 原文:(PDF) . ...

  9. python3数据分析,安装学习

    python3数据分析,安装学习 转载注明来源: 本文链接 来自osnosn的博客,写于 2019-09-26. 为了简单.安装 anaconda3 就好啦. 因为安装原版python3,用pip安装 ...

随机推荐

  1. openstack,docker,mesos,k8s关系

    openstack,docker,mesos,k8s什么关系? - 知乎https://www.zhihu.com/question/62985699 OpenStack + K8S 环境集成测试ht ...

  2. Spark源码编译,官网学习

    这里以spark-1.6.0版本为例 官网网址   http://spark.apache.org/docs/1.6.0/building-spark.html#building-with-build ...

  3. ArrayList的扩容机制

    一.ArrayList的扩容机制 1.扩容的计算方式是向右位移,即:newSize = this.size + (this.size>>1).向右位移,只有在当前值为偶数时,才是除以2:奇 ...

  4. java回调机制——基本理解

    回调(diao):往回调用,反向调用. 英文 call back.call:调用,back:返回,往返. 回调的意思就是杀个回马枪...... 回调(callback),既然是往回调用,那自然有一个正 ...

  5. python爬虫scrapy之scrapy终端(Scrapy shell)

    Scrapy终端是一个交互终端,供您在未启动spider的情况下尝试及调试您的爬取代码. 其本意是用来测试提取数据的代码,不过您可以将其作为正常的Python终端,在上面测试任何的Python代码. ...

  6. Plugin/Preset files are not allowed to export objects,webpack报错/babel报错的解决方法

    1.为什么会报错 ? 这里抱着错误是因为 babel 的版本冲突. 多是因为你的 babel 依赖包不兼容. 可以查看你的 package.json 的依赖列表 即有 babel 7.0 版本的( @ ...

  7. 关于浏览器兼容问题——还有移动端meta问题

    <!DOCTYPE html><!--[if lt IE 7]> <html dir="ltr" lang="en-US" cla ...

  8. Play framework框架中通过post方式发送请求

    搞了好久这个最终还是在play官方文档中看见的发送请求的方式,国内好像很少有使用这个框架的,加之自己不是太愿意宣传,好东西总归是好东西,不说废话了. 在play中发送请求有两种常用的方式,一种get, ...

  9. JS操作Cookies

    JS操作Cookies 获取Cookie function getCookie(c_name) { if (document.cookie.length > 0) { c_start = doc ...

  10. BZOJ2150部落战争——最小路径覆盖

    题目描述 lanzerb的部落在A国的上部,他们不满天寒地冻的环境,于是准备向A国的下部征战来获得更大的领土. A国是一 个M*N的矩阵,其中某些地方是城镇,某些地方是高山深涧无人居住.lanzerb ...