Rafy 领域实体框架演示(3) - 快速使用 C/S 架构部署

简介:

本系列演示如何使用 Rafy 领域实体框架快速转换一个传统的三层应用程序,并展示转换完成后,Rafy 带来的新功能。

福利到!Rafy(原OEA)领域实体框架 2.22.2067 发布!

Rafy 领域实体框架示例(1) - 转换传统三层应用程序

Rafy 领域实体框架演示(2) - 新功能展示

以 Rafy 开发的应用程序,其实体、仓库、服务代码不需要做任何修改,即可同时支持单机部署、C/S 分布式部署。本文将说明如果快速使用 C/S 分布式部署。

 

前言


截止到上一篇,我们开发的应用程序都是采用直接连接数据库的模式:

image

接下来,将通过一些简单的调整,使得这个应用程序支持以 C/S 架构部署。整个过程只需要少量的代码:

image

包含以下步骤:

  • 添加服务端控制台应用程序项目
  • 修改客户端应用程序连接方式
  • 配置客户端应用程序
  • 运行示例
  • 代码下载

 

添加服务端控制台应用程序项目


在整个解决方案中添加一个新的控制台应用程序,取名为 ServerConsole:

image

为项目添加所有 Rafy 程序集、CS 实体程序集以及 System.ServiceModel 程序集的引用:

image

在 Main 函数中添加以下代码,启动服务端领域项目,并开始监听 WCF 端口:

   1:  using System;
   2:  using System.Collections.Generic;
   3:  using System.Linq;
   4:  using System.ServiceModel;
   5:  using System.Text;
   6:  using CS;
   7:  using Rafy;
   8:  using Rafy.Domain;
   9:   
  10:  namespace ServerConsole
  11:  {
  12:      class Program
  13:      {
  14:          static void Main(string[] args)
  15:          {
  16:              PluginTable.DomainLibraries.AddPlugin<CSPlugin>();
  17:              new DomainApp().Startup();
  18:   
  19:              using (ServiceHost serviceHost = new ServiceHost(typeof(Rafy.DataPortal.WCF.ServerPortal)))
  20:              {
  21:                  serviceHost.Open();
  22:                  Console.WriteLine("Press <enter> to terminate service");
  23:                  Console.ReadLine();
  24:                  serviceHost.Close();
  25:              }
  26:          }
  27:      }
  28:  }

然后,为本项目添加应用程序配置文件 App.config,代码如下:

   1:  <?xml version="1.0" encoding="utf-8" ?>
   2:  <configuration>
   3:      <appSettings>
   4:          <add key="SQL_TRACE_FILE" value="D:\SQLTraceLog.txt"/>
   5:      </appSettings>
   6:      <connectionStrings>
   7:          <add name="CS" connectionString="server=.\SQLExpress;database=ClothesSys;uid=sa;pwd=GIX4" providerName="System.Data.SqlClient"/>
   8:      </connectionStrings>
   9:      <system.serviceModel>
  10:          <services>
  11:              <service name="Rafy.DataPortal.WCF.ServerPortal" behaviorConfiguration="includesException">
  12:                  <endpoint address="/Text" binding="basicHttpBinding" contract="Rafy.DataPortal.WCF.IWcfPortal"/>
  13:                  <host>
  14:                      <baseAddresses>
  15:                          <add baseAddress="http://localhost:8000/RafyServer" />
  16:                      </baseAddresses>
  17:                  </host>
  18:              </service>
  19:          </services>
  20:          <behaviors>
  21:              <serviceBehaviors>
  22:                  <behavior name="includesException">
  23:                      <serviceMetadata httpGetEnabled="true" />
  24:                      <serviceDebug includeExceptionDetailInFaults="true" />
  25:                  </behavior>
  26:              </serviceBehaviors>
  27:          </behaviors>
  28:      </system.serviceModel>
  29:  </configuration>

 

修改客户端应用程序连接方式


接下来需要把界面程序变更为连接服务端。打开 ClothesSys 项目中的 Program.cs 文件,修改为以下代码:

   1:  static class Program
   2:  {
   3:      /// <summary>
   4:      /// 应用程序的主入口点。
   5:      /// </summary>
   6:      [STAThread]
   7:      static void Main()
   8:      {
   9:          PluginTable.DomainLibraries.AddPlugin<CSPlugin>();
  10:          new ClientDomainApp().Startup();
  11:   
  12:          Application.EnableVisualStyles();
  13:          Application.SetCompatibleTextRenderingDefault(false);
  14:          Application.Run(new formLogin());
  15:      }
  16:  }
  17:   
  18:  /// <summary>
  19:  /// 客户端使用的应用程序类型。
  20:  /// </summary>
  21:  public class ClientDomainApp : DomainApp
  22:  {
  23:      protected override void InitEnvironment()
  24:      {
  25:          RafyEnvironment.Location.DataPortalMode = DataPortalMode.ThroughService;
  26:   
  27:          base.InitEnvironment();
  28:      }
  29:  }

RafyEnvironment.Location.DataPortalMode 表示连接数据的模式,默认值是DataPortalMode.ConnectDirectly(直接连接数据库),ClientDomainApp 类把该值变更为 DataPortalMode. ThroughService(通过服务连接数据)。

 

配置客户端应用程序


在客户端配置文件中,删除数据库连接配置,并添加 WCF 连接配置,如下:

   1:  <?xml version="1.0"?>
   2:  <configuration>
   3:      <configSections>
   4:          <section name="rafy" type="Rafy.Configuration.RafyConfigurationSection, Rafy" />
   5:      </configSections>
   6:      <rafy
   7:          dataPortalProxy="Rafy.DataPortal.WCF.ClientProxy, Rafy.Domain"
   8:          collectDevLanguages="IsDebugging">
   9:      </rafy>
  10:      <system.serviceModel>
  11:          <client>
  12:              <endpoint name="ClientProxyEndPoint" address="http://localhost:8000/RafyServer/Text"
  13:                        binding="basicHttpBinding" bindingConfiguration="basicHttpBindingConfig"
  14:                        contract="Rafy.DataPortal.WCF.IWcfPortal" />
  15:          </client>
  16:          <bindings>
  17:              <basicHttpBinding>
  18:                  <binding name="basicHttpBindingConfig" receiveTimeout="00:20:00" sendTimeout="02:00:00" maxReceivedMessageSize="1000000000">
  19:                      <readerQuotas maxDepth="64" maxStringContentLength="2147483647" maxArrayLength="2147483647" maxBytesPerRead="4096" maxNameTableCharCount="16384"/>
  20:                  </binding>
  21:              </basicHttpBinding>
  22:          </bindings>
  23:      </system.serviceModel>
  24:  </configuration>

 

运行程序


先运行 ServerConsole,成功运行界面:

image

再运行 ClothesSys,点击登录。登录成功,即说明已经成功使用 C/S 进行部署。

imageimage

 

代码下载


下载地址:http://pan.baidu.com/s/1AB9TL

image

本文的代码在“3.使用 CS 部署程序”文件夹中。

 

欢迎试用 Rafy 领域实体框架,框架发布地址:http://www.cnblogs.com/zgynhqf/p/3356692.html

目录
相关文章
|
1月前
|
数据采集 监控 前端开发
二级公立医院绩效考核系统源码,B/S架构,前后端分别基于Spring Boot和Avue框架
医院绩效管理系统通过与HIS系统的无缝对接,实现数据网络化采集、评价结果透明化管理及奖金分配自动化生成。系统涵盖科室和个人绩效考核、医疗质量考核、数据采集、绩效工资核算、收支核算、工作量统计、单项奖惩等功能,提升绩效评估的全面性、准确性和公正性。技术栈采用B/S架构,前后端分别基于Spring Boot和Avue框架。
|
1月前
|
存储 分布式计算 关系型数据库
架构/技术框架调研
本文介绍了微服务间事务处理、调用、大数据处理、分库分表、大文本存储及数据缓存的最优解决方案。重点讨论了Seata、Dubbo、Hadoop生态系统、MyCat、ShardingSphere、对象存储服务和Redis等技术,提供了详细的原理、应用场景和优缺点分析。
|
2月前
|
分布式计算 资源调度 Hadoop
大数据-80 Spark 简要概述 系统架构 部署模式 与Hadoop MapReduce对比
大数据-80 Spark 简要概述 系统架构 部署模式 与Hadoop MapReduce对比
78 2
|
2月前
|
人工智能 前端开发 JavaScript
前端架构思考 :专注于多框架的并存可能并不是唯一的方向 — 探讨大模型时代前端的分层式微前端架构
随着前端技术的发展,微前端架构成为应对复杂大型应用的流行方案,允许多个团队使用不同技术栈并将其模块化集成。然而,这种设计在高交互性需求的应用中存在局限,如音视频处理、AI集成等。本文探讨了传统微前端架构的不足,并提出了一种新的分层式微前端架构,通过展示层与业务层的分离及基于功能的横向拆分,以更好地适应现代前端需求。
|
2月前
|
存储 分布式计算 API
大数据-107 Flink 基本概述 适用场景 框架特点 核心组成 生态发展 处理模型 组件架构
大数据-107 Flink 基本概述 适用场景 框架特点 核心组成 生态发展 处理模型 组件架构
99 0
|
4天前
|
Serverless 决策智能 UED
构建全天候自动化智能导购助手:从部署者的视角审视Multi-Agent架构解决方案
在构建基于多代理系统(Multi-Agent System, MAS)的智能导购助手过程中,作为部署者,我体验到了从初步接触到深入理解再到实际应用的一系列步骤。整个部署过程得到了充分的引导和支持,文档详尽全面,使得部署顺利完成,未遇到明显的报错或异常情况。尽管初次尝试时对某些复杂配置环节需反复确认,但整体流程顺畅。
|
1月前
|
监控
SMoA: 基于稀疏混合架构的大语言模型协同优化框架
通过引入稀疏化和角色多样性,SMoA为大语言模型多代理系统的发展开辟了新的方向。
44 6
SMoA: 基于稀疏混合架构的大语言模型协同优化框架
|
1月前
|
监控 安全 持续交付
构建高效的微服务架构:从设计到部署
构建高效的微服务架构:从设计到部署
24 1
|
1月前
|
Docker 微服务 容器
使用Docker Compose实现微服务架构的快速部署
使用Docker Compose实现微服务架构的快速部署
58 1
|
1月前
|
供应链 监控 安全
网络安全中的零信任架构:从概念到部署
网络安全中的零信任架构:从概念到部署