设为首页 收藏本站
查看: 1010|回复: 0

[经验分享] perl操作memcache-Linux的生活

[复制链接]

尚未签到

发表于 2018-8-31 10:14:37 | 显示全部楼层 |阅读模式
  想到用perl操作memcache的原因,是因为需要从一个数据库里取数据,然后插入另外一个数据库中(从mysql里取数据,插入到postgresql),mysql是在用的数据库,而postgresql则是存放所有历史数据的。由于不是实时取的,在一段时间间隔里,可能会有大量的数据需要取,如果是直接取一条插一条的话,可能时间会比较慢,并且影响到数据库的性能。
  所以就想如果能把取出来的数据尽可能快的存放到一个地方去,然后再从那个地方取出来存放到postgresql,这样即不影响Mysql的性能,也提高的效率。常用的存储介质中自然是放到内存里最快的了,然后就想到nosql,在这么多的nosql产品中,memcache比较熟悉,故此,就选用了memcache,将要取的数据先存放到memcache里,然后,再从memcache里取数据存放到postgresql里。
  思路有了,然后就开始实施了,要操作memcache、mysql、postgresql,需要安装相应的perl模块,cpan直接搞定,下面的代码是测试的代码:
  


  • #/usr/bin/perl -w
  • use strict;
  • use Data::Dumper;
  • use DBI;
  • use DBD::Pg;
  • use Cache::Memcached;

  • my $dbname='zabbix';
  • my $uname='zabbix';
  • my $pw='zabbix';
  • my $host='192.168.65.219';
  • my $port="5432";
  • my $mc_expires=500000;

  • #connect database
  • my $dbh=DBI->connect("dbi:Pg:dbname=$dbname;host=$host;port=$port",$uname,$pw,{AutoCommit => 1});

  • #my $sth=$dbh->prepare("select userid,alias,name,surname,passwd from users");
  • my $sth=$dbh->prepare(&quot;select * from history where clock < 1348037308;&quot;);
  • $sth->execute();

  • #connect memcache
  • my $mem = new Cache::Memcached({
  •      servers =>[&quot;192.168.65.219:11211&quot;],
  •      });
  • $mem->set_connect_timeout(0.1);

  • my $row;
  • #my $key,$value;
  • my %row_hash;
  • while($row = $sth -> fetchrow_hashref)
  • {
  • #  print Dumper($row);
  •   my $zb_itemid=$row -> {itemid};
  • my $zb_value=$row -> {value};
  •   my $zb_ns=$row -> {ns};

  •   my $key=$row->{clock};
  •   printf(&quot;$key\n&quot;);

  • #  $mem->set($key,{array1122 => ['a11','b22','c333'],someone => {aaa => &quot;bbb&quot;, 444 => &quot;dddd&quot;}, sss => &quot;eee&quot;},$mc_expires);
  •   $mem->set($key,{$key=>{zb_itemid=>&quot;$zb_itemid&quot;,zb_value=>&quot;$zb_value&quot;,zb_ns=>&quot;$zb_ns&quot;}});
  •   my $test = $mem->get($key);
  •   printf(&quot;$test->{$key}->{zb_itemid}\n&quot;);
  •   print Dumper($test) . &quot;\n&quot;;
  

  上面代码操作zabbix的数据库的,目的是从现在正在使用的zabbix数据库中,取出history这张表的数据出来,存放到memcache里去,然后再从memcache里取数据,存放到postgresql数据库里去。
  这里取出的数据以clock为key,其他字段为value,存放到memcache里去,perl操作memcache和php操作有些不一致,php可以将多个字段的值存放在一个数组里,然后再将这个数组作为value存放到memcache里。
  但perl不行,如果直接将数组作为value的话,则只能将数组的第一个值存放到memcache里,那么数组的引用可以吗?这样是可以的,如下代码:
  


  • while($row = $sth -> fetchrow_hashref)
  • {
  • #  print Dumper($row);
  •   my $zb_itemid=$row -> {itemid};
  •   my $zb_value=$row -> {value};
  •   my $zb_ns=$row -> {ns};

  •   my @data=(&quot;$zb_itemid&quot;,&quot;$zb_value&quot;,&quot;$zb_ns&quot;);
  •   my $insert_data=\@data;
  • #插入的时候,使用数组引用
  • $mem->set($key,$insert_data,$mc_expires);
  •   my $test=$mem->get($key);
  •   print Dumper($test) . &quot;\n&quot;;
  

  得到如下的数据结构:
DSC0000.png

  从得到的数据结构来看,$mem->get($key)得到的是数组的引用,要得到真实的数据,还得解引用,如下方式:
  


  • printf(&quot;$test->[0]  $test->[1]  $test->[2]\n&quot;);
  

  这样才能得到真实的数据。如果这样操作的话,只能按照数组的下标来操作数据。
  在cpan里的例子是这样来操作memcache的:
  


  • $memd->set(&quot;my_key&quot;, &quot;Some value&quot;);
  • $memd->set(&quot;object_key&quot;, { 'complex' => [ &quot;object&quot;, 2, 4 ]});
  

  这样是以一个匿名hash的方式来存放一组数据的,具体的操作方式还可以有以下几种:
  


  • #匿名hash中value是一个匿名数组
  • $mem->set($key,{array1122 => ['a11','b22','c333']});
  • #匿名hash中的匿名hash
  • $mem->set($key,{someone => {aaa => &quot;bbb&quot;, 444 => &quot;dddd&quot;});
  • #hash中的hash
  • $mem->set($key,{sss => &quot;eee&quot;});
  

  以上操作可以单独用,也可以混合用,可以根据实际情况来定。
  写完这篇博客的时候,最终要用到哪种方式,还没确定好。
  



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-559252-1-1.html 上篇帖子: Perl程序中显示进度条之多姿多彩的自写代码 下篇帖子: linux perl 脚本 邮件
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表