亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Perl > 正文

Perl集群配置管理系統Rex簡明手冊

2020-10-31 15:16:31
字體:
來源:轉載
供稿:網友

Rex 是 Perl 編寫的基于 SSH 鏈接的集群配置管理系統,語法上類似 Puppet DSL。官網中文版見 http://rex.perl-china.com 。本文僅為本人在部門 Wiki 上編寫的簡介性文檔。

常用命令參數

rex 命令參數很多,不過因為我們的環境是 krb 認證的,所以有些參數只能寫在 Rexfile 里。所以一般固定在存放了 Rexfile 的 /etc/puppet/webui 下執行命令,很多配置就自動加載了。那么還需要用到的命令參數基本就只有下面幾個:
-Tv: 查看當前 Rexfile 里定義了哪些 Task 任務,以及服務器組。
-H: 指定 Task 將在哪些 Host 上執行。這里比較方便的地方是支持 10.5.16.[95..110] 這樣的寫法。
-G: 指定 Task 將在哪些 Group 上執行。Group 的定義方式很多,Rex 默認支持的有直接在 Rexfile 里通過 group 指令指定,通過 ini 配置文件設定等等。目前我是實現了一個 groups_db 指令,來從我們的 sqlite 里獲取。groups_db('cdnbj::nginx') 就會自動生成一個名叫 ‘cdnbj::nginx' 的服務器組,包括 cdnbj 里所有部署了 nginx 的服務器。
-e: 指定一個臨時任務。通常是'say run “ipconfig”‘這樣的簡單命令形式。如果需要復雜邏輯,還是在 Rexfile 里書寫 Task。
-q:指定運行日志級別,有 -q 和 -qq。
-d:指定運行日志級別,有 -d 和 -dd。

Rexfile 介紹

參數設置部分:

復制代碼 代碼如下:

    set connection => "OpenSSH";
    user "root";
    krb5_auth;
    parallelism 10;

這四行指定采用 kerberos 認證,并發 10 個進程執行 ssh 命令。
復制代碼 代碼如下:

    desc "install puppet agent";
    task "puppet_install", sub {
    }
    before "puppet_install", sub {
    }
    after "puppet_install", sub {
    }

這幾行就是 Rexfile 的任務定義主體格式。task 指令定義任務,任務會在具體的 -H 或者 -G 服務器上執行。其他都是可選項,desc內容會在 -Tv 的時候顯示;before 和 after 定義的任務會在執行對應 task 之前或之后,在'''rex命令執行處,即10.4.1.21本地'''執行。

常用指令介紹

run

運行命令。如果有回調函數,那么會把 stdout 和 stderr 傳給回調函數;如果沒有,直接把 stdout 作為返回值。

比如:

復制代碼 代碼如下:

say run "uptime";
    run "nginx -v", sub { my ($out, $err) = @_; say $err };

file

分發文件。語法類似 Puppet 的 file。支持 source、template、ensure、on_change 等操作。注意:rex 是順序執行 Rexfile 的,所以不用設置 Puppet 的 require 指令。

比如:

復制代碼 代碼如下:

    file "/etc/yum.repos.d/xiaonei-private.repo",
      source => "repos/xiaonei-private.repo";
    file "/etc/nginx/nginx.conf",
      content => template("templates/etc/nginx/nginx.conf.tpl"),
      owner  => "nginx",
      group  => "nginx",
      mode   => 644,
      ensure => 'file',
      on_change => sub { service nginx => "restart"; };
    file "/etc/nginx/conf.d",
      ensure => "directory",

pkg

安裝軟件包,在早期版本命令寫作 install package => "nginx" ,最近改成 pkg 了,更像 Puppet 語法了。

也支持傳遞數組作為 pkg 內容。另外,rex 還 提供了一個 update_package_db 指令,用于執行 yum clean all 或者 apt-get update 操作。這點是 Puppet 欠缺的。

比如:

復制代碼 代碼如下:

 update_package_db();
   my $packages = case operating_system,
      Debian => ["apache2", "libphp5-apache2"],
      CentOS => ["httpd", "php5"],
   pkg $packages,
     ensure => "present";

ensure 也支持 present、absent、latest 等幾種含義。同 Puppet。

account

用戶管理原先用 create_user 和 create_group 指令,最近把 create_user 更新為 account 指令。

比如:

復制代碼 代碼如下:

  create_group 'puppet';
  account "puppet",
    ensure   => "present",
    uid      => 509,
    home     => '/home/puppet',
    comment  => 'Puppet Account',
    expire   => '2015-05-30',
    groups   => ['puppet'],
    password => 'puppet',
    system   => 1,
    no_create_home => TRUE,
    ssh_key        => "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQChUw...";

tail

用來同時觀測多臺主機的日志的最新追加情況。應該是比較有用的一個小功能。代碼如下:

復制代碼 代碼如下:

   tail "/var/log/syslog", sub {
     my ($data) = @_;
     my $server = Rex->get_current_connection()->{'server'};
     print "$server>> $data/n";
   };

遠程主機詳情相關變量

Puppet 有專門的 Facts 變量來判定遠程主機的詳情。Rex 因為走 SSH 連接,不會在遠程主機上跑一個 agent 來收集這些信息,所以還是通過遠程執行命令的方式來提供相關內容。目前常用的幾個函數(也可以認為是變量)有:

is_redhat

這個用來判斷操作系統是否是 RedHat 系列。之前因為有一批 Debian 的機器,所以 Rexfile 里一直有這么個操作邏輯:

復制代碼 代碼如下:

    if ( is_debian ) {
    } elsif ( is_redhat ) {
    } else {
    }

operating_system_version

這個用來判斷具體的操作系統版本號。比如 CentOS5 跟 CentOS6 應該應用的操作就不一樣,甚至 CentOS6.5 和 CentOS6.2 也有可能不一致。

比如 Rexfile 里的 1w10 任務:

復制代碼 代碼如下:

    if ( is_redhat and operating_system_version >= 64 )
    }

route

rex 可以收集的信息比 puppet 要多很多,比如網絡相關、sysctl 相關等等。Rexfile 里的 1w10 任務用到了 route 信息來獲取默認網關和網卡接口。

復制代碼 代碼如下:

    my ($default_route) = grep {
      $_->{"flags"} =~ m/UG/ && (
        $_->{"destination"} eq "0.0.0.0" ||
        $_->{"destination"} eq "default" )
      } route;
    if ($default_route) {
        my $default_gw = $default_route->{"gateway"};
        my $default_if = $default_route->{"iface"};
        run "ip route change default via ${default_gw} dev ${default_if} initcwnd 10 initrwnd 10";
    };

connection

在多臺主機執行任務的時候,大多希望在輸出的時候看到某條結果是哪個主機返回的。前面 tail 任務就用到了,不過寫起來非常復雜的樣子。其實 rex 提供給更簡潔一點的寫法。就是 connection->server。

復制代碼 代碼如下:

  task 'tellmewhoyouare', sub {
    say connection->server;
  }

當前連接的服務器的整個信息,也可以通過 get_system_information 指令來獲取,這兩個指令其實是等同的。不過根據字面意思一般用來不同語境下。

這些信息如果要完整查看,可以通過 dump_system_information 指令來查看。這個命令跟 print Dumper get_system_information() 不一樣的是,會把每個鍵作為單獨變量。而這些變量就是可以直接用于 rex 的 template 里的內嵌變量。比如:

復制代碼 代碼如下:

  listen <%= $eth0_ip %>:80;
  visible_hostname <%= $hostname %>

不在 dump_system_information 清單里的變量,也想在 template 里使用的,就必須顯式傳遞。這點和 Puppet 不一致,puppet 在 template 里可以通過 scope.lookupvar() 指令獲取任意pp類里設定的變量,這一點完全無視詞法作用域的存在==!

比如:

復制代碼 代碼如下:

   file '/etc/elasticsearch/elasticsearch.yml',
     content => template('files/es.yml.tmpl', conf => {
       clustername => 'logstash'
     });

對應的 es.yml.tmpl 里寫作:
復制代碼 代碼如下:

  clustername: <%= $conf->{'clustername'} %>

這樣才行。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91国内在线视频| 国产精品高潮呻吟久久av黑人| 国产精品扒开腿做| 91wwwcom在线观看| 国产精品久久电影观看| 国产91精品最新在线播放| 啪一啪鲁一鲁2019在线视频| 日韩精品中文字幕有码专区| 奇米影视亚洲狠狠色| 亚洲精品自产拍| 91在线视频免费| 欧美一级片一区| 日韩av影视在线| 欧美黑人国产人伦爽爽爽| 久久999免费视频| 国产日韩中文字幕| 精品中文字幕久久久久久| 国产精品久久久久免费a∨| 欧美激情videos| 亚洲区中文字幕| 欧美亚洲第一区| 亚洲第一视频在线观看| 欧美一级视频一区二区| 日韩精品亚洲元码| 欧美性猛交xxxx偷拍洗澡| 中文字幕日韩免费视频| 亚洲高清一二三区| 亚洲精品国偷自产在线99热| 亚洲一二三在线| 97视频免费看| www国产精品视频| 免费91麻豆精品国产自产在线观看| 精品亚洲一区二区三区四区五区| 69久久夜色精品国产69乱青草| 欧美精品videossex性护士| 欧美激情久久久久久| 精品亚洲男同gayvideo网站| 国产精品爽爽爽爽爽爽在线观看| 国产精国产精品| 国产精品久久婷婷六月丁香| 国产精品白嫩初高中害羞小美女| 欧美成人性色生活仑片| 亚洲成人精品av| 精品久久久久久电影| 国产丝袜一区二区| 国产亚洲美女精品久久久| 久久久久久久97| 欧美日本在线视频中文字字幕| 国产精品久久久久久久久久尿| 日韩免费av片在线观看| 国产精品美女午夜av| 国产精品福利小视频| 日本韩国在线不卡| 久久69精品久久久久久久电影好| 欧美刺激性大交免费视频| 8x拔播拔播x8国产精品| 亚洲综合在线做性| 国产一区二区黑人欧美xxxx| 亚洲人成免费电影| 国产成人在线一区| 日韩av在线网| 亚洲va欧美va在线观看| 亚洲欧美日韩区| 国产精品视频地址| 久久久久久国产| 欧美性感美女h网站在线观看免费| 欧美黄色片视频| 国产精品视频区1| 9.1国产丝袜在线观看| 欧美高清自拍一区| 国产成人在线亚洲欧美| 精品成人国产在线观看男人呻吟| 热久久99这里有精品| 亚洲国产欧美一区二区三区同亚洲| 欧美色视频日本高清在线观看| 欧美激情综合亚洲一二区| 国产精品日韩在线| 亚洲qvod图片区电影| 亚洲精品久久久久久久久久久久| 国产在线a不卡| 久久久久久久久久久亚洲| 欧美一级大胆视频| 中文字幕日韩av综合精品| 亚洲精品久久久久久下一站| 日韩免费视频在线观看| 亚洲最大中文字幕| 欧美在线一级va免费观看| 韩国19禁主播vip福利视频| 视频在线观看一区二区| 国产精品久久久久久亚洲影视| 成人亚洲欧美一区二区三区| 久久久久久久久亚洲| 日韩中文字幕久久| 精品国产一区二区三区四区在线观看| 综合欧美国产视频二区| 欧美老少配视频| 国产日韩在线观看av| 亚洲自拍中文字幕| 欧美成人自拍视频| 亚洲精品久久久久久久久久久久| 亚洲欧洲在线观看| 久久亚洲综合国产精品99麻豆精品福利| 亚洲国产天堂网精品网站| 亚洲人成电影在线播放| 精品国内产的精品视频在线观看| 亚洲三级 欧美三级| 国产精品久久久久久久久久小说| 国内外成人免费激情在线视频网站| 日韩中文字幕视频在线| 日韩欧美大尺度| 欧美疯狂做受xxxx高潮| 欧美日韩免费看| 91精品国产色综合久久不卡98口| 黑人精品xxx一区一二区| 亚洲成成品网站| 国产精品啪视频| 亚洲国产精品视频在线观看| 一本色道久久88亚洲综合88| 亚洲第一男人av| 亚洲一级一级97网| 欧美成人h版在线观看| 日韩av免费在线看| 亚洲国产日韩欧美在线图片| 亚洲欧美综合图区| 精品国产91乱高清在线观看| 在线观看免费高清视频97| 久久久久亚洲精品国产| 国产精品美女在线| 亚洲精品免费一区二区三区| 亚洲第一级黄色片| 国产精品av在线| 久久久久女教师免费一区| 成人av在线天堂| 中文字幕亚洲天堂| 亚洲伊人一本大道中文字幕| 久久久久久国产精品三级玉女聊斋| 91网站在线免费观看| 欧美激情在线观看| 欧美人与性动交a欧美精品| 91成人国产在线观看| 欧美美女18p| 亚洲精品动漫100p| 一区二区三区国产在线观看| 97国产一区二区精品久久呦| 成人精品视频在线| 亚洲欧美制服丝袜| 777国产偷窥盗摄精品视频| 国产精品激情自拍| 91精品久久久久久久久久久久久| 午夜精品一区二区三区在线播放| 国产精品爽爽爽| 成人久久精品视频| 岛国视频午夜一区免费在线观看| 国产一区二区三区在线观看网站| 亚洲一区www| 亚洲精品av在线| 91视频免费在线| 欧美国产日韩一区二区| 热re91久久精品国99热蜜臀| 激情懂色av一区av二区av| 正在播放欧美一区| 欧美最猛性xxxxx(亚洲精品)| 久久久www成人免费精品张筱雨| 欧美午夜精品久久久久久久|