The modern customer support platform, an open-source alternative to Intercom, Zendesk, Salesforce Service Cloud etc.
Chatwoot is the modern, open-source, and self-hosted customer support platform designed to help businesses deliver exceptional customer support experience. Built for scale and flexibility, Chatwoot gives you full control over your customer data while providing powerful tools to manage conversations across channels.
Supercharge your support with Captain, Chatwoot’s AI agent. Captain helps automate responses, handle common queries, and reduce agent workload—ensuring customers get instant, accurate answers. With Captain, your team can focus on complex conversations while routine questions are resolved automatically. Read more about Captain here.
Chatwoot centralizes all customer conversations into one powerful inbox, no matter where your customers reach out from. It supports live chat on your website, email, Facebook, Instagram, Twitter, WhatsApp, Telegram, Line, SMS etc.
Publish help articles, FAQs, and guides through the built-in Help Center Portal. Enable customers to find answers on their own, reduce repetitive queries, and keep your support team focused on more complex issues.
- Private Notes and @mentions for internal team discussions.
- Labels to organize and categorize conversations.
- Keyboard Shortcuts and a Command Bar for quick navigation.
- Canned Responses to reply faster to frequently asked questions.
- Auto-Assignment to route conversations based on agent availability.
- Multi-lingual Support to serve customers in multiple languages.
- Custom Views and Filters for better inbox organization.
- Business Hours and Auto-Responders to manage response expectations.
- Teams and Automation tools for scaling support workflows.
- Agent Capacity Management to balance workload across the team.
- Contact Management with profiles and interaction history.
- Contact Segments and Notes for targeted communication.
- Campaigns to proactively engage customers.
- Custom Attributes for storing additional customer data.
- Pre-Chat Forms to collect user information before starting conversations.
- Slack Integration to manage conversations directly from Slack.
- Dialogflow Integration for chatbot automation.
- Dashboard Apps to embed internal tools within Chatwoot.
- Shopify Integration to view and manage customer orders right within Chatwoot.
- Use Google Translate to translate messages from your customers in realtime.
- Create and manage Linear tickets within Chatwoot.
- Live View of ongoing conversations for real-time monitoring.
- Conversation, Agent, Inbox, Label, and Team Reports for operational visibility.
- CSAT Reports to measure customer satisfaction.
- Downloadable Reports for offline analysis and reporting.
Detailed documentation is available at chatwoot.com/help-center.
The translation process for Chatwoot web and mobile app is managed at https://translate.chatwoot.com using Crowdin. Please read the translation guide for contributing to Chatwoot.
We use the git-flow branching model. The base branch is develop.
If you are looking for a stable version, please use the master or tags labelled as v1.x.x.
Для запуска Chatwoot локально с базами данных в Docker выполните следующие шаги:
-
Убедитесь что у вас установлены:
- Docker и Docker Compose
- Ruby 3.3+
- Node.js 18+
- pnpm
-
Склонируйте репозиторий:
git clone https://github.com/chatwoot/chatwoot.git cd chatwoot
-
Запустите только базы данных и MailHog:
docker-compose -f docker-compose.dev.yaml up -d
-
Проверьте что сервисы запущены:
docker-compose -f docker-compose.dev.yaml ps
-
Создайте файл
.env:# Chatwoot Configuration NODE_ENV=development RAILS_ENV=development # Database Configuration POSTGRES_HOST=localhost POSTGRES_PORT=5433 POSTGRES_DB=chatwoot POSTGRES_USER=postgres POSTGRES_PASSWORD=chatwoot_password # Redis Configuration REDIS_URL=redis://localhost:6380 REDIS_PASSWORD= # Frontend Configuration FRONTEND_URL=http://localhost:3000 # Email Configuration (using MailHog for development) SMTP_DOMAIN=localhost SMTP_PORT=1025 SMTP_ADDRESS=localhost SMTP_USERNAME= SMTP_PASSWORD= SMTP_AUTHENTICATION= FORCE_SSL=false # Application Configuration SECRET_KEY_BASE=your_secret_key_base_here_minimum_30_characters INSTALLATION_ENV=docker # Disable Enterprise features for OSS version CW_ENTERPRISE_EDITION=false DISABLE_ENTERPRISE=true # Active Storage Configuration ACTIVE_STORAGE_SERVICE=local # Default settings DEFAULT_LOCALE=en
-
Установите зависимости:
# Ruby зависимости bundle install # Node.js зависимости pnpm install
-
Настройте базу данных:
# Создание и миграции базы данных bundle exec rails db:create bundle exec rails db:migrate bundle exec rails db:seed
-
В первом терминале запустите Rails сервер:
bundle exec rails server -
Во втором терминале запустите Sidekiq:
bundle exec sidekiq -C config/sidekiq.yml -
В третьем терминале запустите Vite dev server:
bin/vite dev
- Chatwoot: http://localhost:3000
- MailHog (для тестирования email): http://localhost:8025
- PostgreSQL: localhost:5433
- Redis: localhost:6380
Данные PostgreSQL и Redis сохраняются в Docker volumes:
chatwoot_postgres_data- данные PostgreSQLchatwoot_redis_data- данные Redis
При перезапуске Docker контейнеров данные сохранятся.
# Остановка Docker сервисов
docker-compose -f docker-compose.dev.yaml down
# Остановка с удалением volumes (ВНИМАНИЕ: удалит все данные!)
docker-compose -f docker-compose.dev.yaml down -vПолный запуск всех сервисов в Docker (исправлены все проблемы с подключениями):
# 1. Запустите базовые сервисы
docker-compose up -d postgres redis mailhog
# 2. Запустите все сервисы
docker-compose up -d rails sidekiq vite
# Проверьте статус всех сервисов
docker-compose psТестовые учетные данные для входа в админку: (name: 'John', email: 'john@acme.inc', password: 'Password1!', type: 'SuperAdmin')
Что было исправлено для полного Docker запуска:
- ✅ Настроены правильные environment переменные для связи между контейнерами
- ✅ Исправлена проблема с
POSTGRES_USERvsPOSTGRES_USERNAMEв entrypoint скриптах - ✅ Sidekiq корректно подключается к Redis через
redis://redis:6379 - ✅ Rails сервер успешно стартует и подключается к PostgreSQL
- ✅ Persistent storage настроен для сохранения данных
- Если порты 5432 или 6379 заняты, проект использует 5433 и 6380 соответственно
- Для просмотра логов:
docker-compose -f docker-compose.dev.yaml logs <service-name> - Для входа в контейнер:
docker-compose -f docker-compose.dev.yaml exec <service-name> bash - При проблемах с сетью при сборке Docker образов используйте гибридный подход (базы в Docker, приложение локально)
Deploying Chatwoot to Heroku is a breeze. It's as simple as clicking this button:
Follow this link to understand setting the correct environment variables for the app to work with all the features. There might be breakages if you do not set the relevant environment variables.
Chatwoot now supports 1-Click deployment to DigitalOcean as a kubernetes app.
For other supported options, checkout our deployment page.
Looking to report a vulnerability? Please refer our SECURITY.md file.
If you need help or just want to hang out, come, say hi on our Discord server.
Thanks goes to all these wonderful people:
Chatwoot © 2017-2025, Chatwoot Inc - Released under the MIT License.



