wiki:Servicos/Cyrus

Version 13 (modified by lucas.carraro, 13 years ago) (diff)

--

Cyrus IMAP

O servidor Cyrus IMAP é o responsável em fornecer as mailboxes dos usuários. Ele é um servidor IMAP de alta performance que permite que vários usuários trabalhem simultanemanete na mesma mailbox, além de possuir funções de pesquisa, indice e compartilhamento muito avançadas. Para maiores informações sobre o protocolo IMAP e suas funções consulte o seguinte  endereço. O servidor Cyrus IMAP é compatível com praticamente todos os clientes IMAP disponíveis no mercado(Apple Mail,Android,Thunderbird,Outlook,Evolution,KMail). Atualmente a versão considerada estável pelo projeto é a 2.4.6. As distribuições de Linux costumam vir por padrão com o Cyrus 2.2 ou 2.3

Funcionalidades

  • Armazenamento: Utiliza um formato próprio para armazenar as mensagens parecido com o formato Maildir.
  • Indices: Suporta indices nos formato BerkleyDB ou no formato skiplist( padrão a partir das versões 2.4)
  • Autenticação: Utiliza da estrutura SASL.
  • Controle: Possui implementado as RFCs (5593,4551,5464,5551) que normatizam administração de servidores IMAP. Possui nativamente suporte há:
    • Hierarquia;
    • Autorização;
    • Quota.
    • Compartilhamentos
  • Suporta administração por mail de interface própria ( cyradm ) e várias linguagens como perl, python e java.
  • Conectividade: Possui suporte e módulos para diversas aplicações como:
    • Exim (MTA)
    • Postfix
    • SpamAssassin
    • Clamav
    • Amavis
  • Filtros: Suporte built-in para filtros no lado do servidor(SIEVE).

Como configurar o Cyrus para o Expresso

Esta configuração é específica para o módulo com apenas um servidor IMAP. O servidor também pode ser configurado de forma distribuída ( Cyrus Aggregation (Murder) ).

Edite o arquivo /etc/imapd.conf e certifique-se que este arquivo contém as seguintes linhas:

 unixhierarchysep: yes
 admins: expresso-admin
 sasl_mech_list: PLAIN
 sasl_pwcheck_method: saslauthd
 allowusermoves: yes
 duplicatesupression: 0
 lmtp_over_quota_perm_failure: 1
 partition-default: /var/spool/imap
 configdirectory: /var/lib/imap
 defaultpartition: default
 

Edite o arquivo /etc/cyrus.conf e certifique-se que este arquivo contém as seguintes linhas:

START {
	# do not delete this entry!
	recover		cmd="/usr/cyrus/bin/ctl_cyrusdb -r"
}

SERVICES {
        imap            cmd="imapd -U 30" listen="imap" prefork=1
	imaps		cmd="imapd -s -U 30" listen="imaps" prefork=1
	lmtpd		cmd="lmtpd" listen="lmtp" prefork=1
  	sieve		cmd="timsieved" listen="sieve" prefork=1
}

EVENTS {
  # this is required
  checkpoint	cmd="/usr/cyrus/bin/ctl_cyrusdb -c" period=5

  # SQUATTER indexa as caixas postais para pesquisa.
  squatter        cmd="/usr/cyrus/bin/squatter -s -r user" at=2300
}

A lista de todos os parâmetros de configuração disponíveis pode ser acessada pelo shell através dos comandos

 man imapd.conf
 man cyrus.conf

Administrando as Contas no Servidor IMAP

A administração de cotas e compartilhamentos de caixa é feita pelo módulo Expresso Admin do Expresso. Quando você cria ou deleta uma conta de correio no Expresso Admin a operação é executada no Servidor IMAP.

As contas de e-mail podem ser administradas pela linha de comando através do comando "cyradm" ou via scripts em perl, python e etc ....

A ferramenta cyradm é um shell interativo para administração do cyrus.

Abaixo segue um exemplo de conexão e criação de caixas:

cyradm --server servidor.imap.expresso  --user expresso-admin

cm user/login   ( criar caixa de usuário )
cm user/login/Sent
cm user/login/Drafts
cm user/login/Trash

lm (lista as caixas)

lq user/login ( listar quota do usuário: login )

sq user/login 1024000 ( Setar a cota de 1Gb para a caixa )

lam user/login ( Listar as ACLs de uma caixa )
lam user/login/*

( Para deletar uma caixa voce deve dar permissão ao expresso-admin para ela )
sam user/login expresso-admin all
dm user/login

Maiores dúvidas sobre a administração podem ser consultadas no manual do cyradm. ou pelo manual.

 man cyradm

Criando scripts para administração em lote

O cyrus possui uma API em perl que permite a criação de scripts

para tarefas rotineiras como criação de contas em massa, configuração de cotas, definir compartilhamentos e etc .

Neste manual este assunto não vai ser abordado com detalhes.

Uma biblioteca que facilita bastante o trabalho é a " python-cyrus" criada pelo Reinaldo Carvalho um dos colaboradores da comunidade Expresso.

Configurando o Expresso para utilizar um servidor Cyrus em uma máquina remota

A aplicação Expresso já prevê a distribuição dos seus serviços em outros servidores. Para o Cyrus, proceda da seguinte forma:

- Se logue no expresso como expresso-admin;

- Vá no módulo Administrador e procure pelo módulo Admin do Email (EmailAdmin);

- Clique em "Configurações do Servidor";

- Edite o perfil e configure os novos parâmetros na aba POP3/IMAP;

Como testar/administrar

O banco de dados do Cyrus é mapeado em /var/spool/cyrus. Desta forma o administrador consegue ver, remover, adicionar, alterar os emails das caixas postais. Por exemplo na pasta "/var/spool/cyrus/mail/e/user/expresso-admin" encontra-se as caixas do usuário expresso-admin. Por exemplo listando o conteúdo desta pasta:

10740.  10751.  cyrus.cache   cyrus.index  Enviados
10749.  95431.  cyrus.header  Drafts       Lixeira

Os arquivos regulares 10740., 10749., 10751. e 95431. são mensagens em formato texto. Os diretórios Lixeira, Enviados, Drafts são pastas das caixas postais.

Os arquivos cyrus.index, cyrus.cache e cyrus.header são arquivos de controle do cyrus para otimizar buscas em conteúdos e cabeçalhos dos emails. Quando as caixas apresentarem problema, como por exemplo lentidão, estes podem ser refeitos. A forma de refaze-los é usando a ferramenta /usr/sbin/cyrreconstruct.

Para administrar caixas (como por exemplo remoção e criação) o administrador deve usar a ferramenta cyradm.

Mais informações

 Documentação do cyrus