Rafy 领域实体框架演示(3) - 快速使用 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 部署程序”文件夹中。

 

本文转自BloodyAngel博客园博客,原文链接:http://www.cnblogs.com/zgynhqf/p/3421517.html,如需转载请自行联系原作者

相关文章
|
29天前
|
算法 数据挖掘 调度
隐语实训营-第3讲:详解隐私计算框架的架构和技术要点
主要介绍隐语的隐私计算架构,并对每个模块进行拆解、分析,以期望不同使用者找到适合自己的模块,快速入手。
46 4
|
2月前
|
监控 负载均衡 Dubbo
Dubbo 框架揭秘:分布式架构的精髓与魔法【一】
Dubbo 框架揭秘:分布式架构的精髓与魔法【一】
161 0
|
29天前
|
分布式计算 算法 调度
课3-详解隐私计算框架的架构和技术要点
隐语架构涵盖产品、算法、计算、资源和硬件五层,旨在实现互联互通和跨域管控。产品层包括SecretPad等,简化用户和集成商体验。算法层涉及PSI/PIR、SCQL和联邦学习,提供隐私保护的数据分析和学习。计算层如RayFed、SPU、HEU等,支持分布式计算和密态处理。资源层的KUSCIA用于跨机构任务编排,硬件层涉及FPGA等加速器。互联互通支持黑盒和白盒模式,确保不同平台协作。跨域管控则强调数据流转控制,保护数据权益。
|
4月前
|
前端开发 数据库 Python
Python Web 开发: 解释 Django 框架的 MVC 架构是什么?
Python Web 开发: 解释 Django 框架的 MVC 架构是什么?
|
29天前
|
算法
隐私计算实训营 第1期-详解隐私计算框架的架构和技术要点
本文简要介绍了隐语技术架构的五层结构:产品层、算法层、计算层、资源层和硬件层。每层分别涉及模块功能、定位和人群画像,旨在使不同角色的用户能轻松理解和使用,降低隐私计算的入门难度。此外,隐语产品设计具有开放性和前瞻性,易于集成。
|
1月前
|
SQL API 数据处理
新一代实时数据集成框架 Flink CDC 3.0 —— 核心技术架构解析
本文整理自阿里云开源大数据平台吕宴全关于新一代实时数据集成框架 Flink CDC 3.0 的核心技术架构解析。
688 0
新一代实时数据集成框架 Flink CDC 3.0 —— 核心技术架构解析
|
1月前
|
Kubernetes 测试技术 持续交付
探索微服务架构下的持续集成与部署最佳实践
本文将深入探讨在微服务架构下实施持续集成与部署的最佳实践,介绍如何利用现代化工具和流程来实现自动化测试、持续集成、灰度发布等关键环节,帮助开发团队提升交付效率和质量。
|
2月前
|
KVM 虚拟化 Android开发
DP读书:鲲鹏处理器 架构与编程(十二)鲲鹏软件实战案例Docker+KVM的部署
DP读书:鲲鹏处理器 架构与编程(十二)鲲鹏软件实战案例Docker+KVM的部署
52 1
|
2月前
|
云计算 开发者 Docker
深入浅出:使用Docker部署微服务架构
在当今快速迭代的软件开发环境中,微服务架构凭借其灵活性和可扩展性成为了热门趋势。本文将探讨如何利用Docker这一强大的容器化技术,简化和加速微服务应用的部署与管理过程。我们将从微服务的基本概念出发,逐步深入到Docker的核心功能,最后通过一个实际案例演示整个部署流程。文章旨在为开发者提供一个清晰、实用的指南,帮助他们有效地利用Docker在微服务架构下的应用部署。
26 0
|
2月前
|
前端开发 JavaScript API