OSSEC 安装详解

简介

写在前面的话,网上能够找到一些关于ossec方面的资料,虽然很少,但是总比没有强,不过在实际的使用过程中还是会碰到许多稀奇古怪的问题。整理整理我的使用过程,就当做一篇笔记吧。

PS:本文填了很多坑。

OSSEC是一款开源的基于主机的***检测系统,可以简称为HIDS。它具备日志分析,文件完整性检查,策略监控,rootkit检测,实时报警以及联动响应等功能。它支持多种操作系统:Linux、Windows、MacOS、Solaris、HP-UX、AIX。属于企业安全之利器。

详细的介绍和文档可以参考官网网站:

http://www.ossec.net/

环境

本文中的环境极其简单,两台CentOS 6.4虚拟机。

服务端

计算机名:ossec-server

IP地址:192.168.1.110

客户端

计算机名:ossec-agent

IP地址:192.168.1.104

准备

我们以一个全新的CentOS 6.4为基础的操作系统为例实际讲述如何进行安装。

首先我们安装需要用到的关联库和软件,由于我们最终是需要把日志导入到MySQL中进行分析,以及需要通过web程序对报警结果进行展示,同时需要把本机当做SMTP,所以需要在本机安装MySQL、Apache和sendmail服务。在当前的终端中执行如下命令:

[root@ossec-server ~]# yum install wget gcc make mysql mysql-server mysql-devel httpd php php-mysql sendmail

启动httpd、mysql、sendmail服务

[root@ossec-server ~]# /etc/init.d/httpd start

[root@ossec-server ~]# /etc/init.d/mysqld start

[root@ossec-server ~]# /etc/init.d/sendmail start

下面创建数据库以方便我们下面的安装配置,连接到本机的MySQL,然后执行如下命令:

[root@ossec-server ~]# mysql -uroot -p

mysql> create database ossec;

mysql> grant INSERT,SELECT,UPDATE,CREATE,DELETE,EXECUTE on ossec.* to ossec@localhost;

mysql> set password for ossec@localhost=PASSWORD('ossec');

mysql> flush privileges;

mysql> exit

######################################################################################################################

安装OSSEC服务端

首先通过官网的链接下载当前的最新稳定版本 2.7 的服务端包,同时解压。

[root@ossec-server ~]# wget http://www.ossec.net/files/ossec-hids-2.7.tar.gz

[root@ossec-server ~]# tar zxf ossec-hids-2.7.tar.gz

[root@ossec-server ~]# cd ossec-hids-2.7

为了使OSSEC支持MySQL,需要在安装前执行make setdb命令,如下

[root@ossec-server ~]# cd src; make setdb; cd ..

看到如下的信息说明可以正常支持MySQL:

Info: Compiled with MySQL support.

下面进入安装步骤,执行install.sh脚本:

[root@ossec-server ossec-hids-2.7]# ./install.sh

(en/br/cn/de/el/es/fr/hu/it/jp/nl/pl/ru/sr/tr) [en]: cn

您将开始 OSSEC HIDS 的安装.

请确认在您的机器上已经正确安装了 C 编译器.

– 按 ENTER 继续或 Ctrl-C 退出. –

1- 您希望哪一种安装 (server, agent, local or help)? server

选择了 Server 类型的安装.

2- 正在初始化安装环境.

请选择 OSSEC HIDS 的安装路径 [/var/ossec]: /opt/ossec

OSSEC HIDS 将安装在  /opt/ossec .

3- 正在配置 OSSEC HIDS.

3.1- 您希望收到e-mail告警吗? (y/n) [y]:

- 请输入您的 e-mail 地址? youmailaddress

我们找到您的 SMTP 服务器为: xxx.xxxx.xxx.xxxx

您希望使用它吗? (y/n) [y]: n

请输入您的 SMTP 服务器IP或主机名 ? 127.0.0.1

3.2- 您希望运行系统完整性检测模块吗? (y/n) [y]:

系统完整性检测模块将被部署.

3.3- 您希望运行 rootkit检测吗? (y/n) [y]:

rootkit检测将被部署.

3.4- 关联响应允许您在分析已接收事件的基础上执行一个

已定义的命令.

例如,你可以阻止某个IP地址的访问或禁止某个用户的访问权限.

更多的信息,您可以访问:

http://www.ossec.net/en/manual.html#active-response

您希望开启联动(active response)功能吗? (y/n) [y]:

关联响应已开启

默认情况下, 我们开启了主机拒绝和防火墙拒绝两种响应.

第一种情况将添加一个主机到 /etc/hosts.deny.

第二种情况将在iptables(linux)或ipfilter(Solaris,

FreeBSD 或 NetBSD)中拒绝该主机的访问.

该功能可以用以阻止 SSHD 暴力***, 端口扫描和其他

一些形式的***. 同样你也可以将他们添加到其他地方,

例如将他们添加为 snort 的事件.

您希望开启防火墙联动(firewall-drop)功能吗? (y/n) [y]:

防火墙联动(firewall-drop)当事件级别 >= 6 时被启动

联动功能默认的白名单是:

8.8.8.8

您希望添加更多的IP到白名单吗? (y/n)? [n]:

3.5- 您希望接收远程机器syslog吗 (port 514 udp)? (y/n) [y]:

远程机器syslog将被接收.

3.6- 设置配置文件以分析一下日志:

– /var/log/messages

– /var/log/secure

– /var/log/maillog

-如果你希望监控其他文件, 只需要在配置文件ossec.conf中

添加新的一项.

任何关于配置的疑问您都可以在 http://www.ossec.net 找到答案.

— 按 ENTER 以继续 —

5- 正在安装系统

- 正在运行Makefile

INFO: Little endian set.

…………省略编译输出…………

系统类型是   Linux.

修改启动脚本使 OSSEC HIDS 在系统启动时自动运行

已正确完成系统配置.

要启动 OSSEC HIDS:

/opt/ossec/bin/ossec-control start

要停止 OSSEC HIDS:

/opt/ossec/bin/ossec-control stop

要查看或修改系统配置,请编辑  /opt/ossec/etc/ossec.conf

感谢使用 OSSEC HIDS.

如果您有任何疑问,建议或您找到任何bug,

请通过 contact@ossec.net 或邮件列表 ossec-list@ossec.net 联系我们.

( http://www.ossec.net/en/mailing_lists.html ).

您可以在 http://www.ossec.net 获得更多信息

— 请按 ENTER 结束安装 (下面可能有更多信息). —

直到碰到上面内容,说明安装完成。

######################################################################################################################

OSSEC服务端配置

上面只是安装好了OSSEC服务端,下面则是为了配置服务端,使其工作正常。执行下面命令启用数据库支持:

[root@ossec-server ossec-hids-2.7]# /opt/ossec/bin/ossec-control enable database

然后导入MySQL表结构到MySQL中:

[root@ossec-server ossec-hids-2.7]# mysql -uossec -p ossec < ./src/os_dbd/mysql.schema

修改部分配置文件的权限,否则会启动服务失败:

[root@ossec-server ossec-hids-2.7]# chmod u+w /opt/ossec/etc/ossec.conf

然后我们编辑ossec.conf文件,在ossec_config中添加MySQL配置:

<ossec_config>

.....

   <database_output>

       <hostname>192.168.100.103</hostname>

       <username>ossec</username>

       <password>ossec</password>

       <database>ossec</database>

       <type>mysql</type>

   </database_output>

</ossec_config>

由于我们在前面的安装过程中支持接受远程机器的syslog,所以我们还需要对ossec.conf文件中的syslog部分进行配置,修改ossec.conf文件,按照下面的内容进行修改,把我们网段可以全添加进去:

 <remote>

   <connection>syslog</connection>

   <allowed-ips>192.168.0.0/16</allowed-ips>

 </remote>

在实际的实验过程中启动ossec服务端必须先添加一个客户端,否则直接启动服务端是会失败的,通过如下命令查看日志会发现如下错误:

[root@ossec-server logs]# cat /opt/ossec/logs/ossec.log

2013/09/23 23:43:15 ossec-analysisd(1210): ERROR: Queue '/queue/alerts/ar' not accessible: 'Connection refused'.

2013/09/23 23:43:15 ossec-analysisd(1301): ERROR: Unable to connect to active response queue.

在服务器上添加客户端,执行如下命令,:

[root@ossec-server logs]# /opt/ossec/bin/manage_agents

  ****************************************

  * OSSEC HIDS v2.7 Agent manager.     *

  * The following options are available: *

  ****************************************

     (A)dd an agent (A).

     (E)xtract key for an agent (E).

     (L)ist already added agents (L).

     (R)emove an agent (R).

     (Q)uit.

Choose your action: A,E,L,R or Q: A

Adding a new agent (use ‘\q’ to return to the main menu).

Please provide the following:

A name for the new agent: ossec-agent

The IP Address of the new agent: 192.168.1.104

An ID for the new agent[001]:

Agent information:

ID:001

Name:ossec-agent

IP Address:192.168.1.104

Confirm adding it?(y/n): y

Agent added.

然后程序会重新进入到第一次的界面,如下,我们导出刚才添加的那个agent的key,用于后面的客户端连接到服务端:

  ****************************************

  * OSSEC HIDS v2.7 Agent manager.     *

  * The following options are available: *

  ****************************************

     (A)dd an agent (A).

     (E)xtract key for an agent (E).

     (L)ist already added agents (L).

     (R)emove an agent (R).

     (Q)uit.

Choose your action: A,E,L,R or Q: E

Available agents:

ID: 001, Name: ossec-agent, IP: 192.168.1.104

Provide the ID of the agent to extract the key (or ‘\q’ to quit): 001

Agent key information for ’001′ is:

MDAxIG9zc2VjLWFnZW50IDE5Mi4xNjguMTAwLjEwNCAzZWJmZWMzZmRlYzE2ODgzZmEyMzc0NWI5MWMyZDlmNmIyNDViZDMxNjBkZGRiM2FlMTk4NDA3ODNiNDFhYzYz

** Press ENTER to return to the main menu.

到现在就可以启动我们的ossec服务端了。

# /opt/ossec/bin/ossec-control start

或者执行

# /etc/init.d/ossec start

######################################################################################################################

安装OSSEC客户端

由于我们本身客户端也是Linux服务器,而ossec的服务端和客户端是同一个安装包,所以在客户端上下载安装包,并且解压安装,如下。

[root@ossec-server ~]# wget http://www.ossec.net/files/ossec-hids-2.7.tar.gz

[root@ossec-server ~]# tar zxf ossec-hids-2.7.tar.gz

[root@ossec-server ~]# cd ossec-hids-2.7

[root@ossec-server ~]# ./install.sh

** Para instalao em português, escolha [br].

** 要使用中文进行安装, 请选择 [cn].

** Fur eine deutsche Installation wohlen Sie [de].

** Για εγκατσταση στα Ελληνικ, επιλξτε [el].

** For installation in English, choose [en].

** Para instalar en Espaol , eliga [es].

** Pour une installation en franais, choisissez [fr] ** A Magyar nyelv telepítéshez válassza [hu].

** Per l’installazione in Italiano, scegli [it].

** 日本語でインストールします.選択して下さい.[jp].

** Voor installatie in het Nederlands, kies [nl].

** Aby instalowa w jzyku Polskim, wybierz .

** Для инструкций по установке на русском ,введите [ru].

** Za instalaciju na srpskom, izaberi [sr].

** Türke kurulum iin sein [tr].

(en/br/cn/de/el/es/fr/hu/it/jp/nl/pl/ru/sr/tr) [en]: cn

OSSEC HIDS v2.7 安装脚本 – http://www.ossec.net

您将开始 OSSEC HIDS 的安装.

请确认在您的机器上已经正确安装了 C 编译器.

系统类型: Linux

主机: ossec-agent

– 按 ENTER 继续或 Ctrl-C 退出. –

1- 您希望哪一种安装 (server, agent, local or help)? agent

选择了 Agent(client) 类型的安装.

2- 正在初始化安装环境.

请选择 OSSEC HIDS 的安装路径 [/var/ossec]: /opt/ossec

OSSEC HIDS 将安装在  /opt/ossec .

3- 正在配置 OSSEC HIDS.

3.1- 请输入 OSSEC HIDS 服务器的IP地址或主机名: 192.168.1.110

添加服务器IP  192.168.100.110

3.2- 您希望运行系统完整性检测模块吗? (y/n) [y]:

系统完整性检测模块将被部署.

3.3- 您希望运行 rootkit检测吗? (y/n) [y]:

rootkit检测将被部署.

3.4 – 您希望开启联动(active response)功能吗? (y/n) [y]:

3.5- 设置配置文件以分析一下日志:

– /var/log/messages

– /var/log/secure

– /var/log/xferlog

– /var/log/maillog

– /var/log/httpd/error_log (apache log)

– /var/log/httpd/access_log (apache log)

-如果你希望监控其他文件, 只需要在配置文件ossec.conf中

添加新的一项.

任何关于配置的疑问您都可以在 http://www.ossec.net 找到答案.

— 按 ENTER 以继续 —

5- 正在安装系统

- 正在运行Makefile

INFO: Little endian set.

…………省略编译输出…………

系统类型是  Redhat Linux.

修改启动脚本使 OSSEC HIDS 在系统启动时自动运行

已正确完成系统配置.

要启动 OSSEC HIDS:

/opt/ossec/bin/ossec-control start

要停止 OSSEC HIDS:

/opt/ossec/bin/ossec-control stop

要查看或修改系统配置,请编辑  /opt/ossec/etc/ossec.conf

感谢使用 OSSEC HIDS.

如果您有任何疑问,建议或您找到任何bug,

请通过 contact@ossec.net 或邮件列表 ossec-list@ossec.net 联系我们.

( http://www.ossec.net/en/mailing_lists.html ).

您可以在 http://www.ossec.net 获得更多信息

— 请按 ENTER 结束安装 (下面可能有更多信息). —

您必须首先将该代理添加到服务器端以使他们能够相互通信.

这样做了以后,您可以运行’manage_agents’工具导入

服务器端产生的认证密匙.

/opt/ossec/bin/manage_agents

详细信息请参考:

http://www.ossec.net/en/manual.html#ma

######################################################################################################################

配置OSSEC客户端

其实配置ossec客户端就是把刚才由服务端生成的key,在客户端中导入,执行如下命令

[root@ossec-agent ossec-hids-2.7]# /opt/ossec/bin/manage_agents

****************************************

* OSSEC HIDS v2.7 Agent manager.     *

* The following options are available: *

****************************************

  (I)mport key from the server (I).

  (Q)uit.

Choose your action: I or Q: I

Provide the Key generated by the server.

The best approach is to cut and paste it.

*** OBS: Do not include spaces or new lines.

Paste it here (or ‘\q’ to quit):MDAxIG9zc2VjLWFnZW50IDE5Mi4xNjguMTAwLjEwNCAzZWJmZWMzZmRlYzE2ODgzZmEyMzc0NWI5MWMyZDlmNmIyNDViZDMxNjBkZGRiM2FlMTk4NDA3ODNiNDFhYzYz

Agent information:

ID:001

Name:ossec-agent

IP Address:192.168.1.104

Confirm adding it?(y/n): y

Added.

** Press ENTER to return to the main menu.

最后启动客户端

[root@ossec-agent ossec-hids-2.7]# /etc/init.d/ossec start

######################################################################################################################

安装web界面 analogi

更新。。。。。

#########################################################################################

至此安装完成。网上有很多安装方法,我收集整理了一下。