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

目录
相关文章
|
8天前
|
数据采集 监控 前端开发
二级公立医院绩效考核系统源码,B/S架构,前后端分别基于Spring Boot和Avue框架
医院绩效管理系统通过与HIS系统的无缝对接,实现数据网络化采集、评价结果透明化管理及奖金分配自动化生成。系统涵盖科室和个人绩效考核、医疗质量考核、数据采集、绩效工资核算、收支核算、工作量统计、单项奖惩等功能,提升绩效评估的全面性、准确性和公正性。技术栈采用B/S架构,前后端分别基于Spring Boot和Avue框架。
|
27天前
|
分布式计算 资源调度 Hadoop
大数据-80 Spark 简要概述 系统架构 部署模式 与Hadoop MapReduce对比
大数据-80 Spark 简要概述 系统架构 部署模式 与Hadoop MapReduce对比
59 2
|
13天前
|
人工智能 前端开发 JavaScript
前端架构思考 :专注于多框架的并存可能并不是唯一的方向 — 探讨大模型时代前端的分层式微前端架构
随着前端技术的发展,微前端架构成为应对复杂大型应用的流行方案,允许多个团队使用不同技术栈并将其模块化集成。然而,这种设计在高交互性需求的应用中存在局限,如音视频处理、AI集成等。本文探讨了传统微前端架构的不足,并提出了一种新的分层式微前端架构,通过展示层与业务层的分离及基于功能的横向拆分,以更好地适应现代前端需求。
|
27天前
|
存储 分布式计算 API
大数据-107 Flink 基本概述 适用场景 框架特点 核心组成 生态发展 处理模型 组件架构
大数据-107 Flink 基本概述 适用场景 框架特点 核心组成 生态发展 处理模型 组件架构
72 0
|
3月前
|
负载均衡 应用服务中间件 持续交付
微服务架构下的Web服务器部署
【8月更文第28天】随着互联网应用的不断发展,传统的单体应用架构逐渐显露出其局限性,特别是在可扩展性和维护性方面。为了解决这些问题,微服务架构应运而生。微服务架构通过将应用程序分解成一系列小型、独立的服务来提高系统的灵活性和可维护性。本文将探讨如何在微服务架构中有效部署和管理Web服务器实例,并提供一些实际的代码示例。
103 0
|
27天前
|
JSON 前端开发 Java
Spring Boot框架中的响应与分层解耦架构
在Spring Boot框架中,响应与分层解耦架构是两个核心概念,它们共同促进了应用程序的高效性、可维护性和可扩展性。
44 3
|
2月前
|
机器学习/深度学习
ACM MM24:复旦提出首个基于扩散模型的视频非限制性对抗攻击框架,主流CNN和ViT架构都防不住它
【9月更文挑战第23天】复旦大学研究团队提出了ReToMe-VA,一种基于扩散模型的视频非限制性对抗攻击框架,通过时间步长对抗性潜在优化(TALO)与递归令牌合并(ReToMe)策略,实现了高转移性且难以察觉的对抗性视频生成。TALO优化去噪步骤扰动,提升空间难以察觉性及计算效率;ReToMe则确保时间一致性,增强帧间交互。实验表明,ReToMe-VA在攻击转移性上超越现有方法,但面临计算成本高、实时应用受限及隐私安全等挑战。[论文链接](http://arxiv.org/abs/2408.05479)
69 3
|
2月前
|
Kubernetes Java Android开发
用 Quarkus 框架优化 Java 微服务架构的设计与实现
Quarkus 是专为 GraalVM 和 OpenJDK HotSpot 设计的 Kubernetes Native Java 框架,提供快速启动、低内存占用及高效开发体验,显著优化了 Java 在微服务架构中的表现。它采用提前编译和懒加载技术实现毫秒级启动,通过优化类加载机制降低内存消耗,并支持多种技术和框架集成,如 Kubernetes、Docker 及 Eclipse MicroProfile,助力开发者轻松构建强大微服务应用。例如,在电商场景中,可利用 Quarkus 快速搭建商品管理和订单管理等微服务,提升系统响应速度与稳定性。
56 5
|
28天前
|
存储 SQL 消息中间件
Hadoop-26 ZooKeeper集群 3台云服务器 基础概念简介与环境的配置使用 架构组成 分布式协调框架 Leader Follower Observer
Hadoop-26 ZooKeeper集群 3台云服务器 基础概念简介与环境的配置使用 架构组成 分布式协调框架 Leader Follower Observer
42 0
|
2月前
|
运维 Cloud Native Devops
云原生架构的崛起与实践云原生架构是一种通过容器化、微服务和DevOps等技术手段,帮助应用系统实现敏捷部署、弹性扩展和高效运维的技术理念。本文将探讨云原生的概念、核心技术以及其在企业中的应用实践,揭示云原生如何成为现代软件开发和运营的主流方式。##
云原生架构是现代IT领域的一场革命,它依托于容器化、微服务和DevOps等核心技术,旨在解决传统架构在应对复杂业务需求时的不足。通过采用云原生方法,企业可以实现敏捷部署、弹性扩展和高效运维,从而大幅提升开发效率和系统可靠性。本文详细阐述了云原生的核心概念、主要技术和实际应用案例,并探讨了企业在实施云原生过程中的挑战与解决方案。无论是正在转型的传统企业,还是寻求创新的互联网企业,云原生都提供了一条实现高效能、高灵活性和高可靠性的技术路径。 ##
164 3

热门文章

最新文章