|
|
www.lissyara.su
—> статьи
—> FreeBSD
—> почтовые системы
—> RoundCube
Roundcube в связке с PostgreSQL
Автор: AlkoGekS.
Решил внести свой скромный вклад, накатать статейку про roundcube. Вроде бы с установкой проблем быть не должно, по крайней мере я так думал, но все же с некоторыми я столкнулся, например локализация. Но не все сразу, начнем по порядку.
По просьбам трудящихся: Roundcube - это веб интерфес для почты, полнофункциональный, немного напонимает Squirrel mail, но по моему мнению лучше :)
Ставить будем связку roundcube и postgresql, последний выбрал не случайно, хотелось посмотреть что это за зверь.
Итак, первым делом обновляем порты. Я использую portsnap:
Server# portsnap fetch update
| Все, теперь переходим к установке postgresql. Я выбрал версию 8.2, 8.3 насколько я знаю еще не совсем стабильна.
Server# cd /usr/ports/databases/postgresql82-server/
Server# make install clean
| Вылезает окошко, где я выбрал
Options for postgresql-server 8.2.5_2
[X] NLS Use internationalized messages
[ ] PAM Build with PAM support (server only)
[ ] LDAP Build with LDAP authentication support
[ ] MIT_KRB5 Build with MIT's kerberos support
[ ] HEIMDAL_KRB5 Builds with Heimdal kerberos support
[ ] OPTIMIZED_CFLAGS Builds with compiler optimizations (-O3)
[X] LIBC_R Link w/ libc_r, used by plpython (server)
[ ] THREADSAFE make libpq thread safe
[X] TESTS Allows the use of a check target (server)
[X] DEBUG Builds with debugging symbols
[ ] HIER Builds with query hierarchy (server)
[ ] INTDATE Builds with 64-bit date/time type (server)
| Вроде бы все, нажимаем на OK и устанавливаем.
После установки нужно запустить сервер и настроить, так как postgres на тот момент я не знал вообще, то пришлось ставить оболочку, аналог phpMyAdmin, только называется она phpPgAdmin
Server# cd /usr/ports/databases/phppgadmin/
Server# make install clean
| После установки, добавляем следующие строчки в конек конфига апача /usr/local/etc/apache2/httpd.conf
Alias /postgres/ "/usr/local/www/phpPgAdmin/"
<Directory "/usr/local/www/phpPgAdmin/">
Options none
AllowOverride Limit
Order Deny,Allow
## Тут можно разрешить коонект с опреденных ip адресах, в примеру
# Allow from 192.168.0.111
Allow from all
</Directory>
| Итак, phpPgAdmin установлен и готов к работе. Вернемся к нашему postgres.
В /etc/rc.conf вносим следующие строчки:
postgresql_enable="YES"
postgresql_data="/var/db/pgsql/data"
postgresql_flags="-w -s -m fast"
postgresql_initdb_flags="--encoding=utf8 --lc-collate=C"
postgresql_class="default"
| В /etc/login.conf тоже теребуется внести некоторые изменения
postgres:\
:lang=ru_RU.UTF-8:\
:setenv=LC_COLLATE=C:\
:tc=default:
| Вообще, по дефолту все базы и конфиги будут хранится в /usr/local/pgsql, но меня это не устроило. Поэтому следующие действия я предпринял чтоб изменить этот путь:
Server# mkdir /var/db/pgsql
Server# chown pgsql:pgsql /var/db/pgsql
Server# chmod 0700 /var/db/pgsql
Server# pw usermod pgsql -d /var/db/pgsql
| Затем мы инициализируем базы данных и конфиги:
Server# /usr/local/etc/rc.d/postgresql initdb
| Идем править конфиг самого postgres. Я изменил всего лишь одну строчку, чтобы можно было конектиться с phpPgAdmin. Итак в /var/db/pgsql/data/postgresql.conf правим строчи, на такие:
listen_addresses = '*' #“*” - коннект со всех хостов,
#“localhost” – с самого сервера.
......................................................
#autovacuum = on # Необходимо закоментировать, у меня с этой строчкой
# roundcube вываливался с ошибкой.
| Можно еще изменить методы аутентификации в файле /var/db/pgsql/pg_ident.conf, но я оставил все как есть.
Итак, конфиг поправили, можно и поадминить, заходим по адресу http://you_site/postgres/ , указываем в качестве логина и пароля pgsql.
Переходим к следующему этапу, ставим сам roundcube.
Server# cd /usr/ports/mail/roundcube/
Server# make install clean
| После установки я изменил виртуал-хосты апача таким образом (веб-интерфейс почты будет досупен по адресу mail.myserv.net)
Server# cat /usr/local/etc/apache2/Includes/vhosts.conf
...................................
<VirtualHost *:80>
ServerAdmin admin@myserv.net
DocumentRoot /usr/local/www/roundcube/
ServerName mail.myserv.net
</VirtualHost>
...................................
Server#
| В postgres создаем простого пользователя roundcube (ВАЖНО!!! Кодировку выбираем UTF-8) с паролем pass и базу roundcube.
Затем выполняем SQL запрос из примера (Все примеры для различных баз данных находятся в файликах по адресу /usr/local/www/roundcube/SQL)
Нас интересует файл /usr/local/www/roundcube/SQL/postgres.initial.sql
--
-- Sequence "user_ids"
-- Name: user_ids; Type: SEQUENCE; Schema: public; Owner: postgres
--
CREATE SEQUENCE user_ids
INCREMENT BY 1
NO MAXVALUE
NO MINVALUE
CACHE 1;
--
-- Table "users"
-- Name: users; Type: TABLE; Schema: public; Owner: postgres
--
CREATE TABLE users (
user_id integer DEFAULT nextval('user_ids'::text) PRIMARY KEY,
username character varying(128) DEFAULT ''::character varying NOT NULL,
mail_host character varying(128) DEFAULT ''::character varying NOT NULL,
alias character varying(128) DEFAULT ''::character varying NOT NULL,
created timestamp with time zone DEFAULT now() NOT NULL,
last_login timestamp with time zone DEFAULT now() NOT NULL,
"language" character varying(5) DEFAULT 'en'::character varying NOT NULL,
preferences text DEFAULT ''::text NOT NULL
);
--
-- Table "session"
-- Name: session; Type: TABLE; Schema: public; Owner: postgres
--
CREATE TABLE "session" (
sess_id character varying(40) DEFAULT ''::character varying PRIMARY KEY,
created timestamp with time zone DEFAULT now() NOT NULL,
changed timestamp with time zone DEFAULT now() NOT NULL,
ip character varying(16) NOT NULL,
vars text NOT NULL
);
--
-- Sequence "identity_ids"
-- Name: identity_ids; Type: SEQUENCE; Schema: public; Owner: postgres
--
CREATE SEQUENCE identity_ids
START WITH 1
INCREMENT BY 1
NO MAXVALUE
NO MINVALUE
CACHE 1;
--
-- Table "identities"
-- Name: identities; Type: TABLE; Schema: public; Owner: postgres
--
CREATE TABLE identities (
identity_id integer DEFAULT nextval('identity_ids'::text) PRIMARY KEY,
user_id integer NOT NULL REFERENCES users (user_id),
del integer DEFAULT 0 NOT NULL,
standard integer DEFAULT 0 NOT NULL,
name character varying(128) NOT NULL,
organization character varying(128),
email character varying(128) NOT NULL,
"reply-to" character varying(128),
bcc character varying(128),
signature text,
html_signature integer DEFAULT 0 NOT NULL
);
--
-- Sequence "contact_ids"
-- Name: contact_ids; Type: SEQUENCE; Schema: public; Owner: postgres
--
CREATE SEQUENCE contact_ids
START WITH 1
INCREMENT BY 1
NO MAXVALUE
NO MINVALUE
CACHE 1;
--
-- Table "contacts"
-- Name: contacts; Type: TABLE; Schema: public; Owner: postgres
--
CREATE TABLE contacts (
contact_id integer DEFAULT nextval('contact_ids'::text) PRIMARY KEY,
user_id integer NOT NULL REFERENCES users (user_id),
changed timestamp with time zone DEFAULT now() NOT NULL,
del integer DEFAULT 0 NOT NULL,
name character varying(128) DEFAULT ''::character varying NOT NULL,
email character varying(128) DEFAULT ''::character varying NOT NULL,
firstname character varying(128) DEFAULT ''::character varying NOT NULL,
surname character varying(128) DEFAULT ''::character varying NOT NULL,
vcard text
);
--
-- Sequence "cache_ids"
-- Name: cache_ids; Type: SEQUENCE; Schema: public; Owner: postgres
--
CREATE SEQUENCE cache_ids
INCREMENT BY 1
NO MAXVALUE
NO MINVALUE
CACHE 1;
--
-- Table "cache"
-- Name: cache; Type: TABLE; Schema: public; Owner: postgres
--
CREATE TABLE "cache" (
cache_id integer DEFAULT nextval('cache_ids'::text) PRIMARY KEY,
user_id integer NOT NULL REFERENCES users (user_id),
session_id character varying(40) REFERENCES "session" (sess_id),
cache_key character varying(128) DEFAULT ''::character varying NOT NULL,
created timestamp with time zone DEFAULT now() NOT NULL,
data text NOT NULL
);
--
-- Sequence "message_ids"
-- Name: message_ids; Type: SEQUENCE; Schema: public; Owner: postgres
--
CREATE SEQUENCE message_ids
INCREMENT BY 1
NO MAXVALUE
NO MINVALUE
CACHE 1;
--
-- Table "messages"
-- Name: messages; Type: TABLE; Schema: public; Owner: postgres
--
CREATE TABLE "messages" (
message_id integer DEFAULT nextval('message_ids'::text) PRIMARY KEY,
user_id integer NOT NULL REFERENCES users (user_id),
del integer DEFAULT 0 NOT NULL,
cache_key character varying(128) DEFAULT ''::character varying NOT NULL,
created timestamp with time zone DEFAULT now() NOT NULL,
idx integer DEFAULT 0 NOT NULL,
uid integer DEFAULT 0 NOT NULL,
subject character varying(128) DEFAULT ''::character varying NOT NULL,
"from" character varying(128) DEFAULT ''::character varying NOT NULL,
"to" character varying(128) DEFAULT ''::character varying NOT NULL,
cc character varying(128) DEFAULT ''::character varying NOT NULL,
date timestamp with time zone NOT NULL,
size integer DEFAULT 0 NOT NULL,
headers text NOT NULL,
structure text
);
ALTER TABLE "messages" ADD UNIQUE (user_id, cache_key, uid);
| После чего идем редактировать конфиги.
В /usr/local/www/rouncube/configs/db.inc.php добавляем информацию о postgres по примеру:
$rcmail_config['db_dsnw'] = 'pgsql://roundcube:pass@localhost/roundcube';
| Остальное я не трогал.
В /usr/local/www/rouncube/configs/main.inc.php меняем следующие строчки:
$rcmail_config['default_host'] = 'хост';
$rcmail_config['mail_domain'] = 'почтовый_домен';
$rcmail_config['smtp_user'] = '%u';
$rcmail_config['smtp_pass'] = '%p';
$rcmail_config['smtp_auth_type'] = 'PLAIN';
$rcmail_config['locale_string'] = 'ru'; #русская локализация
| На данном шаге, у меня был полностью русифицированный Roundcube, без всяких проблем с кодировками!
Почта приходит и отправляется великолепно, русские шрифты отображаются хорошо - русские папки создаются, контакты тоже. Пользуйтесь :)
Вот так оно выглядит
Ссылка на обсуждение: http://forum.lissyara.su/viewtopic.php?t=5831.
размещено: 2007-11-02,
последнее обновление: 2007-11-02,
автор: AlkoGekS
|
|
|
|
2014-07-27, lissyara
gmirror
Удалённое создание софтверного зеркала средствами gmirror, на диске разбитом с использованием gpart. Использование меток дисков для монтирования разделов.
2013-08-20, zentarim
Scan+Print server FreeBSD 9
Настройка сервера печати и сервера сканирования под управлением операционной системы FreebSD 9 для МФУ Canon PIXMA MP540
2011-11-20, BlackCat
Разъём на WiFi-карту
Делаем съёмной несъёмную антену на WiFi-карте путём установки ВЧ-разъёма
2011-09-14, manefesto
Настройка git+gitosis
Настройка системы контроля версия исходного кода в связке git+gitosis+ssh
2011-08-14, zentarim
Wi-FI роутер + DHCP + DNS
Настройка Wi-Fi роутера на Freebsd 8 + DNS сервер + DHCP сервер: чтобы Wi-Fi клиенты были в одной подсети с проводными, проводные и беспроводные клиенты получали адреса автоматически по DHCP, кэширующ
2011-06-15, -ZG-
Охранная система на FreeBSD+LPT
В этой статье описана попытка реализации простой охранной системы на базе FreeBSD с подключением к ней охранных устройтсв на LPT порт и видеорегистрацией.
2011-03-13, terminus
ng_nat
Описание работы ng_nat, практическое использование, достоинства и недостатки в сравнении с ipfw nat
2011-02-20, Капитан
Nagios+Digitemp
Статья описывает создание системы оповещения о превышении температуры в специальных помещениях на основе Nagios с использованием программы Digitemp.
2011-02-17, Le1
Zyxel Configuration
Скрипт для массового изменения конфига свичей Zyxel. Берет из файла iplist список ip-шек, заходит последовательно на каждый и выполняет комманды из файла commands, записывая происходящее в лог файл.
2011-02-16, fox
hast carp zfs ucarp cluster
HAST (Highly Available Storage), CARP, UCARP, ZFS, Cluster настройка и одаптация плюс личные размышления…
2011-02-04, BlackCat
Восстановление ZFS
История о том, как был восстановлен развалившийся RAIDZ ZFS-пул (перешедший в FAULTED) с помощью скотча и подручных средств. Или о том, какие приключения ожидают тех, кто не делает резервных копий.
2011-02-03, Капитан
1-Wire
Статья описывает самостоятельное изготовление контроллера DS9097 для съёма показаний с датчиков температуры DS1820 с помощью программы Digitemp.
2011-01-28, Капитан
Температура в серверной
Статья описывает построение системы наблюдения за температурой в помещении серверной с использованием программы Digitemp и выводом графиков в MRTG
2011-01-21, m4rkell
Syslog server
Как то буквально на днях, у нас завалилось, что то в еве) или не в еве не суть. Суть в том, что когда захотели снять логи с хостов esx обнаружили, что хранят эти негодяи логии только за последнии сутк
2011-01-07, lissyara
Canon/gphotofs
Монтирование цифровых фотоаппаратов Canon (PTP) как файловой системы, автоматизация этого процесса через события devd и внешние скрипты.
2010-12-13, Al
IPSec
Описание принципов работы IPSEC и способов аутентификации.
2010-12-07, manefesto
FreeBSD on flash
Было принято решении переехать на USB Flash и установить минимальный джентельменский набор для работы своего роутера. Делаем =)
2010-12-05, Fomalhaut
root ZFS, GPT
Инструкция по установке FreeBSD с использованием в качестве таблицы разделов GPT и в качестве основной файловой системы - ZFS
2010-09-05, Cancer
Настройка аудиоплеера на ximp3
Цели: Простенький аудиоплеер, для того что бы тетя продавец в магазине утром пришла нажала на кнопку Power и заиграла в зале музыка, так же был доступ по сети, общая шара куда можно заливать музыку, к
2010-08-31, Cancer
Установка и настройка OpenVPN
На днях появилась задача - объединить головной офис и 3 филиала в одну сеть через интернет посредством OpenVPN, чтобы люди могли подключаться через RDP к базам 1С на серверах.
2010-08-25, manefesto
freebsd lvm
Использование linux_lvm для работы с LVM разделами из-под FreeBSD. Проблемы которые возники при монтирование lvm раздела
2010-04-30, gonzo111
proftpd file auth"a
Proftpd - квоты и авторизация из файлов, без использования базы данных и/или системных пользователей
2010-04-22, lissyara
tw_cli
Пошаговая инструкция по восстановлению RAID на контроллере 3ware, из которого выпал один диск. Настройка мониторинга состояния рейда и отчётов о его состоянии на email.
2010-04-14, fox
MySQL Master+Master
MySQL (Master Master) and (Master Slave) Как настроить репликацию…
2010-03-09, terminus
DNS zones
Краткий ликбез про управление DNS зонами. Примеры проведения делегирования прямых и обратных DNS зон.
2010-03-09, aspera
Squid+AD (group access)
Настройка прокси сервера SQUID с автроризацией пользователей в AD. Разделение пользователей на группы
2010-03-02, BlackCat
Шлюз: Часть 4
Настройка дополнительных сервисов: синхронизация времени (OpenNTPD), клиент DynDNS.org.
2010-03-01, BlackCat
Шлюз: Часть 3
Настройка DHCP и DNS серверов для работы внутри частной сети, c поддержкой внутренних (частных зон) DNS, а так же интеграция DHCP и DNS сервисов.
2010-03-01, BlackCat
Шлюз: Часть 2
Конфигурация МСЭ pf для проброса портов с изменением порта назначения и без, а так же поддержки активного режима FTP и ограничения максимального размера сегмента
2010-03-01, BlackCat
Шлюз: Часть 1
Быстрая настройка шлюза/маршрутизатора с установлением PPPoE-соединения, поддержкой NAT и DNS-forwarding.
2010-02-23, Morty
darkstat
Простая считалка траффика, со встроенным веб-сервером. Очень маленькая, может делать отчеты трафика по хостам, портам, протоколам, а также строить графики
2010-01-23, gonzo111
squid+sams+sqstat
Пилим squid и sams - примеры конфигов с объяснениями. Установка SqStat.
2009-12-19, schizoid
mpd5 + radius + ng_car + Abills
Настройка pppoe-сервера с биллинговой системой Abills и шейпером ng_car
|
Комментарии пользователей [33 шт.]