Проблемы приложения WCF и Entity Framework уровня приложений
Я занимаюсь разработкой службы WCF, которая является частью более крупной системы. Сервис предоставит некоторую бизнес-логику и будет подключен к базе данных через Entity Framework (используя модель-сначала). Я вижу, что есть много разных способов работы с Entity Framework с WCF-сервисом (базовые объекты, DTO, объекты самоконтроля, POCO и т. Д.). Мои основные требования:
- Сервис создан для тонких клиентов (и других Сервисов), большая часть логики находится на его стороне, так что это не какое-либо приложение CRUD (Сервисы данных WCF не для меня)
- Разным клиентам нужны данные с разной степенью детализации, поэтому для одной и той же сущности в базе данных будут разные контракты данных
Из-за моих требований мое видение того, как это должно быть построено, наиболее близко (я думаю, что это наиболее близко к подходу DTO): http://www.codeproject.com/Articles/127395/Implementing-a-WCF-Service-with-Entity-Framework
Но я думаю, что уровень доступа к данным должен быть отделен от логики Сервиса (2 сборки: проекты, пространства имен, библиотеки DLL, но работающие как одно приложение). В этом случае у меня есть некоторые проблемы, что должен делать каждый из этих двух уровней: должна ли вся логика выполняться в сервисе, и DAL будет использоваться просто как CRUD? Или же Service должен отвечать только за четкую бизнес-логику, в то время как вся логика базы данных (конкретные запросы, использующие linq) будет выполняться в DAL (много более специфических методов, предоставляемых DAL)? Кроме того, что важно, какие объекты следует отправлять между этими двумя уровнями: контракты данных, сущности или дополнительная модель?
Мой подход в указанной ситуации?
1 ответ
До SOA N- или 3-уровневые архитектуры обычно имели выделенный бизнес-уровень. Если вы чувствуете себя достаточно твердо в отношении разделения интересов (или если вы думаете, что вы можете получить некоторое повторное использование своих бизнес-функций от не-сервисных потребителей), почему бы не вывести свою бизнес-логику из уровня обслуживания? (но не помещайте бизнес-логику в свой DAL)
Однако, если ваш сервисный уровень действительно предлагает сервисы запроса данных, а также транзакционные сервисы, то бизнес-уровень для этих сервисов не нужен - взгляните на шаблоны проектирования типа CQRS здесь.
Если вам нужен контроль над форматом XML ваших сущностей (Names, xmlns и т. Д.), Вы, вероятно, захотите создать собственные сущности WCF DataContract или MessageContract. Однако, если вам все равно, как выглядят данные по сети, вы можете просто использовать классы EF Entity (если они не привязаны к контексту - т.е., если использовать POCO с EF). Если вы не связываете POCO с DataContract и т. Д., Поведение DataContractSerializer по умолчанию заключается в сериализации открытых свойств.
Таким образом, вы можете получить следующие "слои" сборки (снизу вверх)
- Объекты DAL для EF (привязанные к ObjectContext или POCO)
- EF DAL
- Бизнес-уровень (только для транзакционных методов обслуживания - обойден для запросов)
- Возможно, отдельные объекты WCF, где вы сопоставляете свои POCO / DAL BE с DataContract / MessageContract
- Уровень сервиса WCF