简介:
func: fedora 上的统一网络控制器
func为我们带来了什么:
· 你曾经试图命令或查询的系统大量使用SSH? 你想要一个更好的办法?
·你需要一个方法来审核你的系统你所有的远程命令呢?
·厌倦了编写shell脚本和解析命令的输出?
·你是美联储通过CIM,WBEM的,复杂的通信系统,防止doing /real/ work??
·那么我们有没有给你买了一个解决方案。 它的 功能 。
func几乎可以解决运维上任何问题:
一个方案,系统和一些工具,需要大量的沟通方式。功能提供了一种双向认证的统称做这些事情的排序制度。你可以建立自己的在顶部,这样,很容易扩大应用在其他模块添加功能,无论你 希望通过这些工作func命令行或其他一些应用的手段。如果你只是想用命令行的功能,这是伟大的。如果你想建立应用程序的功能工具,那也很好。如果这听起来很笼统空泛,它只是因为它确实是容易扩展。
下载源码:
git clone git://git.fedorahosted.org/certmaster.git git clone git://git.fedorahosted.org/func.git 或者: wget https://fedorahosted.org/releases/f/u/func/func-0.27.tar.gz wget https://fedorahosted.org/releases/c/e/certmaster/certmaster-0.27.tar.gz
#修改 master机器 hosts
127.0.0.1 localhost 127.0.1.1 mysql 127.0.1.1 certmaster 192.168.6.161 master 192.168.6.160 minions
#修改 minions机器 hosts
127.0.0.1 localhost 127.0.1.1 slave 192.168.6.161 master 192.168.6.160 minions
以git 为例:
安装 func
master $> cd func master $> make clean master $> make install master $> cd ..
安装certmaster
master $> cd certmaster master $> make clean master $> make install
#修改配置文件:
master $> vim /etc/certmaster/certmaster.conf
[main] autosign = no listen_addr = listen_port = 51235 cadir = /etc/pki/certmaster/ca cert_dir = /etc/pki/certmaster certroot = /var/lib/certmaster/certmaster/certs csrroot = /var/lib/certmaster/certmaster/csrs cert_extension = cert sync_certs = False
master $> vim /etc/certmaster/minion.conf
[main] certmaster = certmaster certmaster_port = 51235 log_level = DEBUG cert_dir = /etc/pki/certmaster
minions 机器上安装master的安装步骤。
配置:
minions $> vim /etc/certmaster/minion.conf
[main] certmaster = master #对应master 和minions hosts文件 的名字或者IP地址 certmaster_port = 51235 log_level = DEBUG cert_dir = /etc/pki/certmaster
minions $> vim /etc/func/minion.conf
[main] log_level = INFO acl_dir = /etc/func/minion-acl.d listen_addr = listen_port = 51234 #端口与master 一致 minion_name = minions #这个名字就是master和minions里定义的名字。 method_log_dir = /var/log/func/methods/
在 master 启动服务
master $> /etc/init.d/certmaster start
在minions 端启动服务
minions $> /etc/init.d/funcd start
master端操作
查看为签发证书列表:
master $> certmaster-ca --list
minions
为客户端签发证书:
master $> certmaster-ca --sign minions
#OK 可以使用了
例子:
master $> func '*' ping
[ ok ... ] minions
master $> func "*" call command run "date"
('minions', [0, 'Fri Jan 21 16:13:09 CST 2011\n', ''])